**CPU Components**

**Arithmetic and Logic Unit (ALU)**

The ALU was designed to perform each of the arithmetic operations defined by the instruction set. These operations are bitwise AND, bitwise OR, bitwise NOT, bitwise XOR, addition(ADD), addition with carry(ADC), subtraction(SUB), subtraction with borrow(SBB), negation(NEG) and compare(CMP). A number of these operations are similar enough that they can share a large amount of circuitry, reducing hardware overhead. In particular, the add instruction is the same as addition with carry, only omitting the input carry and not setting the carry bit. The subtraction with borrow hardware can also be used to perform a SUB operation and the CMP operation.

The ALU module takes 4 inputs: 2 register buses of 8 bits each, an ALU select line which determines the operation to be performed by the ALU and a carry in line of 1 bit. It has an out bus of 8 bits carrying the result and 3 bits which maintain the carry out, N and Z flags.

If the current opcode is encoding for an ALU operation the output of the ALU is always the result of the 2 currently active registers, i.e it is constant rather than event triggered. If the opcode does not match an ALU instruction, the ALU ouptus “00000000”. This value is never written to a register however as the ALU is only ever set to write to a register if the current instruction dictates it.

**Registers**

The CPU maintains 8 Genreral Purpose Registers each 8 bits long, 3 address registers of 16 bits in length, a program counter and a status register, each of 16 bits length.

The standard registers are controlled by a demultiplexer on the input side and 2 multiplexers on the output side (from the perspective of the registers). The demultiplexer controls which register is written to based on a select line which is determined by the opcode for any given cycle. There are two multiplexers, which are wired to the ALU inputs. The output from these multiplexers is also used to pass data to address registers or other registers depending on the current instruction. Each of the two outputs is controlled by a select line, with one output always showing the register which is being written to.

**Control Unit**

**Decoder**

The leading 6 bits (MSBs) of any specific opcode encode the instruction to be performed. 6 bits of information gives 64 possible states and thus 64 possible operations; however the instruction set implemented only contains 24 entries, thus many codes go unused. The decoder determines what each instruction means based on the first 6 bits and sets the register select and ALU lines accordingly. This happens as soon as the opcode changes.

![](data:image/png;base64,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)

Figure 3.1: Structure of the General Purpose Registers

**Register Control**

The control unit contains decoder that control the select lines for the register multiplexers. Each opcode is interpreted and the register select lines are then assigned. For example an AND statement has the opcode 0 0 0 0 1 0 0 0 y2 y1 y0 0 0 x2 x1 x0 where y0-y2 and x0-x2 determine the specific registers which will be ANDed together. Also y0-y2 is the register which the result will be written back into. Therefore the same code can be used to identify one of the output registers and the input register. This code is given the designation SEL1 while the code for the remaining register is called SEL2. The opcodes are written such that for most instructions the registers are defined in the same place in the instruction word; this made the process of defining the register select codes very easy. Exceptions were coded for in this module (Cu.vhd, line 150). As there are 8 general register each SEL code is 3 bits long to provide the 8 states necessary.

A similar process was adopted for the address register controls. As the address registers are 16 bit in length compared to the 8 bit registers an additional bit is required to indicate which half of the address register is to be used in the instruction.

**Write Control**

A write event occurs every clock cycle. At each event each register type (REG, PC, ADR, SR) is written to regardless of whether that register has changed value this clock cycle or not. Each register has a feedback loop that will write the current value of the register to the register if it hasn’t changed value (determined by the control unit and passed to the write control). For example the value that is written to a standard register can be either an immediate value, the value of another register (standard or address), its current value added with another number, or its current value. The hardware that controls this is a multiplexer whose select signal is changed depending on which instruction is being performed.

**Special Registers**

There are two special registers, the Program Counter (PC) and the Status Register (SR). The program counter is a 16 bit register which stores the address of the current instruction while the status register, which is also 16 bits, contains the N, Z and Carry flags.

