



A

A

B

B

C

C

D

D



The two general purpose registers each store 8 bits of information, using 8 D-type flip flops each. A flip flop is a logic circuit that flips between two states based on its inputs, and a d-type flip flop is a flip flop that has a data input line and a clock input. The flip flop stores and outputs whatever logic level the data input had at the last clock pulse. Here the clock pulses are the control signals AI and BI, which cause the A or B register to store the data bus as it is.



Each register also had a line buffer stage. This exists because in the way I've configured the flip flops they are both constantly outputting to the adder and variable storage, as this saves on control signals, however if their outputs were then connected to the data bus they would render it unusable. As such, the buffers only allow the output to be passed through to the data bus when the AO and BO control signals are asserted. They're effectively a set of 8 switches, which allow the data to pass through onto the data bus when the respective control signals are asserted.

Author: Sebastian Gaume  
A sheet that gives access to both of the general purpose registers in the CPU.

Sheet: /General Purpose Registers/  
File: general-purpose-registers.sch

### Title: General Purpose Registers

|              |                  |
|--------------|------------------|
| Size: A4     | Date: 2019-11-08 |
| KiCad E.D.A. | kicad 5.1.4      |

|          |
|----------|
| Rev: 1   |
| Id: 2/14 |

A

A

B

B

C

C

D

D

The 74HC547 is the set of 8 D-type flip flops, with its inputs connected to the data bus and its outputs to an internal bus which goes to the line buffer and the adder. Its output enable pin is tied such that it always outputs and the clock signal is hooked up to A1.



The 74HC541 is the line buffer, which has its inputs connected to the registers internal bus and its outputs connected to the data bus. Its output enable lines are connected to the control signal A0.

Author: Sebastian Gaume  
 The schematic for the 8-bit A register.

Sheet: /General Purpose Registers/A Register/  
 File: a-register.sch

### Title: A Register

Size: A4 Date: 2019-11-08  
 KiCad E.D.A. kicad 5.1.4

Rev: 1  
 Id: 3/14

A

B

C

D

A

B

C

D



The only difference between the A and B registers is that the B register's internal bus is connected to the variable storage's address bus as well as to the adder.

Author: Sebastian Gaume  
The schematic for the 8-bit B register.

Sheet: /General Purpose Registers/B Register/  
File: b-register.sch

### Title: B Register

Size: A4 Date: 2019-11-08  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 4/14

A

A

B

B

C

C

D

D



The adder gets constant input from the A and B registers, and constantly outputs its result to the line buffer chip (similarly to the registers), which only asserts to the data bus when the E0 control signal is asserted. The actual adding is done by 2 74HC283 4-bit binary full adders, one of which outputs a carry bit to the other, allowing them to act as 1 8-bit adder.

Author: Sebastian Gaume  
The schematic for the 8-bit adder.

Sheet: /Adder/  
File: adder.sch  
**Title: Adder**  
Size: A4 Date: 2019-11-08  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 5/14



The comparison unit consists of two data latches (chips that can 'latch' the current value of a bus and output it) being fed into two 4-bit comparators which, similarly to the adders and counters elsewhere in the CPU have outputs that can carry between chips, allowing the two 74HC85s to act as a single 8-bit comparator. The two 74HC573A latches are used to store the two words to compare, each one storing the value of the data bus on the relevant control signal of either L1 or L2. The comparators output their result to the instruction decoder where it is used as part of the instruction lookup process.

Author: Sebastian Gaume  
The schematic for the comparison unit of the 8-bit CPU, which can compare the magnitude of two 8-bit words.

Sheet: /Comparison Unit/  
File: comparison-unit.sch

### Title: Comparison Unit

Size: A4 Date: 2019-11-11  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 6/14



The instruction register is identical to the general purpose registers, except that it only outputs its 4 least significant bits to the data bus since the others are used for operands which shouldn't ever go on the data bus. It constantly outputs its 4 most significant bits to the instruction decoder, for it to decode the instructions from machine code to control signals so that they can be executed and it constantly outputs its 4 least significant bits to the RAM's address bus, as it is the only thing that asserts those lines, so it saves control signals to not have an 'output address to RAM signal'.

Author: Sebastian Gaume  
The schematic for the instruction register of the 8-bit CPU.

Sheet: /Instruction Register/  
File: instruction-register.sch

### Title: Instruction Register

Size: A4 Date: 2019-11-11  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 7/14

A



The instruction decoder, as the name suggests, decodes instructions. It does so by looking up the instruction's 'op-code' (the 4-bit binary operand from the instruction register), and the current step (of which each instruction has at most 8) in an EEPROM. The EEPROMs use these two fields, along with the current output status of the comparison unit as an address, where the data at that address is the value of each control signal for that instruction, at that step, depending on the status of the comparison unit (which is useful for conditional jump instructions, ie jump if A = B).

