forked from amberisvibin/chibi-pc09
		
	Compare commits
	
		
			14 Commits
		
	
	
		
			5bd4c7ae15
			...
			main
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e3352fab06 | |||
| b4d44f4e84 | |||
| da1d22988e | |||
| cc8a9fc95f | |||
| a0427ad949 | |||
| 0845370c43 | |||
| 347b6fa236 | |||
| 677b3cb02d | |||
| c67176e99a | |||
| 9c668967d5 | |||
| 53c6c7fd78 | |||
| 08b85a186e | |||
| 9f28e315b7 | |||
| 69836aa24b | 
| @@ -27,4 +27,4 @@ Assembly is in progress. | |||||||
|  |  | ||||||
| ## License | ## License | ||||||
|  |  | ||||||
| This project is licensed under the MIT license. This applies to both the hardware (schematics, bill of materials, pcb layouts) and documentation. This does *not* apply to the datasheets/ directory, the books/ directory or code/assist09/. Those files belong to their respective copyright holders. | This project is licensed under the MIT license. This applies to both the hardware (schematics, bill of materials, pcb layouts) and documentation. This does *not* apply to the datasheets/ directory or code/assist09/. Those files belong to their respective copyright holders. | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								books/as11v2.pdf
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								books/as11v2.pdf
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								books/manual.pdf
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								books/manual.pdf
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										3
									
								
								code/boot/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								code/boot/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -5,3 +5,6 @@ | |||||||
