



BUS VISUALIZER

**TBR Designs**

Sheet: /Breadboard Layout/  
File: breadboard-layout.kicad\_sch

**Title: 8-bit CPU**

Size: A3 Date: 2023-11-28

KiCad E.D.A. kicad 7.0.10

Rev: 1.0

Id: 2/23



ASTABLE\_OUTPUT



MONOSTABLE\_OUTPUT



BISTABLE\_OUTPUT



Provides a clock pulse and inverted clock pulse.  
Speed can be set with the potentiometer.  
Manual pulse can be chosen with the switch and pulsed with the button.  
If HALT is HIGH no pulse is outputted.

#### TBR Designs

Sheet: /Clock/  
File: clock.kicad\_sch

**Title: 8-bit CPU**

Size: A4 Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
Id: 3/23



#### TBR Designs

Sheet: /A register/  
File: a-register.kicad\_sch

**Title: 8-bit CPU**

Size: A4 | Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
Id: 4/23



#### TBR Designs

Sheet: /B register/  
 File: b-register.kicad\_sch

**Title: 8-bit CPU**

Size: A4 | Date: 2023-11-28  
 KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
 Id: 5/23



#### TBR Designs

Sheet: /ALU/  
File: alu.kicad\_sch

**Title: 8-bit CPU**

Size: A4 Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
Id: 6/23





1 2 3 4 5 6

When in programming mode the value from the dip-switches is selected.  
Otherwise the value from the bus is selected.



#### TBR Designs

Sheet: /RAM/RAM write value/  
File: ram-write-value.kicad\_sch

**Title: 8-bit CPU**

Size: A4 | Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

**Rev: 1.0**  
Id: 9/23

1 2 3 4 5 6





#### TBR Designs

Sheet: /Program Counter/  
File: program-counter.kicad\_sch

**Title: 8-bit CPU**

Size: A4 Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
Id: 11/23





#### TBR Designs

Sheet: /Instruction register/  
 File: instruction-register.kicad\_sch

**Title: 8-bit CPU**

Size: A4 | Date: 2023-11-28  
 KiCad E.D.A. kicad 7.0.10

**Rev: 1.0**  
 Id: 13/23



This address buffer triggers on the inverted CLOCK.  
 I had to include this because during an address transition the outputs of the EEPROM's are undefined.  
 They vary wildly and random actions were triggered briefly.  
 Making the address change on the inverted CLOCK seems to solve this issue because all of the other logic is triggered on the CLOCK.

A

B

C

D

A

B

C

D



#### TBR Designs

Sheet: /Control logic/EEPROM address buffer/  
 File: eeprom-address-buffer.kicad\_sch

#### Title: 8-bit CPU

Size: A4 Date: 2023-11-28  
 KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
 Id: 15/23



#### TBR Designs

Sheet: /Control logic/Microstep counter/  
File: microstep-counter.kicad\_sch

**Title: 8-bit CPU**

Size: A4 | Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
Id: 16/23





#### TBR Designs

Sheet: /Control logic/Middle Microcode EEPROM/  
File: middle-microcode-eeprom.kicad\_sch

**Title: 8-bit CPU**

Size: A4 Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
Id: 18/23









#### TBR Designs

Sheet: /Stack/  
File: stack.kicad\_sch

**Title: 8-bit CPU**

Size: A4 Date: 2023-11-28  
KiCad E.D.A. kicad 7.0.10

Rev: 1.0  
Id: 22/23

A

A

B

B

C

C

D

D



Sheet: /Power and Mounting/  
File: power-and-mounting.kicad\_sch

**Title:**

Size: A4 | Date:  
KiCad E.D.A. kicad 7.0.10

**Rev:**  
Id: 23/23