## 3 Stage Pipeline

Group 9: CS14B023 Rahul Kejriwal CS13B005 Bharat Sai Botta CS16S033 Debanjan Ghatak

## 1. Work Split:

| Team Member      | Work Share                                                                                                                                                                                                                                                                                             |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rahul Kejriwal   | <ol> <li>Designed architecture and module interfaces.</li> <li>Building module for 'Register File' unit.</li> <li>Building module for 'Decode Instruction and Fetch Operands' unit.</li> <li>Building corresponding testbenches.</li> <li>Helping Ghatak for 'Execute and Store Back' unit.</li> </ol> |
| Bharat Sai Botta | Building module for 'Fetch Instruction'.     Building corresponding testbenches.                                                                                                                                                                                                                       |
| Debanjan Ghatak  | Building module for 'Execute and Store Back' unit.     Building corresponding testbenches.                                                                                                                                                                                                             |

## 2. Assumptions:

- a. We assume that the 'Fetch instruction' unit and the 'Execute and Store Back' (for LOAD/STORE instructions) don't use the same memory address in the same cycle. [As PS says one read/write port per memory address]
- b. All units finish their entire work within one clock cycle. [What this means, is that say 'Decode Instruction and Fetch Operands' takes 5ns and 'Execute and Store Back' takes 10 ns then the cycle width/duration is greater than

- 10ns. The cycle duration is large enough for each unit to finish their respective work for their current instruction within that cycle itself.]
- c. We are not using any delays (#n) in the verilog code. We do not worry about balancing the time taken by each pipeline stage to improve throughput.
- d. Register values can be changed during a cycle (not only on posedges). But register status bits change only on posedges.

## 3. System Architecture:

a. Here, is the system architecture schematic showing the interfaces between the modules:



b. Description of Modules (and variables used in the schematic):

| Module                               | Core<br>Components                                                                    | Input                                                                                                                                                                                                                                                                                                                                          | Output                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|--------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Fetch<br>Instructio<br>n Unit        | Program     Counter     Instruction     Register                                      | Instruction (to be executed)                                                                                                                                                                                                                                                                                                                   | Instruction Address (to be read)     Instruction (transfer to next unit)                                                                                                                                                                                                                                                                                                                                                                |  |
| Decode &<br>Fetch<br>Operand<br>Unit |                                                                                       | <ol> <li>Instruction (to be decoded)</li> <li>Value of 2 source registers,<br/>srcRegVal1 and srcRegVal2</li> <li>Status of 2 source registers,<br/>i.e., whether are being<br/>computed by the Execute<br/>Unit currently, inuse1 and<br/>inuse2</li> </ol>                                                                                   | <ol> <li>Source register address, srcReg1 and srcReg2 (to be read)</li> <li>Destination register address, nextDestReg (to set inuse bit)</li> <li>Opcode of instruction, opcode</li> <li>Destination register address, destReg for next instruction</li> <li>Source register values, srcVal1 and srcVal2</li> <li>Address of memory location in case of LOAD/Store</li> <li>Inuse bits for source registers, used1 and used2</li> </ol> |  |
| Register<br>File                     | 1. 16-bit<br>registers x16<br>2. Inuse bits<br>x16                                    | <ol> <li>Source register address,<br/>srcReg1 and srcReg2 (to be<br/>read)</li> <li>Destination register address<br/>of next instruction (to set<br/>inuse bit)</li> <li>Destination register address<br/>of current instruction,<br/>destReg and value to be<br/>stored there, destVal</li> </ol>                                             | <ol> <li>Value of 2 source registers,<br/>srcRegVal1 and srcRegVal2</li> <li>Status of 2 source registers,<br/>i.e., whether are being<br/>computed by the Execute Unit<br/>currently, inuse1 and inuse2</li> </ol>                                                                                                                                                                                                                     |  |
| Execute & Store Back Unit            | 1. Processor Status Word 2. LastDestVal (stores the value computed in the last cycle) | <ol> <li>Opcode of instruction, opcode</li> <li>Destination register address, destReg for next instruction</li> <li>Source register values, srcVal1 and srcVal2</li> <li>Address of memory location in case of LOAD/Store</li> <li>Inuse bits for source registers, used1 and used2</li> <li>Memory read value for LOAD instruction</li> </ol> | <ol> <li>Memory write value for<br/>STORE instruction</li> <li>Memory address for<br/>LOAD/STORE instruction</li> <li>Destination register address,<br/>destReg</li> <li>Destination register value,<br/>destVal</li> </ol>                                                                                                                                                                                                             |  |