| *.s19 | *.s19 | ||||||
| map.txt | map.txt | ||||||
| build/ | build/ | ||||||
|  |  | ||||||
|  | # Build system generated files | ||||||
|  | src/version.s | ||||||
|   | |||||||
| @@ -1,31 +1,37 @@ | |||||||
| # Boot Firmware for CHIBI PC-09 | # Boot Firmware for CHIBI PC-09 | ||||||
|  |  | ||||||
| TODO: Description of what the firmware does for the PC-09. | This is the firmware for the CHIBI PC-09. In the future it will provide the | ||||||
|  | CHIBI with initialization code, a UART driver, some self test features. | ||||||
|  |  | ||||||
| ## Building the Firmware | ## Building the Firmware | ||||||
|  |  | ||||||
| You will need GNU `make`, and [`asm6809`](https://www.6809.org.uk/asm6809) to | Building the firmware from source requires [LWTOOLS](http://www.lwtools.ca/) for | ||||||
| build the firmware. Obtaining a working copy of `asm6809` could be difficult if | building S-Records of the ROM, and `mot2bin` from | ||||||
| you aren't on Debian, Ubuntu, or Windows as instructions for building it are not | [F9DASM](https://github.com/Arakula/f9dasm) for building binary images. A GNU | ||||||
| given on the `asm6809` website. Functional instructions for building from Git or | Make makefile is provided for building on Linux. | ||||||
| tarball are given here: |  | ||||||
|  | ### Using the Makefile | ||||||
|  |  | ||||||
|  | To generate an S-Record run: | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| git clone https://www.6809.org.uk/git/asm6809.git | make generate | ||||||
| cd asm6809 | make boot.s19 | ||||||
| ./configure |  | ||||||
| make |  | ||||||
| sudo make install |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| From there all you should have to do to generate a `boot.bin` is: | To generate a binary run: | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| git clone https://github.com/amberisvibin/chibi-pc09.git | make generate | ||||||
| cd chibi-pc09 |  | ||||||
| make | make | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | The makefile also can clean up after itself: | ||||||
|  |  | ||||||
|  | ```sh | ||||||
|  | make clean | ||||||
|  | ``` | ||||||
|  |  | ||||||
| ## Firmware Licensing | ## Firmware Licensing | ||||||
|  |  | ||||||
| This firmware like the rest of the CHIBI PC-09 is licensed under the MIT | This firmware like the rest of the CHIBI PC-09 is licensed under the MIT | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								code/boot/genver.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										33
									
								
								code/boot/genver.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | #!/usr/bin/env sh | ||||||
|  |  | ||||||
|  | # Script to generate version information | ||||||
|  |  | ||||||
|  | # Current git tag | ||||||
|  | TAG="$(git describe --always --dirty --tags)" | ||||||
|  | DATE="$(date)" | ||||||
|  |  | ||||||
|  | # Output filename | ||||||
|  | OUTFILE='src/version.s' | ||||||
|  |  | ||||||
|  | sed -e "s/<TAG>/$TAG/g" -e "s/<DATE>/$DATE/g" <<EOF > "$OUTFILE" | ||||||
|  | ; CHIBI PC-09 Prototype #1 Boot ROM -- Version Information | ||||||
|  | ; Copyright (c) 2024-2025 Amber Zeller, Gale Faraday | ||||||
|  | ; Licensed under MIT | ||||||
|  |  | ||||||
|  | ; This file generated by genver.sh | ||||||
|  |  | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  | ;; | ||||||
|  | ;; Boot ROM Version & Build Information | ||||||
|  | ;; | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION VERSION | ||||||
|  |  | ||||||
|  |   EXPORT VERMSG | ||||||
|  |  | ||||||
|  | VERMSG | ||||||
|  |   fcc "CHIBI PC-09 BOOT ROM <TAG>" | ||||||
|  |   fcb \$0A | ||||||
|  |   fcn "BUILT <DATE>" | ||||||
|  | EOF | ||||||
							
								
								
									
										6
									
								
								code/boot/linkscript
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								code/boot/linkscript
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | section RESET load 8000 | ||||||
|  | section SERIAL | ||||||
|  | section MEMTEST | ||||||
|  |  | ||||||
|  | section VECTORS high 100000 | ||||||
|  | section VERSION high | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| # Makefile for CHIBI PC-09 Firmware | # Makefile for CHIBI PC-09 Firmware | ||||||
|  |  | ||||||
| .PHONY: all clean | .PHONY: generate all clean | ||||||
| .IGNORE: clean | .IGNORE: clean | ||||||
| .DEFAULT_GOAL := all | .DEFAULT_GOAL := all | ||||||
|  |  | ||||||
| @@ -8,26 +8,52 @@ | |||||||
| # Project Defaults & Folders | # Project Defaults & Folders | ||||||
| # ------------------------------------------------------------------------------ | # ------------------------------------------------------------------------------ | ||||||
|  |  | ||||||
| TARGET  := boot.bin | TARGET   := boot | ||||||
|  | TARGREC  := $(TARGET).s19 | ||||||
|  | TARGROM  := $(TARGET).bin | ||||||
| SRCDIR   := src/ | SRCDIR   := src/ | ||||||
| MAINSRC := $(SRCDIR)boot.s | BUILDDIR := build/ | ||||||
|  | GENS     := $(SRCDIR)version.s | ||||||
| SRCS     := $(wildcard $(SRCDIR)*.s) | SRCS     := $(wildcard $(SRCDIR)*.s) | ||||||
|  | OBJS     := $(patsubst $(SRCDIR)%.s,$(BUILDDIR)%.o,$(SRCS)) | ||||||
| INCS     := $(wildcard $(SRCDIR)*.inc) | INCS     := $(wildcard $(SRCDIR)*.inc) | ||||||
|  |  | ||||||
| # ------------------------------------------------------------------------------ | # ------------------------------------------------------------------------------ | ||||||
| # Toolchain Definitions | # Toolchain Definitions | ||||||
| # ------------------------------------------------------------------------------ | # ------------------------------------------------------------------------------ | ||||||
|  |  | ||||||
| AS := asm6809 | AS  := lwasm | ||||||
|  | LD  := lwlink | ||||||
|  | FIX := objcopy | ||||||
|  |  | ||||||
|  | ASFLAGS := -f obj | ||||||
|  | LDFLAGS := -f srec -m map.txt -s linkscript | ||||||
|  |  | ||||||
| # ------------------------------------------------------------------------------ | # ------------------------------------------------------------------------------ | ||||||
| # Rules and Phony Targets | # Rules and Phony Targets | ||||||
| # ------------------------------------------------------------------------------ | # ------------------------------------------------------------------------------ | ||||||
|  |  | ||||||
| all: $(TARGET) | all: $(TARGROM) | ||||||
|  |  | ||||||
| $(TARGET): $(SRCS) $(INCS) | # Fix srec into flashable bin file | ||||||
| 	$(AS) -o $(TARGET) $(MAINSRC) | $(TARGROM): $(TARGREC) | ||||||
|  | 	$(FIX) -I srec -O binary $< $@ | ||||||
|  |  | ||||||
|  | # Link objects | ||||||
|  | $(TARGREC): $(OBJS) | ||||||
|  | 	$(LD) $(LDFLAGS) -o $@ $^ | ||||||
|  |  | ||||||
|  | # Assemble objects | ||||||
|  | $(OBJS): $(BUILDDIR)%.o : $(SRCDIR)%.s | ||||||
|  | 	-@mkdir -p $(BUILDDIR) | ||||||
|  | 	$(AS) $(ASFLAGS) -o $@ $< | ||||||
|  |  | ||||||
|  | generate: $(GENS) | ||||||
|  |  | ||||||
|  | $(GENS): | ||||||
|  | 	./genver.sh | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	rm -v $(TARGET) | 	@echo 'Cleaning up intermediary files...' | ||||||
|  | 	@rm -rv $(TARGROM) $(TARGREC) map.txt $(BUILDDIR) | ||||||
|  | 	@rm -rv $(GENS) | ||||||
|   | |||||||
| @@ -1,118 +0,0 @@ | |||||||
| ; CHIBI PC-09 Prototype #1 Boot ROM -- Hardware Initialization and Reset Vecs |  | ||||||
| ; Copyright (c) 2024 Amber Zeller, Gale Faraday |  | ||||||
| ; Licensed under MIT |  | ||||||
|  |  | ||||||
|   INCLUDE "src/hardware.inc" |  | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |  | ||||||
| ;; |  | ||||||
| ;; Hardware Initialization Routines |  | ||||||
| ;; |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |  | ||||||
|  |  | ||||||
|   SECTION "Reset" |  | ||||||
|   ORG ROM_BASE |  | ||||||
|  |  | ||||||
| RESET |  | ||||||
|   ; 8n1 Serial Enable DLAB |  | ||||||
|   lda #(UARTF_LCR_WLS | UARTF_LCR_DLAB) |  | ||||||
|   sta UART_LCR |  | ||||||
|  |  | ||||||
|   ; REVIEW: Potential endianness hiccough here |  | ||||||
|   ldd #$0C00           ; Set divisor to 12 (9600 baud) |  | ||||||
|   sta UART_DLM |  | ||||||
|   stb UART_DLL |  | ||||||
|  |  | ||||||
|   lda #(UARTF_LCR_WLS) ; 8n1 serial, disable DLAB |  | ||||||
|   sta UART_LCR |  | ||||||
|  |  | ||||||
|   lda #(UARTF_MCR_RTS) ; Enable Request-to-Send |  | ||||||
|   sta UART_MCR |  | ||||||
|  |  | ||||||
|   lda 'H               ; send 'H' |  | ||||||
|   sta UART_BUFR |  | ||||||
|  |  | ||||||
| WAIT |  | ||||||
|   sync                 ; Wait for interrupts |  | ||||||
|   nop |  | ||||||
|   bra WAIT |  | ||||||
|  |  | ||||||
|   SECTION "Serial" |  | ||||||
|  |  | ||||||
| ; Writes a char to the UART in non FIFO mode, preserves A. |  | ||||||
| ; @param b: char to write |  | ||||||
| OUTCHAR |  | ||||||
|   pshs a               ; Preserve A |  | ||||||
| 1 |  | ||||||
|   lda UART_LSR         ; if LSR.THRE == 1 then write |  | ||||||
|   anda UARTF_LSR_THRE |  | ||||||
|   bne 1B               ; Loop if UART not ready yet |  | ||||||
|   stb UART_BUFR        ; Write char |  | ||||||
|   puls a               ; Restore A |  | ||||||
|   rts |  | ||||||
|  |  | ||||||
| ; Writes a null terminated string to the UART in non FIFO mode, clobbers A and |  | ||||||
| ; B. |  | ||||||
| ; @param x: null terminated string start address. |  | ||||||
| OUTSTR |  | ||||||
|   ldb x                ; Get the next value from X |  | ||||||
|   cmpb #$00            ; Make sure that mother is non-null |  | ||||||
|   beq 2F |  | ||||||
|   leax 1,x             ; Increment X for our next char |  | ||||||
| 1                      ; Loop point for UART waiting |  | ||||||
|   lda UART_LSR         ; Wait for UART to be ready |  | ||||||
|   anda UARTF_LSR_THRE |  | ||||||
|   bne 1B |  | ||||||
|   stb UART_BUFR        ; Actually do our write |  | ||||||
|   bra OUTSTR           ; Reset for the next char |  | ||||||
| 2                      ; Jump point for end of routine |  | ||||||
|   rts |  | ||||||
|  |  | ||||||
|   SECTION "Memtest" |  | ||||||
|  |  | ||||||
| ; RAM testing routine. Ported to 6809 from 6800, based on source for ROBIT-2 for |  | ||||||
| ; MIKBUG. |  | ||||||
| RAMTEST |  | ||||||
|   ldx #SRAM_BASE |  | ||||||
| 1                      ; Store 1 in memory |  | ||||||
|   lda #1               ; Set [X] to 1 |  | ||||||
|   sta 0,x |  | ||||||
|   cmpa 0,x             ; If failed print out an error indicator |  | ||||||
|   bne 3F |  | ||||||
| 2                      ; Loop point for next address |  | ||||||
|   asla                 ; Shift A and [X] left |  | ||||||
|   asl 0,x |  | ||||||
|   cmpa 0,x             ; Compare A and [X] |  | ||||||
|   bne 3F |  | ||||||
|   cmpa #$80            ; Only test up to $80 |  | ||||||
|   bne 2B               ; Loop if not $80 |  | ||||||
|   cmpx #$60FF          ; Compare X to end of RAM |  | ||||||
|   beq 4F               ; Finish if we're at the end |  | ||||||
|   leax 1,x             ; Increment X |  | ||||||
|   bra 1B |  | ||||||
| 3                      ; Write out error indicator |  | ||||||
|   ldb #'X |  | ||||||
|   jsr OUTCHAR |  | ||||||
| 4                      ; Pass test |  | ||||||
|   ldb #'P |  | ||||||
|   jsr OUTCHAR |  | ||||||
|   rts |  | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |  | ||||||
| ;; |  | ||||||
| ;; Interrupt and Reset Vectors |  | ||||||
| ;; |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |  | ||||||
|  |  | ||||||
|   SECTION "Vectors" |  | ||||||
|   ORG VECS_BASE |  | ||||||
|  |  | ||||||
| VECTORS |  | ||||||
|   fdb $0000 ; Reserved |  | ||||||
|   fdb $0000 ; SWI3 |  | ||||||
|   fdb $0000 ; SWI2 |  | ||||||
|   fdb $0000 ; FIRQ |  | ||||||
|   fdb $0000 ; IRQ |  | ||||||
|   fdb $0000 ; SWI |  | ||||||
|   fdb $0000 ; NMI |  | ||||||
|   fdb RESET ; Reset |  | ||||||
| @@ -1,7 +1,9 @@ | |||||||
| ; CHIBI PC-09 Hardware Definitions | ; CHIBI PC-09 Hardware Definitions | ||||||
| ; Copyright (c) 2024 Amber Zeller, Gale Faraday | ; Copyright (c) 2024-2025 Amber Zeller, Gale Faraday | ||||||
| ; Licensed under MIT | ; Licensed under MIT | ||||||
|  |  | ||||||
|  | ; vim: ft=asm | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
| ;; | ;; | ||||||
| ;; Hardware Base Addresses | ;; Hardware Base Addresses | ||||||
| @@ -13,6 +15,16 @@ UART_BASE EQU $7F00 ; UART Base Address | |||||||
| ROM_BASE  EQU $8000 ; ROM Base Address and Entry Point | ROM_BASE  EQU $8000 ; ROM Base Address and Entry Point | ||||||
| VECS_BASE EQU $FFF0 ; Vectors Base Address | VECS_BASE EQU $FFF0 ; Vectors Base Address | ||||||
|  |  | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  | ;; | ||||||
|  | ;; Stack Base Address and Size Information | ||||||
|  | ;; | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  | STACK_BOTTOM EQU $0100 ; Bottom address of system stack | ||||||
|  | STACK_DEPTH  EQU $FF   ; System stack's depth | ||||||
|  | STACK_TOP    EQU STACK_BOTTOM+STACK_DEPTH ; Top address of system stack | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
| ;; | ;; | ||||||
| ;; UART Registers and Flags | ;; UART Registers and Flags | ||||||
| @@ -23,20 +35,20 @@ VECS_BASE EQU $FFF0 ; Vectors Base Address | |||||||
| UART_BUFR EQU UART_BASE  ; TX/RX Buffer (Read for RX, Write for TX) | UART_BUFR EQU UART_BASE  ; TX/RX Buffer (Read for RX, Write for TX) | ||||||
| UART_RBR EQU UART_BASE   ; RX Buffer Register | UART_RBR EQU UART_BASE   ; RX Buffer Register | ||||||
| UART_THR EQU UART_BASE   ; TX Holding Register | UART_THR EQU UART_BASE   ; TX Holding Register | ||||||
| UART_IER EQU UART_BASE + 1 ; Interrupt Enable Register | UART_IER EQU UART_BASE+1 ; Interrupt Enable Register | ||||||
|  |  | ||||||
| ; When UARTF_LCR_DLAB = 1: | ; When UARTF_LCR_DLAB = 1: | ||||||
| UART_DLL EQU UART_BASE   ; Divisor Latch (LSB) | UART_DLL EQU UART_BASE   ; Divisor Latch (LSB) | ||||||
| UART_DLM EQU UART_BASE + 1 ; Divisor Latch (MSB) | UART_DLM EQU UART_BASE+1 ; Divisor Latch (MSB) | ||||||
|  |  | ||||||
| ; Independent of DLAB: | ; Independent of DLAB: | ||||||
| UART_IIR EQU UART_BASE + 2 ; Interrupt Ident Register (Upon Read) | UART_IIR EQU UART_BASE+2 ; Interrupt Ident Register (Upon Read) | ||||||
| UART_FCR EQU UART_BASE + 2 ; FIFO Control Register (Upon Write) | UART_FCR EQU UART_BASE+2 ; FIFO Control Register (Upon Write) | ||||||
| UART_LCR EQU UART_BASE + 3 ; Line Control Register | UART_LCR EQU UART_BASE+3 ; Line Control Register | ||||||
| UART_MCR EQU UART_BASE + 4 ; MODEM Control Register | UART_MCR EQU UART_BASE+4 ; MODEM Control Register | ||||||
| UART_LSR EQU UART_BASE + 5 ; Line Status Register | UART_LSR EQU UART_BASE+5 ; Line Status Register | ||||||
| UART_MSR EQU UART_BASE + 6 ; MODEM Status Register | UART_MSR EQU UART_BASE+6 ; MODEM Status Register | ||||||
| UART_SCR EQU UART_BASE + 7 ; Scratch Register (Not for control just spare RAM) | UART_SCR EQU UART_BASE+7 ; Scratch Register (Not for control just spare RAM) | ||||||
|  |  | ||||||
| ; UART Flags for Interrupt Enable Register: | ; UART Flags for Interrupt Enable Register: | ||||||
| UARTF_IER_ERBFI EQU %10000000 ; Enable Received Data Available Interrupt | UARTF_IER_ERBFI EQU %10000000 ; Enable Received Data Available Interrupt | ||||||
| @@ -93,4 +105,3 @@ UARTF_MSR_DSR  EQU %00000100 ; Data Set Ready | |||||||
| UARTF_MSR_RI   EQU %00000010 ; Ring Indicator | UARTF_MSR_RI   EQU %00000010 ; Ring Indicator | ||||||
| UARTF_MSR_DCD  EQU %00000001 ; Data Carrier Detect | UARTF_MSR_DCD  EQU %00000001 ; Data Carrier Detect | ||||||
|  |  | ||||||
| ; vim: ft=asm |  | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								code/boot/src/memtest.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								code/boot/src/memtest.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | ; CHIBI PC-09 Prototype #1 Boot ROM -- Memory Testing Routines | ||||||
|  | ; Copyright (c) 2024-2025 Amber Zeller, Gale Faraday | ||||||
|  | ; Licensed under MIT | ||||||
|  |  | ||||||
|  |   INCLUDE "hardware.inc" | ||||||
|  |   INCLUDE "serial.inc" | ||||||
|  |  | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  | ;; | ||||||
|  | ;; Memory Testing Routines | ||||||
|  | ;; | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION MEMTEST | ||||||
|  |  | ||||||
|  | ; RAM testing routine. Ported to 6809 from 6800, based on source for ROBIT-2 for | ||||||
|  | ; MIKBUG. | ||||||
|  | RAMTEST | ||||||
|  |   ldx #SRAM_BASE | ||||||
|  | AGAIN@                 ; Store 1 in memory | ||||||
|  |   lda #1               ; Set [X] to 1 | ||||||
|  |   sta 0,x | ||||||
|  |   cmpa 0,x             ; If failed print out an error indicator | ||||||
|  |   bne ERR@ | ||||||
|  | NEXT@                  ; Loop point for next address | ||||||
|  |   asla                 ; Shift A and [X] left | ||||||
|  |   asl 0,x | ||||||
|  |   cmpa 0,x             ; Compare A and [X] | ||||||
|  |   bne ERR@ | ||||||
|  |   cmpa #$80            ; Only test up to $80 | ||||||
|  |   bne NEXT@            ; Loop if not $80 | ||||||
|  |   cmpx #$60FF          ; Compare X to end of RAM | ||||||
|  |   beq PASS@            ; Finish if we're at the end | ||||||
|  |   leax 1,x             ; Increment X | ||||||
|  |   bra AGAIN@ | ||||||
|  | ERR@                   ; Write out error indicator | ||||||
|  |   ldb #'X | ||||||
|  |   jsr OUTCHAR | ||||||
|  | PASS@                  ; Pass test | ||||||
|  |   ldb #'P | ||||||
|  |   jsr OUTCHAR | ||||||
|  |   rts | ||||||
							
								
								
									
										7
									
								
								code/boot/src/reset.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								code/boot/src/reset.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | ; CHIBI PC-09 Prototype #1 -- Reset Handler Header | ||||||
|  | ; Copyright (c) 2025 Amber Zeller, Gale Faraday | ||||||
|  | ; Licensed under MIT | ||||||
|  |  | ||||||
|  | ; vim: ft=asm | ||||||
|  |  | ||||||
|  | RESET IMPORT | ||||||
							
								
								
									
										49
									
								
								code/boot/src/reset.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								code/boot/src/reset.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | |||||||
|  | ; CHIBI PC-09 Prototype #1 Boot ROM -- Reset Handler | ||||||
|  | ; Copyright (c) 2024-2025 Amber Zeller, Gale Faraday | ||||||
|  | ; Licensed under MIT | ||||||
|  |  | ||||||
|  |   INCLUDE "hardware.inc" | ||||||
|  |   INCLUDE "serial.inc" | ||||||
|  |  | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  | ;; | ||||||
|  | ;; Hardware Initialization Routines | ||||||
|  | ;; | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION RESET | ||||||
|  |  | ||||||
|  |   EXPORT RESET | ||||||
|  |  | ||||||
|  | RESET | ||||||
|  |  | ||||||
|  | CLRSTACK | ||||||
|  |   ; Initialize the system stack | ||||||
|  |   lda #$00           ; Initialize A & X to zero out the stack | ||||||
|  |   ldx #$0000 | ||||||
|  | NEXT@ | ||||||
|  |   sta STACK_BOTTOM,x ; Write a zero and progress to the next byte | ||||||
|  |   leax 1,x | ||||||
|  |   cmpx #STACK_DEPTH  ; See if we're at the top of the stack yet | ||||||
|  |   blo NEXT@          ; Loop if we aren't at the end yet | ||||||
|  |   lds #STACK_TOP     ; Set S to top of newly cleared stack | ||||||
|  |  | ||||||
|  | SERINIT | ||||||
|  |   ; 8n1 Serial Enable DLAB | ||||||
|  |   lda #UARTF_LCR_WLS|UARTF_LCR_DLAB | ||||||
|  |   sta UART_LCR | ||||||
|  |   ; REVIEW: Potential endianness hiccough here | ||||||
|  |   ldd #$0C00           ; Set divisor to 12 (9600 baud) | ||||||
|  |   sta UART_DLM | ||||||
|  |   stb UART_DLL | ||||||
|  |   lda #(UARTF_LCR_WLS) ; 8n1 serial, disable DLAB | ||||||
|  |   sta UART_LCR | ||||||
|  |   lda #(UARTF_MCR_RTS) ; Enable Request-to-Send | ||||||
|  |   sta UART_MCR | ||||||
|  |   lda #'H              ; send 'H' | ||||||
|  |   sta UART_BUFR | ||||||
|  |  | ||||||
|  | WAIT | ||||||
|  |   sync                 ; Wait for interrupts | ||||||
|  |   nop | ||||||
|  |   bra WAIT | ||||||
							
								
								
									
										8
									
								
								code/boot/src/serial.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								code/boot/src/serial.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | ; CHIBI PC-09 Prototype #1 -- Serial Driver Header | ||||||
|  | ; Copyright (c) 2025 Amber Zeller, Gale Faraday | ||||||
|  | ; Licensed under MIT | ||||||
|  |  | ||||||
|  | ; vim: ft=asm | ||||||
|  |  | ||||||
|  | OUTCHAR IMPORT | ||||||
|  | OUTSTR IMPORT | ||||||
							
								
								
									
										45
									
								
								code/boot/src/serial.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								code/boot/src/serial.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | |||||||
|  | ; CHIBI PC-09 Prototype #1 Boot ROM -- Serial Driver | ||||||
|  | ; Copyright (c) 2024-2025 Amber Zeller, Gale Faraday | ||||||
|  | ; Licensed under MIT | ||||||
|  |  | ||||||
|  |   INCLUDE "hardware.inc" | ||||||
|  |  | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  | ;; | ||||||
|  | ;; Serial UART Driver | ||||||
|  | ;; | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION SERIAL | ||||||
|  |  | ||||||
|  |   EXPORT OUTCHAR | ||||||
|  |   EXPORT OUTSTR | ||||||
|  |  | ||||||
|  | ; Writes a char to the UART in non FIFO mode, preserves A. | ||||||
|  | ; @param b: char to write | ||||||
|  | OUTCHAR | ||||||
|  |   pshs a               ; Preserve A | ||||||
|  | NOTREADY@ | ||||||
|  |   lda UART_LSR         ; if LSR.THRE == 1 then write | ||||||
|  |   anda UARTF_LSR_THRE | ||||||
|  |   bne NOTREADY@        ; Loop if UART not ready yet | ||||||
|  |   stb UART_BUFR        ; Write char | ||||||
|  |   puls a               ; Restore A | ||||||
|  |   rts | ||||||
|  |  | ||||||
|  | ; Writes a null terminated string to the UART in non FIFO mode, clobbers A and | ||||||
|  | ; B. | ||||||
|  | ; @param x: null terminated string start address. | ||||||
|  | OUTSTR | ||||||
|  |   ldb 0,x              ; Get the next value from X | ||||||
|  |   cmpb #$00            ; Make sure that we aren't at a terminator | ||||||
|  |   beq END@ | ||||||
|  |   leax 1,x             ; Increment X for our next char | ||||||
|  | NOTREADY@              ; Loop point for UART waiting | ||||||
|  |   lda UART_LSR         ; Wait for UART to be ready | ||||||
|  |   anda UARTF_LSR_THRE | ||||||
|  |   bne NOTREADY@ | ||||||
|  |   stb UART_BUFR        ; Actually do our write | ||||||
|  |   bra OUTSTR           ; Reset for the next char | ||||||
|  | END@                   ; Jump point for end of routine | ||||||
|  |   rts | ||||||
							
								
								
									
										23
									
								
								code/boot/src/vecs.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								code/boot/src/vecs.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | ; CHIBI PC-09 Prototype #1 Boot ROM -- Interrupt and Reset Vectors | ||||||
|  | ; Copyright (c) 2024-2025 Amber Zeller, Gale Faraday | ||||||
|  | ; Licensed under MIT | ||||||
|  |  | ||||||
|  |   INCLUDE "reset.inc" | ||||||
|  |  | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  | ;; | ||||||
|  | ;; Interrupt and Reset Vectors | ||||||
|  | ;; | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION VECTORS | ||||||
|  |  | ||||||
|  | VECTORS | ||||||
|  |   fdb $0000 ; Reserved | ||||||
|  |   fdb $0000 ; SWI3 | ||||||
|  |   fdb $0000 ; SWI2 | ||||||
|  |   fdb $0000 ; FIRQ | ||||||
|  |   fdb $0000 ; IRQ | ||||||
|  |   fdb $0000 ; SWI | ||||||
|  |   fdb $0000 ; NMI | ||||||
|  |   fdb RESET ; Reset | ||||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								datasheets/mcp100.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								datasheets/mcp100.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								datasheets/memory/AS6C62256-23-March-2016-rev1.2.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								datasheets/memory/AS6C62256-23-March-2016-rev1.2.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -1,6 +0,0 @@ | |||||||
| TTL devices can handle CMOS input. HD6309 -> 74LS612 |  | ||||||
| CMOS devices may or may not handle TTL input. 74LS612 -> peripherals |  | ||||||
|  |  | ||||||
| 62256 SRAM, 28C256 EEPROM, 16550 UART all handle TTL input. |  | ||||||
| 82C42 lists it's outputs as TTL compatible, but says nothing for inputs. |  | ||||||
| Must ensure all peripherals are rated for TTL input. |  | ||||||
| @@ -3,7 +3,6 @@ | |||||||
| File descriptions: | File descriptions: | ||||||
| 
 | 
 | ||||||
| - links.txt contains useful links i would like to keep | - links.txt contains useful links i would like to keep | ||||||
| - 6809-sn74ls612_timing.md contains notes on the mmu and cpu interface |  | ||||||
| - tech-spec.md contains basic info on layout of system (outdated) | - tech-spec.md contains basic info on layout of system (outdated) | ||||||
| - timing.html contains info on vga timing pulled from https://martin.hinner.info/vga/timing.html | - timing.html contains info on vga timing pulled from https://martin.hinner.info/vga/timing.html | ||||||
| - vga_ram.txt contains notes on ram size for the vga card | - vga_ram.txt contains notes on ram size for the vga card | ||||||
							
								
								
									
										1
									
								
								pcb/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								pcb/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | fp-info-cache | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "board": { |   "board": { | ||||||
|     "active_layer": 5, |     "active_layer": 0, | ||||||
|     "active_layer_preset": "", |     "active_layer_preset": "", | ||||||
|     "auto_track_width": true, |     "auto_track_width": true, | ||||||
|     "hidden_netclasses": [], |     "hidden_netclasses": [], | ||||||
| @@ -51,7 +51,7 @@ | |||||||
|       "shapes" |       "shapes" | ||||||
|     ], |     ], | ||||||
|     "visible_layers": "ffffffff_ffffffff_ffffffff_ffffffff", |     "visible_layers": "ffffffff_ffffffff_ffffffff_ffffffff", | ||||||
|     "zone_display_mode": 0 |     "zone_display_mode": 1 | ||||||
|   }, |   }, | ||||||
|   "git": { |   "git": { | ||||||
|     "repo_type": "", |     "repo_type": "", | ||||||
| @@ -59,7 +59,7 @@ | |||||||
|     "ssh_key": "" |     "ssh_key": "" | ||||||
|   }, |   }, | ||||||
|   "meta": { |   "meta": { | ||||||
|     "filename": "prototype-1(v1.1).kicad_prl", |     "filename": "prototype-1.kicad_prl", | ||||||
|     "version": 5 |     "version": 5 | ||||||
|   }, |   }, | ||||||
|   "net_inspector_panel": { |   "net_inspector_panel": { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user