The Program Counter increments by one every cycle, unless a branch instruction is performed. A separate control module for the Program Counter performs load, increment and branch operations on the program counter. Its output is fed directly to the MMU, as it contains the memory address of the next instruction to be executed.

**Description of Operation**

In its current form the CPU performs operations in the following manner:

1. Gets instruction from testbench. In a final implementation the CPU would get its instruction from the address in memory specified by the program counter. This is timed in the testbench to occur on a falling clock edge. \*
2. Decode the instruction
3. Set all control lines/buses to correct values for given instruction. Includes setting write line to true
4. Calculate result and wait for write cycle
5. Write result or data from another register to register specified by instruction. This is initiated in the testbench to occur on the rising clock edge.
6. Set write back to false.
7. Repeat for next instruction

\*In conjunction with an actual MMU, the incoming opcode would change when the MMU responds to a change in the output value of the Program Counter register. This would be well before the clock falling edge (assuming a slow enough clock).

Below is a basic timing diagram for a few instructions

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Clock Edge | Instruction (paraphrased) | Register0 | Register1 | Register2 | Address\_Reg1 |
| Down | load Reg0 | UUUUUUUU | UUUUUUUU | UUUUUUUU | UUUUUUUUUUUUUUUU |
| Up |  | 11110101 | ~ | ~ | ~ |
| Down | load Reg1 | ~ | ~ | ~ | ~ |
| Up |  | ~ | 10101010 | ~ | ~ |
| Down | Reg0 XOR Reg1 | ~ | ~ | ~ | ~ |
| Up |  | 0101111 | ~ | ~ | ~ |
| Down | load Reg1 | ~ | ~ | ~ | ~ |
| Up |  | ~ | 10111000 | ~ | ~ |
| Down | R0 AND R1 | ~ | ~ | ~ | ~ |
| Up |  | 00011000 | ~ | ~ | ~ |
| Down | ADR\_Reg1(HIGH) <- Reg1 | ~ | ~ | ~ | ~ |
| Up |  | ~ | ~ | ~ | 10111000UUUUUUUU |
| Down | ADR\_Reg1(LOW) <- Reg0 | ~ | ~ | ~ | ~ |
| Up |  | ~ | ~ | ~ | 1011100000011000 |
| Down | Reg2 <- ADR\_Reg1(LOW) | ~ | ~ | ~ | ~ |
| Up |  | ~ | ~ | 00011000 | ~ |

Table 3.1: Timing and Register outputs.

This above timing diagram shows the state of each register at each clock edge as this is what currently drives the CPU write cycle, where U indicates the bit is undefined and “~” indicates that the register has the same value as previously. The diagram clearly shows that on each rising edge the register updates its value correctly. This data is from a testbench run on the final design, the original timing diagram is in the appendices [REFERENCE] but presented here in table form for clarity.

**Design Process**

The design concept for the CPU was to break the project down into smaller tasks that would be easier to complete. This is a valid design strategy for a lot of projects but given our lack of experience coding in VHDL and the reasonable scope of the project it seemed especially appropriate.

As such the Initial focus was on getting a working ALU. The bitwise AND, OR, NOT and XOR commands were easily implemented but some trouble was encountered in realising more complex operations such as ADD and SBB. This was because these operations involve a carry which we initially tried to implement concurrently. This proved to be the biggest hurdle in the design on the CPU as the concept of concurrency is not one which had been encountered in other programming languages and took a while to start thinking about what the code was doing. The output of each ALU function was verified to be correct by using a testbench with predefined inputs to the ALU and reading out from the output. All functions were correctly implemented. This can be verified using the ALU testbench file (etalu.vhd).

The next stage of the design was the registers. This was broken down further by defining the standard registers, address registers and special purpose registers separately. The registers proved easy to implement as their size was the only thing needing to be declared.

