forked from amberisvibin/chibi-pc09
		
	Compare commits
	
		
			16 Commits
		
	
	
		
			hardware.i
			...
			5bd4c7ae15
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5bd4c7ae15 | |||
| 9a4f9fb6dd | |||
| 3835594548 | |||
| f6642860a5 | |||
| 9dc46c16ee | |||
| 4e6cdc8834 | |||
| 62a7ccc35a | |||
| 9a72eda0e5 | |||
| 0eb5b2ba89 | |||
| 6e89d26f6b | |||
| d2c5118ba2 | |||
| a642e05c2c | |||
| 9edc255412 | |||
| 971dc1d719 | |||
| 1237cc89eb | |||
|   | 808f868344 | 
							
								
								
									
										16
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								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, the books/ directory or code/assist09/. Those files belong to their respective copyright holders. | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								books/The 6309 Book (Burke & Burke).pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								books/The 6309 Book (Burke & Burke).pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -10,37 +10,101 @@ | |||||||
| ;; | ;; | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION "Reset" | ||||||
|   ORG ROM_BASE |   ORG ROM_BASE | ||||||
|  |  | ||||||
| RESET | RESET | ||||||
|   lda #%11000001 ; 8n1 serial, enable DLAB |   ; 8n1 Serial Enable DLAB | ||||||
|  |   lda #(UARTF_LCR_WLS | UARTF_LCR_DLAB) | ||||||
|   sta UART_LCR |   sta UART_LCR | ||||||
|  |  | ||||||
|   lda #$00       ; Set divisor to 12 (9600 baud) |   ; REVIEW: Potential endianness hiccough here | ||||||
|   sta UART_DLL |   ldd #$0C00           ; Set divisor to 12 (9600 baud) | ||||||
|   lda #$0C |  | ||||||
|   sta UART_DLM |   sta UART_DLM | ||||||
|  |   stb UART_DLL | ||||||
|  |  | ||||||
|   lda #%11000000 ; 8n1 serial, disable DLAB |   lda #(UARTF_LCR_WLS) ; 8n1 serial, disable DLAB | ||||||
|   sta UART_LCR |   sta UART_LCR | ||||||
|  |  | ||||||
|   lda #%01000000 ; Enable RTS |   lda #(UARTF_MCR_RTS) ; Enable Request-to-Send | ||||||
|   sta UART_MCR |   sta UART_MCR | ||||||
|  |  | ||||||
|   lda 'H         ; send 'H' |   lda 'H               ; send 'H' | ||||||
|   sta UART_BUFR |   sta UART_BUFR | ||||||
|  |  | ||||||
| WAIT | WAIT | ||||||
|   sync           ; Wait for interrupts |   sync                 ; Wait for interrupts | ||||||
|   nop |   nop | ||||||
|   bra WAIT |   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 | ;; Interrupt and Reset Vectors | ||||||
| ;; | ;; | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION "Vectors" | ||||||
|   ORG VECS_BASE |   ORG VECS_BASE | ||||||
|  |  | ||||||
| VECTORS | VECTORS | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								datasheets/cd74hc670.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								datasheets/cd74hc670.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											
												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": 5, | ||||||
|  |     "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": 0 | ||||||
|  |   }, | ||||||
|  |   "git": { | ||||||
|  |     "repo_type": "", | ||||||
|  |     "repo_username": "", | ||||||
|  |     "ssh_key": "" | ||||||
|  |   }, | ||||||
|  |   "meta": { | ||||||
|  |     "filename": "prototype-1(v1.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