

CMP N 301 Spring 2017

## **Architecture Project**

## **Objective**

To design and implement a simple 5-stage pipelined processor, von Neumann or Harvard. The design should conform to the ISA specification described in the following sections.

### Introduction

The processor in this project has a RISC-like instruction set architecture. There are eight 2-byte general purpose registers; R<sub>0</sub>, R<sub>1</sub>, R<sub>2</sub>, R<sub>3</sub>, R<sub>4</sub>, R<sub>5</sub>, R<sub>6</sub> and R<sub>7</sub>. R<sub>7</sub> works as program counter (PC). R<sub>6</sub> works as a stack pointer (SP); and hence; points to the top of the stack. The initial value of SP is 1023. The memory (both in case of Harvard) address space is 1 KB of 16-bit width and is word addressable.

When an interrupt occurs, the processor finishes the currently executing instruction, then the address of the next instruction (in PC) is saved on top of the stack, and PC is loaded from address 1 of the memory. To return from an interrupt, an RTI instruction loads PC from the top of stack, and the flow of the program resumes from the instruction after the interrupted instruction.

### **ISA Specifications**

### A) Registers

R[0:7]<15:0> ; Eight 16-bit general purpose registers

PC<15:0>:=R[7]<15:0>; 16-bit program counter SP<15:0>:=R[6]<15:0>; 16-bit stack pointer

CCR<3:0> ; condition code register

Z<0>:=CCR<0>; zero flag, change after arithmetic, logical, or shift operations N<0>:=CCR<1>; negative flag, change after arithmetic, logical, or shift operations

C<0>:=CCR<2>; carry flag, change after arithmetic or shift operations.

V<0>:=CCR<2> ; carry riag, change after arithmetic or shift operations.

#### **B)** Input-Output

IN.PORT<15:0> ; 16-bit data input port OUT.PORT<15:0> ; 16-bit data output port

INTR.IN<0>; a single, non-maskable interrupt

RESET.IN<0>; reset signal



Table 1 shows a summary of the Instruction Set Architecture (ISA) that must be implemented by your processor.

Table 1: Processor ISA (X is the stack and M is the Memory)

Rsrc1; 1st operand register Rsrc2; 2nd operand register Rdst; Result register field EA; Effective address

Imm ; Immediate Value (16 bit)