Here, the instruction decoded is implemented using a single 4-bit counter 74HC163 chip and two AT28C64B, which are necessary since we have 16 control signals and each one can only set 8 for any given address (this isn't strictly true, and we could very much optimise this and probably save an EEPROM, but in the interest of keeping this nice and understandable, this is how I've done it here – ask me about it if you're interested). Both of the EEPROMs have exactly the same inputs to their address lines, but each one outputs to 8 different control signals. The counter is incremented by the system clock, which thus sets the speed at which the whole computer runs.

Author: Sebastian Gaume

The schematic for the EEPROMs that, along with a counter, decode the instruction words into the correct set of steps of command signals.

Sheet: /Instruction Decoder/  
File: instruction-decoder.sch

### Title: Instruction Decoder

Size: A4 Date: 2019-11-12  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 8/14

A

A

B

B

C

C

D

D



The RAM is a single AS7C256B chip, which while capable of storing up to 32kB of data, is only being used to store up to 16 bytes, as it is purely for temporary storage at addresses small enough to be arguments to instructions. There is another memory chip in the CPU which uses the B register for addresses and thus can store far more, however this is intended for very short term storage, as the other chip requires the address first be loaded into the B register first before it can be accessed. This chip simply has the address from the instruction register coming to its inputs and the data bus connected to its outputs. The control signal RO causes it to output the value at the current address to the data bus, while RI causes it to store the value of the data bus at the current address.

Author: Sebastian Gaume  
The schematic for the main RAM of the 8-bit CPU.

Sheet: /RAM/  
File: ram.sch

### Title: RAM

Size: A4 Date: 2019-11-11  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 9/14

A

A

B

B

C

C

D

D



This 'variable storage' block is actually just an extension to the available RAM in the CPU, consisting of the same AS7C256B SRAM chip as the other RAM. The only difference is that this chip uses the B register for its addressing, allowing it to access 256 bytes instead of 16. The tradeoff is that it is more complex to access and so should be used for storing things to be used much later on. Please note that the way I've done memory storage throughout the CPU is very simplistic and not feasible in real CPUs. In fact, real 8-bit CPUs only have an 8-bit data bus, and have far more available addressing lines, generally done by appending multiple 8-bit words onto each other before sending it as an address. While this massively expands the available memory, it is also more complicated and this system is only really meant as a demonstration.

Author: Sebastian Gaume  
The schematic for the extra RAM chip, which allows access to much more memory for storing variables during program execution.

Sheet: /Variable Memory/  
File: variable-memory.sch

### Title: Variable Memory

Size: A4 Date: 2019-11-11  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 10/14

A

A

B

B

C

C

D

D



The program counter stores the next address within the program storage to fetch an instruction from. Its count can either be incremented by 1 with the PI control signal, or set to the value of the data bus with the PJ control signal.

The program counter is implemented with 2 4-bit counters, which are synchronised through the use of a 'ripple carry' – ie once one reaches the maximum and resets, it causes the other to count one, which is how binary counting works (I'll probably demonstrate this more clearly while I'm talking through it). The counters used are 74HC163s, with their inputs connected to the data bus and PI/PJ control signals and their outputs connected to the 'count' bus, which goes to the address lines of program storage.

Author: Sebastian Gaume  
The schematic for the program counter of the 8-bit CPU.

Sheet: /Program Counter/  
File: program-counter.sch

### Title: Program Counter

Size: A4 Date: 2019-11-11  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 11/14

A

A

B

B

C

C

D

D



The program storage stores all of the instructions that make up the program that the computer will execute. They are stored in 8-bit binary words, where the 4 most significant bits (the top 4) store the 'operand', ie the instruction to perform and the 4 least significant bits store the 'argument', ie any data needed to carry out the instruction, for example an address to load.

The implementation here is an EEPROM – an 'electronically erasable programmable read only memory'. The name may be entirely self-contradictory, but it's basically just a chip that retains data even when not powered. I've used an AT28C64B, which can store up to 8kB of data, however since this is an 8-bit computer and I'm only using an 8-bit address bus, it can only really store 256 bytes in this configuration. It will constantly output the value at the address given by the program counter, since the instruction register will decide when to load it, and so all its enable pins are tied high or low to facilitate constantly outputting. Its address lines go to the program counter, while its IO lines go to the instruction register.

Author: Sebastian Gaume  
The schematic for the EEPROM that stores the program instructions.

Sheet: /Program Storage/  
File: program-storage.sch

### Title: Program Storage

Size: A4 Date: 2019-11-12  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 12/14

A

A

B

B

C

C

D

D



This sheet only exists because the logic chips used don't like it when an input isn't specifically high or low, so this termination makes it so that if nothing is asserted to the data bus, a low value will be asserted.

Author: Sebastian Gaume  
This page just neatly terminates the data base with pull-down resistors.

Sheet: /Data Bus Termination/  
File: data-bus-termination.sch

**Title: Data Bus Termination**

Size: A4 Date: 2019-11-12  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 13/14



The system clock comprises 3 555 timers, of which one pulses at a set rate, one allows you to step forward one clock step at a time, and the other lets you choose which of those two modes you want to be in. You can basically ignore those last two and think of them as switches, because they are – the only good thing about them is that they don't 'bounce' – a problem with most mechanical switches that I won't go into unless someone asks. Basically, this whole page is dedicated to either making a constant pulse of adjustable frequency, or allowing you to make the pulses yourself, at your own speed (for demonstration purposes). The control signal CE must be high for the clock pulses to be output, and so if it is set low, the computer will halt (stop), which is useful after a program has finished execution so you can see the output.

Author: Sebastian Gaume  
The clock module of the CPU – not very interesting, nor very fast, but very necessary.

Sheet: /Clock/  
File: clock.sch

**Title: Clock**

Size: A4 | Date: 2019-11-17  
KiCad E.D.A. kicad 5.1.4

Rev: 1  
Id: 14/14