forked from amberisvibin/chibi-pc09
		
	Compare commits
	
		
			25 Commits
		
	
	
		
			9edc255412
			...
			7aac896cef
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7aac896cef | |||
| da1d22988e | |||
| cc8a9fc95f | |||
| a0427ad949 | |||
| 0845370c43 | |||
| 347b6fa236 | |||
| 677b3cb02d | |||
| c67176e99a | |||
| 9c668967d5 | |||
| 53c6c7fd78 | |||
| 08b85a186e | |||
| 9f28e315b7 | |||
| 69836aa24b | |||
| 5bd4c7ae15 | |||
| 9a4f9fb6dd | |||
| 3835594548 | |||
| f6642860a5 | |||
| 9dc46c16ee | |||
| 4e6cdc8834 | |||
| 62a7ccc35a | |||
| 9a72eda0e5 | |||
| 0eb5b2ba89 | |||
| 6e89d26f6b | |||
| d2c5118ba2 | |||
| a642e05c2c | 
							
								
								
									
										18
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,17 +1,19 @@ | |||||||
| # chibi pc-09 | # chibi pc-09 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Description | ## Description | ||||||
|  |  | ||||||
| The PC-09 will be a 6309 based microcomputer with a 74LS612 MMU, uPD72020 graphics, PS/2 keyboard and mouse input, and a capable UART.  | The PC-09 will be a 6309 based microcomputer with an MMU using 74HC670 register files and dual 16550 UARTs. The plan is to eventually add uPD7220 graphics and PS/2 mouse and keyboard. | ||||||
|  |  | ||||||
| The MMU will allow up to 2 megabytes of I/O to be paged into the address space. Pages are 4k. System storage will be paged into the address space as well, as it will be either EEPROM or flash.  | The two 74HC670s will take the top 4 bits of the address bus and expand them to 8 bits, turning the 16 bit cpu address space into a 20 bit address space capable of addressing 1MB of memory. Memory pages are 4KB. Being a register file, any page can be mapped to any slot, allowing complex memory management schemes. | ||||||
|  |  | ||||||
| The uPD72020 is a very advanced graphics chip for it's time, capable of accelerated drawing of lines, shapes, fills, and characters. It can be coerced into outputting a VGA signal at 640x480 and *maybe* 800x600.  | The 16550 UART is capable of interrupt driven operation with FIFOs, allowing for characters to be processed in batches rather than individually, minimizing task switch delays. They also support hardware flow control, and some versions can automatically assert RTS when the FIFO is nearing full. | ||||||
|  |  | ||||||
| Keyboard and mouse will be handled by the VIA VT82C42. It is an Intel 8242 compatible controller capable of both PS/2 keyboard and mouse. It's interface is relatively simple, which makes connection easy. It relies on interrupts, so an interrupt system will be required. | The uPD7220 graphics are very powerful, allowing 16 colors at 640x480, but it is a complex chip to get working. It will be left for a later date. | ||||||
|  |  | ||||||
| To avoid the infamous 65C22 bug, the system will use the 16550 UART from the PC ecosystem. It is *relatively* easy to interface this to a 6800 style bus. It has more features than a 65C22 as well. As configured, it will be stable up to 38,400 baud.  | The solution for PS/2 keyboard and mouse have not yet been decided. | ||||||
|  |  | ||||||
| ## Progress | ## Progress | ||||||
|  |  | ||||||
| @@ -21,6 +23,8 @@ Prototype 1 is currently in progress. It will be a much simpler system. It will | |||||||
|  |  | ||||||
| The PCB and parts for Prototype #1 have been ordered, and assembly will begin soon. Initial test code is now available in the code/ directory. | The PCB and parts for Prototype #1 have been ordered, and assembly will begin soon. Initial test code is now available in the code/ directory. | ||||||
|  |  | ||||||
|  | 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.
										
									
								
							| @@ -1,31 +1,35 @@ | |||||||
