# Report

November 9, 2017

# 1 8 bit RISC Microprocessor

# Author: Varun Sundar, EE16B068.

Done as a part of semester project for EE2016 (Fall 2017)

This serves as both a documentation and a report for the project. Architecture based on Harvard RISC Architecture.

Block Diagram

#### 1.0.1 General Structure:

- 8 bit processor.
- 8 bit Program counter.
- 16 bit IMEM output.
- 8 registers R0 to R7, of 8 bits each.

1.0.2 Module Descriptions:

1.

**Instruction memory** This is be a combinational unit - it takes just the address bus (8 bit value) as input, and gives out a 16-bit value that is the instruction to be decoded. The address is provided by the Program Counter (PC).

2.

**Program Counter** 8 bit register. Under normal operations, will always increment by 1 on every clock cycle, to access the next instruction. In case of a JUMP or BRANCH type of instruction, will go to the value specified by the output of the ALU or the immediate operand in the instruction.

3.

Block Diagram

**Register file** This is a set of 8 registers, each storing an 8 bit value. There are 2 output values ra and rb, whose values are selected based on the instruction word, as in the instruction definitions given above. There is one port by which data can be written into one of the registers, with an enable signal to control whether or not to update the value.

4.

**Data Memory** This is a sequential / clocked unit. At any given cycle, you are either reading from it or writing to it, with the address given by the address bus. In case of a lw (load-word) or sw (store-word) instruction, the address is either immediate or the output of the ALU.

5.

**Arithmetic and Logic Unit (ALU)** The core of the processor - all the actual computations are performed here. As shown in the instruction set, operations such as addition, subtraction and logical operations are all done in this unit. Also, the output of the ALU is used as the address for certain memory related operations.

6.

**Control unit** The unit that actually makes the entire processor work as expected. The input to this is the instruction word, and the output is a set of control signals that decide, for example, whether the register file is to updated, what operation is to be done by the ALU, whether memory read or write is required etc.

This has been implemented by generating the following control signals (not seen in the block diagram, for brevity):

- **MemToReg**: does data being written into the register file come from memory or from output of the ALU
- **MemWrite**: is the present operation going to write into memory?
- **RegWrite**: is an entry in the register file (pointed to by rd) supposed to get an updated value in this instruction?
- ALUSrc: is this an immediate operation, or a register operation?
- **Branch**: If the current instruction is a branch, then use this signal as select for a multiplexer to feed the PC.
- Jump: Control the PC input MUX and also the immediate operand for input to PC.

#### 1.0.3 ALU Opcodes:

```
3'b000: {carry,result} = a + b; // add
R0 is for carry. 3'b001: {borrow,result} = a - b; // sub
3'b010: result = ~a; // Invert
3'b011: result = a <> b; // Right shift by b bits
3'b101: result = a & b; // and
3'b110: result = a | b; // or
3'b111: begin if (a>Rb
```

- 6. Bitwise AND: (OP 0000, func 101) and Rd Ra Rb Rd<=Ra & Rb
- 7. Bitwise OR: (OP 0000, func 110) or Rd Ra Rb Rd<=Ra | | Rb
- 8. Set on Less Than: (OP 0000, func 111) cmp Rd Ra Rb Rd=(Ra<Rb)?1:0

#### C. Control Flow Instructions

- 1. Branch on Equal: (OP 1000) beq rb, ra, immem Branch to immem when ra == rb
- 2. Branch on Not Equal: (OP 1001) bne rb, ra, immem Branch to immem when ra != rb
- 3. Jump: to j\_line (OP 0010) j j\_line;
- 4. Move: mov Ra Rb (OP 0011) Rb <= Ra Ra<=0
- 5. End of Program: eop (OP 0111) Holds pc.

## 1.0.4 The Instruction Skeleton of the RISC processor:

**Memory Access: Load** 

<4 Opcode> <3 RS1> <3 WS> <6 Offset>

**Memory Access: Store** 

<4 Opcode> <3 RS1> <3 RS2> <6 Offset>

**Data Processing:** 

<4 Opcode> <3 RS1> <3 RS2> <3 WS> <3 Neglect>

Branch: (BNE and BEQ)

<4 Opcode> <3 RS1> <3 Rs2> <6 Offset>

Jump:

<4 Opcode> <12 Offset>

MOV:

<4 Opcode> <3 Ra> <3 Rb>

### 1.0.5 Processor Control Unit Design:

Changes in jump (to any line). Inclusion of subi, bne, mov.



#### 1.0.6 Instruction Format:

We have extended a few on the same lines.

## 1.0.7 Control Unit Output Signals:

- 1. jump: Control the PC input MUX and also the immediate operand for input to PC.
- 2. beq: BNE signal, branch
- 3. bne: BEQ signal, branch
- 4. mem\_read: Are you reading memory?
- 5. mem\_write: Are you writing to memory?
- 6. alu\_src: Is this an immediate operation, or a register operation?
- 7. reg\_dst: Data processing in register.
- 8. mem\_to\_reg: Does data being written into the register file come from memory or from output of the ALU
- 9. reg\_write: Is an entry in the register file (pointed to by rd) supposed to get an updated value in this instruction?

This reflects in PFCL Design, and ALU control Design.

## 1.0.8 Sample output

- Program to find n factorial.
- Code present at ./test/factorial.txt
- Compiled code present at ./test/factorial\_prog.txt
- Output logs at ./test/factorial.o



#### factorial waveform

- Verilog vvp compilation at ./test/factorial
- Sample waveform:

| 1.0.9 | Assembler | <b>Syntax</b> |
|-------|-----------|---------------|
|-------|-----------|---------------|

Run:

python assembler.py source destination

#### 1.0.10 Content of Text Files:

- 1. data.txt: contains register values. There are 8 such registers.
- 2. ./test/: this folder contains the output of simulations. Stored in format date\_time.o
- 3. prog.txt: contains program to be executed. (Under relevant directories in test)

### 1.0.11 Implementation Notes:

- 1. Cannot use \$fmonitor in icarus verilog, may use it in xilinx.
- 2. View waveforms in ./test/ or ./Waveform with gtkwave or scansion.
- 3. Run as : > iverilog -o destination ./test\_CU\_n.v
  - > vvp destination
  - > // Modify relevant parameters in Parameter.v first
- 4. Change program count parameter to exceed beyond 16 instructions. Can support up to 256 lines of program code.