It was decided that the easiest way to implement writing and reading functionality in the registers would be to design “sub” control units that would handle the reading and writing for each type of register. This approach was chosen as it would allow functionality testing of a much smaller entity of the full control unity and was in line with the design concept. Once designed the sub units could be easily folded into the higher control unit architecture. The register control units were tested using the LOAD IMMEDIATE and STORE IMMEDIATE instructions as test cases. The address control unit and program counter unit were developed using the code from the register control as the requirements of each module are essentially the same.

Once the registers were receiving and outputting values when requested the final component to implement was the control unit. The control unit was implemented a level above the register sub controls, passing values to the sub control units after interpreting the opcode. The control unit is also responsible for maintaining the timing of the CPU and initiates each write cycle.

**Integration into the Final Design**

The CPU interacts solely with the Memory Management Unit (MMU). This interaction consists primarily of receiving an instruction as a response to a fetch request, performing the operation and if required sending a value back to the MMU to be stored at a particular memory location. The location in memory of the next instruction is determined by the program counter. The program counter increments by one after each successful instruction thus the instruction will be contiguous to the last. The exception to this is when an instruction specifically alters the instruction address such as a JUMP TO (JMP) statement. While we believe that we have implemented the required hardware to interface with the MMU we were unable to test it due to some persistent errors in the MMU implementation and a lack of time.

**Discussion**

**Things we did well**

The modular approach adopted for this project worked extremely well. By developing modules that handle discrete tasks from the beginning we were essentially creating “black boxes” that took some inputs and gave some outputs. Because of this it made creating the control unit which is the most complex part of the CPU relatively straight forward as the task was reduced to interpreting each instruction and then setting the inputs to the system according to that particular instruction.

**What we learned and what we could do better next time**

As this was our first hands on experience coding in VHDL we learned a lot about basic VHDL coding. The concept of concurrency took a bit of time to fully appreciate and is very different compared to software languages such as C and requires thinking about a problem in a slightly different way.

We also could have named signals and variables in a more coordinated way. When in the rhythm of programming it is not too hard to keep track of everything but can take a few minutes to re-familiarise oneself with the inner workings after being away from it for a day or two.

We didn’t make any effort to code in a similar style to the other members of the group which would lead to potential difficulties in understanding the code if it eventually became integrated with the other components of a microprocessor.

It would have been beneficial to start work on the project sooner. While we ended up with a working design that satisfied most of the specifications we didn’t necessarily meet them in the optimal way and allowing more time would have given opportunity to investigate other methods of doing things. There were heavy constraints on available time however given other projects due before this one.

![](data:image/png;base64,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)

R0

R7

A0

A1

A2

Control Unit

Program Counter

Figure 3.2: Interconnections between modules

References:

[1] Altera Corporation, “VHDL Adder/Subtractor,” in “Design Examples”, 2011, Available: <http://www.altera.com/support/examples/vhdl/vhd-add-sub.html> (accessed 12.10.11)

[2] Green Mountain Computing Systems, “Behavioural Descriptions” in “An Introductory VHDL Tutorial“, 1995, Available: <http://www.gmvhdl.com/signals.htm> (accessed 12.10.11)

[3] Francis Bruno, “VHDL Concurrent Statements” in “VHDL Reference Material”, UMBC University, Maryland, Available: <http://www.cs.umbc.edu/portal/help/VHDL/concurrent.html> (accessed 12.10.11)

[4] Jiri Gaisler, “A structured VHDL design method” in “Fault-tolerant Microprocessors for Space Applications”, 2007, Available: <http://www.gaisler.com/doc/vhdl2proc.pdf> (accessed 12.10.11)

Notes for testbench results:

Ins\_data: the opcode

Dat\_data: the data data bus

Ins\_addr: The program counter register value

Dat\_addr: The value of the currently selected address register

Test: The register input, Data\_in

Regout1: The register output defined by SEL1

Regout2: The register output defined by SEL2

Alout: The ALU output.