| # 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 boot.s19 | ||||||
| cd asm6809 |  | ||||||
| ./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 |  | ||||||
| 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 | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								code/boot/linkscript
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								code/boot/linkscript
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | section RESET load 8000 | ||||||
|  | section SERIAL | ||||||
|  | section MEMTEST | ||||||
|  |  | ||||||
|  | section VECTORS high 100000 | ||||||
| @@ -8,26 +8,45 @@ | |||||||
| # 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/ | ||||||
| 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 $@ $< | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	rm -v $(TARGET) | 	@echo 'Cleaning up intermediary files...' | ||||||
|  | 	@rm -rv $(TARGROM) $(TARGREC) map.txt $(BUILDDIR) | ||||||
|   | |||||||
| @@ -1,88 +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 |  | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |  | ||||||
| ;; |  | ||||||
| ;; 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_THR | ||||||
|  |  | ||||||
|  | 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 | ||||||
							
								
								
									
										61
									
								
								code/boot/src/serial.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								code/boot/src/serial.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | ; 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 SETBAUD | ||||||
|  |   EXPORT OUTCHAR | ||||||
|  |   EXPORT OUTSTR | ||||||
|  |  | ||||||
|  | ; Initializes the UART. | ||||||
|  | ; @param d: new divisor | ||||||
|  | SETBAUD | ||||||
|  |   pshs a              ; Preserve A | ||||||
|  |   lda UART_LCR        ; Set only the DLAB bit | ||||||
|  |   ora #UARTF_LCR_DLAB | ||||||
|  |   sta UART_LCR | ||||||
|  |   puls a | ||||||
|  |   sta UART_DLM        ; Store new divisor | ||||||
|  |   stb UART_DLL | ||||||
|  |   lda UART_LCR        ; Reset DLAB | ||||||
|  |   anda #$FE | ||||||
|  |   sta UART_LCR | ||||||
|  |   rts | ||||||
|  |  | ||||||
|  | ; 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_THR         ; 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_THR         ; 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/cd74hc670.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								datasheets/cd74hc670.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								datasheets/cpu/The 6309 Book (Burke & Burke).pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								datasheets/cpu/The 6309 Book (Burke & Burke).pdf
									
									
									
									
									
										Normal file
									
								
							
										
											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 | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										25507
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_pcb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25507
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_pcb
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										131
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_prl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										131
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_prl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,131 @@ | |||||||
|  | { | ||||||
|  |   "board": { | ||||||
|  |     "active_layer": 0, | ||||||
|  |     "active_layer_preset": "", | ||||||
|  |     "auto_track_width": true, | ||||||
|  |     "hidden_netclasses": [], | ||||||
|  |     "hidden_nets": [], | ||||||
|  |     "high_contrast_mode": 0, | ||||||
|  |     "net_color_mode": 1, | ||||||
|  |     "opacity": { | ||||||
|  |       "images": 0.6, | ||||||
|  |       "pads": 1.0, | ||||||
|  |       "shapes": 1.0, | ||||||
|  |       "tracks": 1.0, | ||||||
|  |       "vias": 1.0, | ||||||
|  |       "zones": 0.6 | ||||||
|  |     }, | ||||||
|  |     "selection_filter": { | ||||||
|  |       "dimensions": true, | ||||||
|  |       "footprints": true, | ||||||
|  |       "graphics": true, | ||||||
|  |       "keepouts": true, | ||||||
|  |       "lockedItems": false, | ||||||
|  |       "otherItems": true, | ||||||
|  |       "pads": true, | ||||||
|  |       "text": true, | ||||||
|  |       "tracks": true, | ||||||
|  |       "vias": true, | ||||||
|  |       "zones": true | ||||||
|  |     }, | ||||||
|  |     "visible_items": [ | ||||||
|  |       "vias", | ||||||
|  |       "footprint_text", | ||||||
|  |       "footprint_anchors", | ||||||
|  |       "ratsnest", | ||||||
|  |       "grid", | ||||||
|  |       "footprints_front", | ||||||
|  |       "footprints_back", | ||||||
|  |       "footprint_values", | ||||||
|  |       "footprint_references", | ||||||
|  |       "tracks", | ||||||
|  |       "drc_errors", | ||||||
|  |       "drawing_sheet", | ||||||
|  |       "bitmaps", | ||||||
|  |       "pads", | ||||||
|  |       "zones", | ||||||
|  |       "drc_warnings", | ||||||
|  |       "drc_exclusions", | ||||||
|  |       "locked_item_shadows", | ||||||
|  |       "conflict_shadows", | ||||||
|  |       "shapes" | ||||||
|  |     ], | ||||||
|  |     "visible_layers": "ffffffff_ffffffff_ffffffff_ffffffff", | ||||||
|  |     "zone_display_mode": 1 | ||||||
|  |   }, | ||||||
|  |   "git": { | ||||||
|  |     "repo_type": "", | ||||||
|  |     "repo_username": "", | ||||||
|  |     "ssh_key": "" | ||||||
|  |   }, | ||||||
|  |   "meta": { | ||||||
|  |     "filename": "prototype-1.kicad_prl", | ||||||
|  |     "version": 5 | ||||||
|  |   }, | ||||||
|  |   "net_inspector_panel": { | ||||||
|  |     "col_hidden": [ | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false, | ||||||
|  |       false | ||||||
|  |     ], | ||||||
|  |     "col_order": [ | ||||||
|  |       0, | ||||||
|  |       1, | ||||||
|  |       2, | ||||||
|  |       3, | ||||||
|  |       4, | ||||||
|  |       5, | ||||||
|  |       6, | ||||||
|  |       7, | ||||||
|  |       8, | ||||||
|  |       9 | ||||||
|  |     ], | ||||||
|  |     "col_widths": [ | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0, | ||||||
|  |       0 | ||||||
|  |     ], | ||||||
|  |     "custom_group_rules": [], | ||||||
|  |     "expanded_rows": [], | ||||||
|  |     "filter_by_net_name": true, | ||||||
|  |     "filter_by_netclass": true, | ||||||
|  |     "filter_text": "", | ||||||
|  |     "group_by_constraint": false, | ||||||
|  |     "group_by_netclass": false, | ||||||
|  |     "show_unconnected_nets": false, | ||||||
|  |     "show_zero_pad_nets": false, | ||||||
|  |     "sort_ascending": true, | ||||||
|  |     "sorting_column": 0 | ||||||
|  |   }, | ||||||
|  |   "open_jobsets": [], | ||||||
|  |   "project": { | ||||||
|  |     "files": [] | ||||||
|  |   }, | ||||||
|  |   "schematic": { | ||||||
|  |     "selection_filter": { | ||||||
|  |       "graphics": true, | ||||||
|  |       "images": true, | ||||||
|  |       "labels": true, | ||||||
|  |       "lockedItems": false, | ||||||
|  |       "otherItems": true, | ||||||
|  |       "pins": true, | ||||||
|  |       "symbols": true, | ||||||
|  |       "text": true, | ||||||
|  |       "wires": true | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										639
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_pro
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										639
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_pro
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,639 @@ | |||||||
|  | { | ||||||
|  |   "board": { | ||||||
|  |     "3dviewports": [], | ||||||
|  |     "design_settings": { | ||||||
|  |       "defaults": { | ||||||
|  |         "apply_defaults_to_fp_fields": false, | ||||||
|  |         "apply_defaults_to_fp_shapes": false, | ||||||
|  |         "apply_defaults_to_fp_text": false, | ||||||
|  |         "board_outline_line_width": 0.05, | ||||||
|  |         "copper_line_width": 0.2, | ||||||
|  |         "copper_text_italic": false, | ||||||
|  |         "copper_text_size_h": 1.5, | ||||||
|  |         "copper_text_size_v": 1.5, | ||||||
|  |         "copper_text_thickness": 0.3, | ||||||
|  |         "copper_text_upright": false, | ||||||
|  |         "courtyard_line_width": 0.05, | ||||||
|  |         "dimension_precision": 4, | ||||||
|  |         "dimension_units": 3, | ||||||
|  |         "dimensions": { | ||||||
|  |           "arrow_length": 1270000, | ||||||
|  |           "extension_offset": 500000, | ||||||
|  |           "keep_text_aligned": true, | ||||||
|  |           "suppress_zeroes": false, | ||||||
|  |           "text_position": 0, | ||||||
|  |           "units_format": 1 | ||||||
|  |         }, | ||||||
|  |         "fab_line_width": 0.1, | ||||||
|  |         "fab_text_italic": false, | ||||||
|  |         "fab_text_size_h": 1.0, | ||||||
|  |         "fab_text_size_v": 1.0, | ||||||
|  |         "fab_text_thickness": 0.15, | ||||||
|  |         "fab_text_upright": false, | ||||||
|  |         "other_line_width": 0.1, | ||||||
|  |         "other_text_italic": false, | ||||||
|  |         "other_text_size_h": 1.0, | ||||||
|  |         "other_text_size_v": 1.0, | ||||||
|  |         "other_text_thickness": 0.15, | ||||||
|  |         "other_text_upright": false, | ||||||
|  |         "pads": { | ||||||
|  |           "drill": 0.762, | ||||||
|  |           "height": 1.524, | ||||||
|  |           "width": 1.524 | ||||||
|  |         }, | ||||||
|  |         "silk_line_width": 0.1, | ||||||
|  |         "silk_text_italic": false, | ||||||
|  |         "silk_text_size_h": 1.0, | ||||||
|  |         "silk_text_size_v": 1.0, | ||||||
|  |         "silk_text_thickness": 0.1, | ||||||
|  |         "silk_text_upright": false, | ||||||
|  |         "zones": { | ||||||
|  |           "min_clearance": 0.5 | ||||||
|  |         } | ||||||
|  |       }, | ||||||
|  |       "diff_pair_dimensions": [ | ||||||
|  |         { | ||||||
|  |           "gap": 0.0, | ||||||
|  |           "via_gap": 0.0, | ||||||
|  |           "width": 0.0 | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "drc_exclusions": [], | ||||||
|  |       "meta": { | ||||||
|  |         "version": 2 | ||||||
|  |       }, | ||||||
|  |       "rule_severities": { | ||||||
|  |         "annular_width": "error", | ||||||
|  |         "clearance": "error", | ||||||
|  |         "connection_width": "warning", | ||||||
|  |         "copper_edge_clearance": "error", | ||||||
|  |         "copper_sliver": "warning", | ||||||
|  |         "courtyards_overlap": "error", | ||||||
|  |         "creepage": "error", | ||||||
|  |         "diff_pair_gap_out_of_range": "error", | ||||||
|  |         "diff_pair_uncoupled_length_too_long": "error", | ||||||
|  |         "drill_out_of_range": "error", | ||||||
|  |         "duplicate_footprints": "warning", | ||||||
|  |         "extra_footprint": "warning", | ||||||
|  |         "footprint": "error", | ||||||
|  |         "footprint_filters_mismatch": "ignore", | ||||||
|  |         "footprint_symbol_mismatch": "warning", | ||||||
|  |         "footprint_type_mismatch": "ignore", | ||||||
|  |         "hole_clearance": "error", | ||||||
|  |         "hole_near_hole": "error", | ||||||
|  |         "hole_to_hole": "error", | ||||||
|  |         "holes_co_located": "warning", | ||||||
|  |         "invalid_outline": "error", | ||||||
|  |         "isolated_copper": "warning", | ||||||
|  |         "item_on_disabled_layer": "error", | ||||||
|  |         "items_not_allowed": "error", | ||||||
|  |         "length_out_of_range": "error", | ||||||
|  |         "lib_footprint_issues": "warning", | ||||||
|  |         "lib_footprint_mismatch": "warning", | ||||||
|  |         "malformed_courtyard": "error", | ||||||
|  |         "microvia_drill_out_of_range": "error", | ||||||
|  |         "mirrored_text_on_front_layer": "warning", | ||||||
|  |         "missing_courtyard": "ignore", | ||||||
|  |         "missing_footprint": "warning", | ||||||
|  |         "net_conflict": "warning", | ||||||
|  |         "nonmirrored_text_on_back_layer": "warning", | ||||||
|  |         "npth_inside_courtyard": "ignore", | ||||||
|  |         "padstack": "warning", | ||||||
|  |         "pth_inside_courtyard": "ignore", | ||||||
|  |         "shorting_items": "error", | ||||||
|  |         "silk_edge_clearance": "warning", | ||||||
|  |         "silk_over_copper": "warning", | ||||||
|  |         "silk_overlap": "warning", | ||||||
|  |         "skew_out_of_range": "error", | ||||||
|  |         "solder_mask_bridge": "error", | ||||||
|  |         "starved_thermal": "error", | ||||||
|  |         "text_height": "warning", | ||||||
|  |         "text_on_edge_cuts": "error", | ||||||
|  |         "text_thickness": "warning", | ||||||
|  |         "through_hole_pad_without_hole": "error", | ||||||
|  |         "too_many_vias": "error", | ||||||
|  |         "track_angle": "error", | ||||||
|  |         "track_dangling": "warning", | ||||||
|  |         "track_segment_length": "error", | ||||||
|  |         "track_width": "error", | ||||||
|  |         "tracks_crossing": "error", | ||||||
|  |         "unconnected_items": "error", | ||||||
|  |         "unresolved_variable": "error", | ||||||
|  |         "via_dangling": "warning", | ||||||
|  |         "zones_intersect": "error" | ||||||
|  |       }, | ||||||
|  |       "rules": { | ||||||
|  |         "max_error": 0.005, | ||||||
|  |         "min_clearance": 0.1524, | ||||||
|  |         "min_connection": 0.0, | ||||||
|  |         "min_copper_edge_clearance": 0.381, | ||||||
|  |         "min_groove_width": 0.0, | ||||||
|  |         "min_hole_clearance": 0.25, | ||||||
|  |         "min_hole_to_hole": 0.25, | ||||||
|  |         "min_microvia_diameter": 0.2, | ||||||
|  |         "min_microvia_drill": 0.1, | ||||||
|  |         "min_resolved_spokes": 2, | ||||||
|  |         "min_silk_clearance": 0.0, | ||||||
|  |         "min_text_height": 0.8, | ||||||
|  |         "min_text_thickness": 0.08, | ||||||
|  |         "min_through_hole_diameter": 0.254, | ||||||
|  |         "min_track_width": 0.1524, | ||||||
|  |         "min_via_annular_width": 0.127, | ||||||
|  |         "min_via_diameter": 0.5, | ||||||
|  |         "solder_mask_to_copper_clearance": 0.0, | ||||||
|  |         "use_height_for_length_calcs": true | ||||||
|  |       }, | ||||||
|  |       "teardrop_options": [ | ||||||
|  |         { | ||||||
|  |           "td_onpthpad": true, | ||||||
|  |           "td_onroundshapesonly": false, | ||||||
|  |           "td_onsmdpad": true, | ||||||
|  |           "td_ontrackend": false, | ||||||
|  |           "td_onvia": true | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "teardrop_parameters": [ | ||||||
|  |         { | ||||||
|  |           "td_allow_use_two_tracks": true, | ||||||
|  |           "td_curve_segcount": 1, | ||||||
|  |           "td_height_ratio": 1.0, | ||||||
|  |           "td_length_ratio": 0.5, | ||||||
|  |           "td_maxheight": 2.0, | ||||||
|  |           "td_maxlen": 1.0, | ||||||
|  |           "td_on_pad_in_zone": false, | ||||||
|  |           "td_target_name": "td_round_shape", | ||||||
|  |           "td_width_to_size_filter_ratio": 0.9 | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "td_allow_use_two_tracks": true, | ||||||
|  |           "td_curve_segcount": 0, | ||||||
|  |           "td_height_ratio": 1.0, | ||||||
|  |           "td_length_ratio": 0.5, | ||||||
|  |           "td_maxheight": 2.0, | ||||||
|  |           "td_maxlen": 1.0, | ||||||
|  |           "td_on_pad_in_zone": false, | ||||||
|  |           "td_target_name": "td_rect_shape", | ||||||
|  |           "td_width_to_size_filter_ratio": 0.9 | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "td_allow_use_two_tracks": true, | ||||||
|  |           "td_curve_segcount": 0, | ||||||
|  |           "td_height_ratio": 1.0, | ||||||
|  |           "td_length_ratio": 0.5, | ||||||
|  |           "td_maxheight": 2.0, | ||||||
|  |           "td_maxlen": 1.0, | ||||||
|  |           "td_on_pad_in_zone": false, | ||||||
|  |           "td_target_name": "td_track_end", | ||||||
|  |           "td_width_to_size_filter_ratio": 0.9 | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "track_widths": [ | ||||||
|  |         0.0, | ||||||
|  |         0.2, | ||||||
|  |         0.4 | ||||||
|  |       ], | ||||||
|  |       "tuning_pattern_settings": { | ||||||
|  |         "diff_pair_defaults": { | ||||||
|  |           "corner_radius_percentage": 80, | ||||||
|  |           "corner_style": 1, | ||||||
|  |           "max_amplitude": 1.0, | ||||||
|  |           "min_amplitude": 0.2, | ||||||
|  |           "single_sided": false, | ||||||
|  |           "spacing": 1.0 | ||||||
|  |         }, | ||||||
|  |         "diff_pair_skew_defaults": { | ||||||
|  |           "corner_radius_percentage": 80, | ||||||
|  |           "corner_style": 1, | ||||||
|  |           "max_amplitude": 1.0, | ||||||
|  |           "min_amplitude": 0.2, | ||||||
|  |           "single_sided": false, | ||||||
|  |           "spacing": 0.6 | ||||||
|  |         }, | ||||||
|  |         "single_track_defaults": { | ||||||
|  |           "corner_radius_percentage": 80, | ||||||
|  |           "corner_style": 1, | ||||||
|  |           "max_amplitude": 1.0, | ||||||
|  |           "min_amplitude": 0.2, | ||||||
|  |           "single_sided": false, | ||||||
|  |           "spacing": 0.6 | ||||||
|  |         } | ||||||
|  |       }, | ||||||
|  |       "via_dimensions": [ | ||||||
|  |         { | ||||||
|  |           "diameter": 0.0, | ||||||
|  |           "drill": 0.0 | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "zones_allow_external_fillets": false | ||||||
|  |     }, | ||||||
|  |     "ipc2581": { | ||||||
|  |       "dist": "", | ||||||
|  |       "distpn": "", | ||||||
|  |       "internal_id": "", | ||||||
|  |       "mfg": "", | ||||||
|  |       "mpn": "" | ||||||
|  |     }, | ||||||
|  |     "layer_pairs": [], | ||||||
|  |     "layer_presets": [], | ||||||
|  |     "viewports": [] | ||||||
|  |   }, | ||||||
|  |   "boards": [], | ||||||
|  |   "cvpcb": { | ||||||
|  |     "equivalence_files": [] | ||||||
|  |   }, | ||||||
|  |   "erc": { | ||||||
|  |     "erc_exclusions": [], | ||||||
|  |     "meta": { | ||||||
|  |       "version": 0 | ||||||
|  |     }, | ||||||
|  |     "pin_map": [ | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         2, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         1, | ||||||
|  |         2, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         1, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         1, | ||||||
|  |         0, | ||||||
|  |         2, | ||||||
|  |         0, | ||||||
|  |         0, | ||||||
|  |         2 | ||||||
|  |       ], | ||||||
|  |       [ | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2, | ||||||
|  |         2 | ||||||
|  |       ] | ||||||
|  |     ], | ||||||
|  |     "rule_severities": { | ||||||
|  |       "bus_definition_conflict": "error", | ||||||
|  |       "bus_entry_needed": "error", | ||||||
|  |       "bus_to_bus_conflict": "error", | ||||||
|  |       "bus_to_net_conflict": "error", | ||||||
|  |       "conflicting_netclasses": "error", | ||||||
|  |       "different_unit_footprint": "error", | ||||||
|  |       "different_unit_net": "error", | ||||||
|  |       "duplicate_reference": "error", | ||||||
|  |       "duplicate_sheet_names": "error", | ||||||
|  |       "endpoint_off_grid": "warning", | ||||||
|  |       "extra_units": "error", | ||||||
|  |       "footprint_filter": "ignore", | ||||||
|  |       "footprint_link_issues": "warning", | ||||||
|  |       "four_way_junction": "ignore", | ||||||
|  |       "global_label_dangling": "warning", | ||||||
|  |       "hier_label_mismatch": "error", | ||||||
|  |       "label_dangling": "error", | ||||||
|  |       "label_multiple_wires": "warning", | ||||||
|  |       "lib_symbol_issues": "warning", | ||||||
|  |       "lib_symbol_mismatch": "warning", | ||||||
|  |       "missing_bidi_pin": "warning", | ||||||
|  |       "missing_input_pin": "warning", | ||||||
|  |       "missing_power_pin": "error", | ||||||
|  |       "missing_unit": "warning", | ||||||
|  |       "multiple_net_names": "warning", | ||||||
|  |       "net_not_bus_member": "warning", | ||||||
|  |       "no_connect_connected": "warning", | ||||||
|  |       "no_connect_dangling": "warning", | ||||||
|  |       "pin_not_connected": "error", | ||||||
|  |       "pin_not_driven": "error", | ||||||
|  |       "pin_to_pin": "error", | ||||||
|  |       "power_pin_not_driven": "error", | ||||||
|  |       "same_local_global_label": "warning", | ||||||
|  |       "similar_label_and_power": "warning", | ||||||
|  |       "similar_labels": "warning", | ||||||
|  |       "similar_power": "warning", | ||||||
|  |       "simulation_model_issue": "ignore", | ||||||
|  |       "single_global_label": "ignore", | ||||||
|  |       "unannotated": "error", | ||||||
|  |       "unconnected_wire_endpoint": "warning", | ||||||
|  |       "unit_value_mismatch": "error", | ||||||
|  |       "unresolved_variable": "error", | ||||||
|  |       "wire_dangling": "error" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "libraries": { | ||||||
|  |     "pinned_footprint_libs": [ | ||||||
|  |       "Custom" | ||||||
|  |     ], | ||||||
|  |     "pinned_symbol_libs": [ | ||||||
|  |       "Custom" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "meta": { | ||||||
|  |     "filename": "prototype-1.kicad_pro", | ||||||
|  |     "version": 3 | ||||||
|  |   }, | ||||||
|  |   "net_settings": { | ||||||
|  |     "classes": [ | ||||||
|  |       { | ||||||
|  |         "bus_width": 12, | ||||||
|  |         "clearance": 0.2, | ||||||
|  |         "diff_pair_gap": 0.25, | ||||||
|  |         "diff_pair_via_gap": 0.25, | ||||||
|  |         "diff_pair_width": 0.2, | ||||||
|  |         "line_style": 0, | ||||||
|  |         "microvia_diameter": 0.3, | ||||||
|  |         "microvia_drill": 0.1, | ||||||
|  |         "name": "Default", | ||||||
|  |         "pcb_color": "rgba(0, 0, 0, 0.000)", | ||||||
|  |         "priority": 2147483647, | ||||||
|  |         "schematic_color": "rgba(0, 0, 0, 0.000)", | ||||||
|  |         "track_width": 0.2, | ||||||
|  |         "via_diameter": 0.6, | ||||||
|  |         "via_drill": 0.3, | ||||||
|  |         "wire_width": 6 | ||||||
|  |       } | ||||||
|  |     ], | ||||||
|  |     "meta": { | ||||||
|  |       "version": 4 | ||||||
|  |     }, | ||||||
|  |     "net_colors": null, | ||||||
|  |     "netclass_assignments": null, | ||||||
|  |     "netclass_patterns": [] | ||||||
|  |   }, | ||||||
|  |   "pcbnew": { | ||||||
|  |     "last_paths": { | ||||||
|  |       "gencad": "", | ||||||
|  |       "idf": "", | ||||||
|  |       "netlist": "", | ||||||
|  |       "plot": "output/gerber/", | ||||||
|  |       "pos_files": "", | ||||||
|  |       "specctra_dsn": "", | ||||||
|  |       "step": "", | ||||||
|  |       "svg": "", | ||||||
|  |       "vrml": "" | ||||||
|  |     }, | ||||||
|  |     "page_layout_descr_file": "" | ||||||
|  |   }, | ||||||
|  |   "schematic": { | ||||||
|  |     "annotate_start_num": 0, | ||||||
|  |     "bom_export_filename": "bom.csv", | ||||||
|  |     "bom_fmt_presets": [], | ||||||
|  |     "bom_fmt_settings": { | ||||||
|  |       "field_delimiter": ",", | ||||||
|  |       "keep_line_breaks": false, | ||||||
|  |       "keep_tabs": false, | ||||||
|  |       "name": "CSV", | ||||||
|  |       "ref_delimiter": ",", | ||||||
|  |       "ref_range_delimiter": "", | ||||||
|  |       "string_delimiter": "\"" | ||||||
|  |     }, | ||||||
|  |     "bom_presets": [], | ||||||
|  |     "bom_settings": { | ||||||
|  |       "exclude_dnp": false, | ||||||
|  |       "fields_ordered": [ | ||||||
|  |         { | ||||||
|  |           "group_by": false, | ||||||
|  |           "label": "Reference", | ||||||
|  |           "name": "Reference", | ||||||
|  |           "show": true | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "group_by": true, | ||||||
|  |           "label": "Value", | ||||||
|  |           "name": "Value", | ||||||
|  |           "show": true | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "group_by": false, | ||||||
|  |           "label": "Datasheet", | ||||||
|  |           "name": "Datasheet", | ||||||
|  |           "show": true | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "group_by": false, | ||||||
|  |           "label": "Footprint", | ||||||
|  |           "name": "Footprint", | ||||||
|  |           "show": true | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "group_by": false, | ||||||
|  |           "label": "Qty", | ||||||
|  |           "name": "${QUANTITY}", | ||||||
|  |           "show": true | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "group_by": true, | ||||||
|  |           "label": "DNP", | ||||||
|  |           "name": "${DNP}", | ||||||
|  |           "show": true | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "group_by": false, | ||||||
|  |           "label": "#", | ||||||
|  |           "name": "${ITEM_NUMBER}", | ||||||
|  |           "show": false | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "group_by": false, | ||||||
|  |           "label": "Description", | ||||||
|  |           "name": "Description", | ||||||
|  |           "show": false | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "filter_string": "", | ||||||
|  |       "group_symbols": true, | ||||||
|  |       "include_excluded_from_bom": false, | ||||||
|  |       "name": "", | ||||||
|  |       "sort_asc": true, | ||||||
|  |       "sort_field": "Reference" | ||||||
|  |     }, | ||||||
|  |     "connection_grid_size": 50.0, | ||||||
|  |     "drawing": { | ||||||
|  |       "dashed_lines_dash_length_ratio": 12.0, | ||||||
|  |       "dashed_lines_gap_length_ratio": 3.0, | ||||||
|  |       "default_line_thickness": 6.0, | ||||||
|  |       "default_text_size": 50.0, | ||||||
|  |       "field_names": [], | ||||||
|  |       "intersheets_ref_own_page": false, | ||||||
|  |       "intersheets_ref_prefix": "", | ||||||
|  |       "intersheets_ref_short": false, | ||||||
|  |       "intersheets_ref_show": false, | ||||||
|  |       "intersheets_ref_suffix": "", | ||||||
|  |       "junction_size_choice": 3, | ||||||
|  |       "label_size_ratio": 0.375, | ||||||
|  |       "operating_point_overlay_i_precision": 3, | ||||||
|  |       "operating_point_overlay_i_range": "~A", | ||||||
|  |       "operating_point_overlay_v_precision": 3, | ||||||
|  |       "operating_point_overlay_v_range": "~V", | ||||||
|  |       "overbar_offset_ratio": 1.23, | ||||||
|  |       "pin_symbol_size": 25.0, | ||||||
|  |       "text_offset_ratio": 0.15 | ||||||
|  |     }, | ||||||
|  |     "legacy_lib_dir": "", | ||||||
|  |     "legacy_lib_list": [], | ||||||
|  |     "meta": { | ||||||
|  |       "version": 1 | ||||||
|  |     }, | ||||||
|  |     "net_format_name": "", | ||||||
|  |     "page_layout_descr_file": "", | ||||||
|  |     "plot_directory": "", | ||||||
|  |     "space_save_all_events": true, | ||||||
|  |     "spice_current_sheet_as_root": false, | ||||||
|  |     "spice_external_command": "spice \"%I\"", | ||||||
|  |     "spice_model_current_sheet_as_root": true, | ||||||
|  |     "spice_save_all_currents": false, | ||||||
|  |     "spice_save_all_dissipations": false, | ||||||
|  |     "spice_save_all_voltages": false, | ||||||
|  |     "subpart_first_id": 65, | ||||||
|  |     "subpart_id_separator": 0 | ||||||
|  |   }, | ||||||
|  |   "sheets": [ | ||||||
|  |     [ | ||||||
|  |       "73f02399-4449-4d3e-bf52-6d1b4c7a62b4", | ||||||
|  |       "Root" | ||||||
|  |     ] | ||||||
|  |   ], | ||||||
|  |   "text_variables": {} | ||||||
|  | } | ||||||
							
								
								
									
										23029
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_sch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23029
									
								
								pcb/prototype-1/v1.1/prototype-1.kicad_sch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user