CS 230 Sem 4

## IITB-RISC

Project

Naman Singh Rana 200050083 Parekh Dhairya 200050097 Shikhar Mundra 200050131 Shri Harsha Thota 200050138

| ADD | 00_01 | RA | RB                                                       | RC                   | 0 | 00 |
|-----|-------|----|----------------------------------------------------------|----------------------|---|----|
| ADC | 00_01 | RA | RB                                                       | RC                   | 0 | 10 |
| ADZ | 00_01 | RA | RB                                                       | RC                   | 0 | 01 |
| ADL | 00_01 | RA | RB                                                       | RC                   | 0 | 11 |
| ADI | 00_00 | RA | RB                                                       | 6 bit intermediate   |   |    |
| NDU | 00_10 | RA | RB                                                       | RC                   | 0 | 00 |
| NDC | 00_10 | RA | RB                                                       | RC                   | 0 | 10 |
| NDZ | 00_10 | RA | RB                                                       | RC                   | 0 | 01 |
| LHI | 00_00 | RA | 9 bit intermediate                                       |                      |   |    |
| LW  | 01_01 | RA | RB 6 bit intermediate                                    |                      |   |    |
| SW  | 01_11 | RA | RB                                                       | B 6 bit intermediate |   |    |
| LM  | 11_01 | RA | 0 + 8 bits corresponding to Reg R0 to R7 (left to right) |                      |   |    |
| SM  | 11_00 | RA | 0 + 8 bits corresponding to Reg R0 to R7 (left to right) |                      |   |    |
| BEQ | 10_00 | RA | RB                                                       | 6 bit Immediate      |   |    |
| JAL | 10_01 | RA | 9 bit Immediate offset                                   |                      |   |    |
| JLR | 10_10 | RA | RB                                                       | RB 000_000           |   |    |
| JRI | 10_11 | RA | 9 bit Immediate offset                                   |                      |   |    |

## **STATE ELABORATION**

(Does not include the bootload states)

| S0         | $"111" \to RF_{A1} \\ RF_{D1} \to PC$                                                                                    |  |  |
|------------|--------------------------------------------------------------------------------------------------------------------------|--|--|
| S1         | PC → MEM (A)  MEM (D)→ IR  PC → ALU_a  +1 → ALU_b  ALU_c → PC                                                            |  |  |
| S2         | $I_{11-9} \rightarrow RF_{A1}$ $I_{8-6} \rightarrow RF_{A2}$ $RF_{D1} \rightarrow T_{1}$ $RF_{D2} \rightarrow T_{2}$     |  |  |
| \$3        | $T_1 \rightarrow ALU_a$ $T_2 \rightarrow ALU_b$ $ALU_c \rightarrow T_3$                                                  |  |  |
| S4         | I <sub>5-3</sub> / I <sub>8-6</sub> → RF <sub>A3</sub><br>T <sub>3</sub> → RF <sub>D3</sub>                              |  |  |
| <b>S</b> 5 | $PC \rightarrow RF_{D3}$ $"111" \rightarrow RF_{A3}$ $T_2 \rightarrow ALU$ $0 \rightarrow ALU$                           |  |  |
| S6         | $I_{8-0} \rightarrow SE_{9-16} \rightarrow LS_7 \rightarrow$ $RF_{D3}$ $I_{11-9} \rightarrow RF_{A3}$                    |  |  |
| S7         | $T_1 \rightarrow ALU\_a$ $I_{5-0} \rightarrow SE_{6-16} \rightarrow ALU\_b$ $ALU\_c \rightarrow T_1 \rightarrow MEM(A)$  |  |  |
| S8         | MEM (DO) $\rightarrow$ T <sub>2</sub> $\rightarrow$ RF <sub>D3</sub><br>I <sub>11-9</sub> $\rightarrow$ RF <sub>A3</sub> |  |  |
| S9         | $RF_{D2} \rightarrow MEM_{10}(DI)$ $PC \rightarrow RF_{D3}$ "111" $\rightarrow RF_{A3}$                                  |  |  |
| S10        | do {MEM <sub>DAT</sub> (DO) → T <sub>2</sub>                                                                             |  |  |

| S11 | $T_2 \rightarrow RF_{D3}$ $PE_{OUTPUT} \rightarrow RF_{A3}$ $T_1 \rightarrow ALU_a$ $+1 \rightarrow ALU_b$ $ALU_c \rightarrow T_1, MEM(DI)$ } while (! invalid_next); |  |  |  |  |  |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| S12 | do {PEoutput → RFa2<br>T1 → MEM(A)                                                                                                                                    |  |  |  |  |  |
| S13 | $T_1 \rightarrow ALU\_a$<br>$+1 \rightarrow ALU\_b$<br>$ALU \rightarrow T_1$ }<br>while (! invalid_next);                                                             |  |  |  |  |  |
| S14 | $PC \rightarrow ALU\_a$ $I_{5-0} \rightarrow SE_{6-16} \rightarrow ALU\_b$ $ALU\_c \rightarrow PC$                                                                    |  |  |  |  |  |
| S15 | $PC \rightarrow RF_{D3}$ $I_{11-9} \rightarrow RF_{A3}$ $PC \rightarrow ALU\_a$ $I_{8-0} \rightarrow SE_{9-16} \rightarrow ALU\_b$ $ALU \ c \rightarrow PC$           |  |  |  |  |  |
| S16 | PC $\rightarrow$ RF <sub>D3</sub> $I_{11-9} \rightarrow$ RF <sub>A3</sub> $I_{8-6} \rightarrow$ RF <sub>A1</sub> RF <sub>D1</sub> $\rightarrow$ PC                    |  |  |  |  |  |
| S17 | $T_2 \rightarrow ALU\_a$ $T_2 \rightarrow ALU\_b$ $ALU\_c \rightarrow T_4$                                                                                            |  |  |  |  |  |
| S18 | $T_1 \rightarrow ALU_a$ $T_4 \rightarrow ALU_b$ $ALU_c \rightarrow T_3$                                                                                               |  |  |  |  |  |
| S19 | $I_{11-9} \rightarrow RF_{A1}$ $RF_{D1} \rightarrow T_{1}$ $T_{1} \rightarrow ALU_{a}$ $I_{8-0} \rightarrow SE_{9-16} \rightarrow ALU_{b}$ $ALU_{c} \rightarrow PC$   |  |  |  |  |  |

## STATE FLOW DIAGRAM





## INSTRUCTIONS THAT AFFECT FLAG SETTINGS

| Instruction | Flags |   | Instruction | Flags |   |
|-------------|-------|---|-------------|-------|---|
|             | С     | Z |             | С     | Z |
| ADD         | Χ     | Χ | NDU         |       | Х |
| ADC         | Х     | Х | NDC         |       | Х |
| ADZ         | Х     | Х | NDZ         |       | Х |
| ADO         | Х     | Х | NDO         |       | Х |
| ADI         | Х     | Χ | LW          |       | Х |