| , ·                                   |                                                                                                                                                 |  |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Mnemonic                              | Function                                                                                                                                        |  |
| NOP                                   | $PC \leftarrow PC + 1$                                                                                                                          |  |
| MOV Rsrc1, Rdst                       | Move value from register Rsrc1 to register Rdst                                                                                                 |  |
| ADD Rsrc1, Rsrc2, Rdst                | Add the values stored in registers Rsrc1, Rsrc2 and store the result in Rdst  If the result =0 then $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ; |  |
|                                       | If the result <0 then $N \leftarrow 1$ ; else: $N \leftarrow 0$                                                                                 |  |
|                                       | Subtract the values stored in registers Rsrc1, Rsrc2                                                                                            |  |
| SUB Rsrc1, Rsrc2, Rdst                | and store the result in Rdst                                                                                                                    |  |
| SOB RSIC1, RSIC2, Rust                | If the result =0 then $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ;                                                                               |  |
|                                       | If the result <0 then $N \leftarrow 1$ ; else: $N \leftarrow 0$                                                                                 |  |
|                                       | AND the values stored in registers Rsrc1, Rsrc2                                                                                                 |  |
| AND Rsrc1, Rsrc2, Rdst                | and store the result in Rdst                                                                                                                    |  |
| 111,2 115101, 115102, 11650           | If the result =0 then $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ;                                                                               |  |
|                                       | If the result <0 then $N \leftarrow 1$ ; else: $N \leftarrow 0$                                                                                 |  |
|                                       | OR the values stored in registers Rsrc1, Rsrc2<br>and store the result in Rdst                                                                  |  |
| OR Rsrc1, Rsrc2, Rdst                 | If the result =0 then $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ;                                                                               |  |
|                                       | If the result <0 then $N \leftarrow 1$ ; else: $N \leftarrow 0$                                                                                 |  |
|                                       | Rotate left Rdst; $C \leftarrow R[Rdst] < 15>$ ;                                                                                                |  |
| RLC Rdst                              |                                                                                                                                                 |  |
|                                       | $R[Rdst] \leftarrow R[Rdst] < 14:0 > \&C$                                                                                                       |  |
| RRC Rdst                              | Rotate right Rdst; $C \leftarrow R[Rdst] < 0>$ ;                                                                                                |  |
|                                       | $R[Rdst] \leftarrow C&R[Rdst] < 15:1>;$                                                                                                         |  |
| SHL Rdst, Imm                         | Shift left Rdst by #Imm bits                                                                                                                    |  |
|                                       | $R[Rdst] \leftarrow R[Rdst] < (15-Imm):0 > \&0$                                                                                                 |  |
| SHR Rdst, Imm                         | Shift right Rdst by #Imm bits                                                                                                                   |  |
| SETC                                  | $R[Rdst] \leftarrow 0\&R[Rdst] < 15:Imm>$                                                                                                       |  |
|                                       | <u>C</u> ←1                                                                                                                                     |  |
| CLRC $C \leftarrow 0$                 |                                                                                                                                                 |  |
| PUSH Rdst $X[SP] \leftarrow R[Rdst];$ |                                                                                                                                                 |  |
| POP Rdst                              | $R[Rdst] \leftarrow X[++SP];$                                                                                                                   |  |
| OUT Rdst                              | $\text{dst} \qquad \qquad \text{OUT.PORT} \leftarrow \text{R[Rdst]}$                                                                            |  |
| IN Rdst                               | R[ Rdst ] ←IN.PORT                                                                                                                              |  |
|                                       | NOT value stored in register Rdst                                                                                                               |  |
| NOT Rdst                              | $R[Rdst] \leftarrow 1$ 's Complement( $R[Rdst]$ );                                                                                              |  |
| NOT Rust                              | If (1's Complement(R[ Rdst ]) = 0): $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ;                                                                 |  |
|                                       | If (1's Complement(R[ Rdst ]) $\leq$ 0): N $\leftarrow$ 1; else: N $\leftarrow$ 0                                                               |  |
|                                       | Negate the value stored in register Rdst                                                                                                        |  |
| NEC Dia                               | $R[Rdst] \leftarrow 2$ 's Complement( $R[Rdst]$ );                                                                                              |  |
| NEG Rdst                              | If $(2$ 's Complement $(R[Rdst]) = 0$ ): $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ;                                                            |  |
|                                       | If (2's Complement(R[ Rdst ]) < 0): N $\leftarrow$ 1; else: N $\leftarrow$ 0                                                                    |  |
|                                       | Increment value stored in Rdst                                                                                                                  |  |
| Dig 5 :                               | $R[Rdst] \leftarrow R[Rdst] + 1;$                                                                                                               |  |
| INC Rdst                              | If $((R[Rdst] + 1) = 0)$ : $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ;                                                                          |  |
|                                       | If $((R[Rdst] + 1) < 0)$ : N $\leftarrow$ 1; else: N $\leftarrow$ 0                                                                             |  |
|                                       | 11 ((11(11001) - 1) - 0). 11 ' 1, 0100. 11 ' 0                                                                                                  |  |

|               | Decrement value stored in Rdst                                         |  |
|---------------|------------------------------------------------------------------------|--|
| DEC Rdst      | $R[Rdst] \leftarrow R[Rdst] - 1;$                                      |  |
|               | If $((R[Rdst] - 1) = 0)$ : $Z \leftarrow 1$ ; else: $Z \leftarrow 0$ ; |  |
|               | If $((R[Rdst]-1)<0)$ : $N \leftarrow 1$ ; else: $N \leftarrow 0$       |  |
| JZ Rdst       | Jump if zero                                                           |  |
|               | If $(Z=1)$ : PC $\leftarrow$ R[ Rdst ]; $(Z=0)$                        |  |
| JN Rdst       | Jump if negative                                                       |  |
|               | If $(N=1)$ : PC $\leftarrow$ R[ Rdst ]; $(N=0)$                        |  |
| JC Rdst       | Jump if carry                                                          |  |
|               | If (C=1): $PC \leftarrow R[Rdst]$ ; (C=0):                             |  |
| JMP Rdst      | Jump                                                                   |  |
|               | PC ←R[ Rdst ]                                                          |  |
| CALL Rdst     | $(X[SP-] \leftarrow PC + 1; PC \leftarrow R[Rdst])$                    |  |
| RET           | $PC \leftarrow X[++SP]$                                                |  |
| RTI           | $PC \leftarrow X[++SP]$ ; Flags restored                               |  |
| LDM Rdst, Imm | Load immediate value to register Rdst                                  |  |
|               | $R[Rdst] \leftarrow Imm < 15:0 >$                                      |  |
| LDD Rdst, EA  | Load value from memory address EA to register Rdst                     |  |
|               | $R[Rdst] \leftarrow M[EA];$                                            |  |
| STD Rsrc, EA  | Store value in register Rsrc to memory location EA                     |  |
|               | $M[EA] \leftarrow R[Rsrc];$                                            |  |

| Input Signals |                                                           |  |
|---------------|-----------------------------------------------------------|--|
| Reset         | $PC \leftarrow M[0]$                                      |  |
| Interrupt     | $X[SP]\leftarrow PC; PC \leftarrow M[1]; Flags preserved$ |  |

### **Phase1 Requirement**

- Instruction format of your design
  - Opcode of each instruction
  - Instruction bits details
- Schematic diagram of the processor with data flow details.
  - ALU / Registers / Memory Blocks
  - Dataflow Interconnections between Blocks & its sizes
  - Control Unit detailed design
- Pipeline stages design
  - Pipeline registers details (Size, Input, Connection, ...)
  - Pipeline hazards and your solution including
    - i. Data Forwarding
    - ii. Static Branch Prediction

# **Phase2 Requirement**

- Implement and integrate your architecture
  - VHDL Implementation of each component of the processor
  - VHDL file that integrates the different components in a single module
- Simulation Test code that reads a program file and execute it on the processor.
  - Setup the simulation wave
  - Load Memory File & Run the test program
- Assembler code that converts assembly program (Text File) into machine code according to your design (Memory File)
- Report that contains any design changes after phase1
- Report that contains pipeline hazards considered and how your design solves it.

## **Project Testing**

• You will be given different test programs. You are required to compile and load it onto the RAM and reset your processor to start executing from memory location 0000h. Each program would test some instructions (you should notify the TA if you haven't implemented or have logical errors concerning some of the instruction set). You MUST prepare a waveform with the main signals showing that your processor is working correctly (R0, R1, R2, R3, PC, ...etc).

### **Evaluation Criteria**

- Each project will be evaluated according to the number of instructions that are implemented, and Pipelining hazards handled in the design. Table 2 shows the evaluation criteria in details.
- Failing to implement a working processor will nullify your project grade. <u>No credits will be</u> given to individual modules or a non-working processor.
- Synthesizing your processor and correctly carrying out timing simulation will be rewarded by bonus 1 mark that accumulates towards the 40-marks semester work.

Table 2: Evaluation Criteria

|              | Each instruction (out of 30 instructions)                             | 0.5 mark (15 marks total) |
|--------------|-----------------------------------------------------------------------|---------------------------|
| Marks        | Data Forwarding                                                       | 2 marks                   |
| Distribution | Static Branch Prediction                                              | 2 marks                   |
|              | Interrupt                                                             | 1 mark                    |
| Bonus Marks  | • Synthesizing the processor (Getting frequency and FPGA utilization) | 1 mark bonus to semester  |
|              |                                                                       | work grade                |

### **Team Members**

• Each team shall consist of a maximum of four members

### **Phase1 Due Date**

• Week 9 (Thursday April 13<sup>rd</sup>, 2017). Section time.

### **Project Due Date**

• Week 13 (Thursday May 18<sup>th</sup>, 2017). The demo will be during the regular lab session.

### **General Advice**

- 1. Compile your design on regular bases (after each modification) so that you can figure out new errors early. Accumulated errors are harder to track.
- 2. Use the engineering sense to back trace the error source.
- 3. As much as you can, don't ignore warnings.
- 4. Read the transcript window messages in Modelsim carefully.
- 5. After each major step, and if you have a working processor, save the design before you modify it (use versioning tool if you can as git & svn).
- 6. Always save the ram files to easily export and import them.
- 7. Start early and give yourself enough time for testing.
- 8. Integrate your components incrementally (i.e: Integrate the RAM with the Registers, then integrate with them the ALU ...).
- 9. Use coding convention to know each signal functionality easily.
- 10. Try to simulate your control signals sequence for an instruction (i.e. Add) to know if your timing design is correct.
- 11. There is no problem in changing the design after phase1, but justify your changes.
- 12. Always reset all components at the start of the simulation.
- 13. Don't leave any input signal float "U", set it with 0 or 1.
- 14. Remember that your VHDL code is a HW system (logic gates, Flipflops and wires).
- 15. Use Do files instead of re-forcing all inputs each time.