## BIRLA INSTITUTE OF TECHNOLOGY & SCIENCE, PILANI K. K. BIRLA Goa Campus

First Semester 2015-2016 CS F342 Computer Architecture Lab – 4, 6<sup>th</sup> October 2015

Implement the following using verilog HDL in **Modelsim software** with the following specifications. Download and modify the multiCycle.v file.



| Inc  | tru | ction | Forn     | าลf |
|------|-----|-------|----------|-----|
| 1115 |     |       | 1,431 11 | 141 |

| Instruction | Instruction Format |    |    |    |    |    |      |   |            |            |   |   |    |   |   |   |
|-------------|--------------------|----|----|----|----|----|------|---|------------|------------|---|---|----|---|---|---|
| instruction | 15                 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7          | 6          | 5 | 4 | 3  | 2 | 1 | 0 |
| add         | 0                  | 0  | 0  |    | Rt |    |      |   | Х          | Rd         |   |   |    |   |   |   |
| mul         | 0                  | 0  | 1  |    | Rt |    |      |   | Х          | Rd         |   |   |    |   |   |   |
| div         | 0                  | 1  | 0  |    | Rt |    |      |   | Χ          | Rd         |   |   |    |   |   |   |
| mfhi        | 0                  | 1  | 1  | Х  |    |    |      |   |            | Rd         |   |   |    |   |   |   |
| mflo        | 1                  | 0  | 0  | Χ  | Χ  | Х  | Х    | Χ | Χ          | Χ          | Х | Χ | Rd |   |   |   |
| addi        | 1                  | 0  | 1  |    |    | R  | lt . |   | Imm(5bits) |            |   |   |    |   |   |   |
| lw          | 1                  | 1  | 0  |    | Rt |    |      |   | Imm(5bits) |            |   |   |    |   |   |   |
| SW          | 1                  | 1  | 1  |    | Rt |    |      |   |            | Imm(5bits) |   |   |    |   |   |   |

## **Control circuit**

## State Diagram:



\*State goes back to State0

|         |                                         | pcWrite | lorD | mem<br>Read | mem<br>Write | IR<br>Write | alu<br>SrcA | alu<br>SrcB<br>(2b) | aluOp<br>(2b)    | hiWrite | loWrite | toReg<br>(2b)      | mem<br>ToReg | regDst   | reg<br>Write |
|---------|-----------------------------------------|---------|------|-------------|--------------|-------------|-------------|---------------------|------------------|---------|---------|--------------------|--------------|----------|--------------|
| State0  | IF                                      | 1       | 1    | 1           | 0            | 1           | 0           | 1                   | 0                | 0       | 0       | Х                  | Х            | Х        | 0            |
| State1  | ID                                      | 0       | Χ    | 0           | 0            | 0           | Χ           | Χ                   | Х                | 0       | 0       | Х                  | Х            | Х        | 0            |
| State2  | EX(add)                                 | 0       | Χ    | 0           | 0            | 0           | 1           | 0                   | 0                | 0       | 0       | Х                  | Х            | Х        | 0            |
| State3  | WB(add)                                 | 0       | Χ    | 0           | 0            | 0           | Χ           | Χ                   | Х                | 0       | 0       | 2                  | 0            | 1        | 1            |
| State4  | EX(mul/div)                             | 0       | Х    | 0           | 0            | 0           | 1           | 0                   | 1/2(mul<br>/div) | 1       | 1       | X                  | Х            | Х        | 0            |
| State5  | WB(mflo<br>/mfhi)                       | 0       | х    | 0           | 0            | 0           | х           | х                   | x                | 0       | 0       | 1/0<br>(mflo/mfhi) | 0            | 1        | 1            |
| State6  | EX(addi)                                | 0       | Χ    | 0           | 0            | 0           | 1           | 2                   | 0                | 0       | 0       | Х                  | Х            | Х        | 0            |
| State7  | WB(addi)                                | 0       | 0    | 0           | 0            | 0           | Х           | Х                   | Х                | 0       | 0       | 2                  | 0            | 0        | 1            |
| State8  | EX(lw/sw)                               | 0       | Х    | 0           | 0            | 0           | 1           | 2                   | 0                | 0       | 0       | Х                  | Х            | Х        | 0            |
| State9  | Mem(lw)                                 | 0       | 0    | 1           | 0            | 0           | Х           | Х                   | Х                | 0       | 0       | 2                  | Х            | Х        | 0            |
| State10 | WB(lw)                                  | 0       | Х    | 0           | 0            | 0           | Х           | Х                   | Х                | 0       | 0       | Х                  | 1            | 0        | 1            |
| State11 | Mem(sw)                                 | 0       | 0    | 0           | 1            | 0           | Х           | Х                   | Х                | 0       | 0       | 2                  | Х            | Х        | 0            |
|         | *Consider all don't care(X) values as 0 |         |      |             |              |             |             |                     |                  |         |         |                    |              | ies as 0 |              |

## WaveForm:



\*Content of Register File and memory location 15 is shown in waveform