

Universidad de Puerto Rico Recinto de Mayagüez Departamento de Ingeniería Eléctrica y de Computadoras ICOM 4215 -001D

## Course Project: Design and Simulation of a RISC Microprocessor

Barbara P. Gonzalez-Rivera Amy Ayala Darielis M. Morales Rodríguez





| `             | l <sub>27-25</sub> | l <sub>24-21</sub> | l <sub>20</sub> | Bit_S | ID_B_inst | Br_L_Inst | Shift_im | Load_inst | $ALU_o$ | RF_enabl | Data_Mem_Opcod |
|---------------|--------------------|--------------------|-----------------|-------|-----------|-----------|----------|-----------|---------|----------|----------------|
| D-t-          | 000                | 0000               | 0               | 0     | r         | r         | m        | r         | P       | e        | e              |
| Data          | 000                | 0000               | 0               | 0     | 0         | 0         | 0        | 1         | 0000    | 1        | 10             |
| Processin     | 000                | 0001               | 0               | 0     | 0         | 0         | 0        | 1         | 0001    | 1        | 10             |
| g<br>Domintou | 000                | 0010               | 0               | 0     | 0         | 0         | 0        | 1         | 0010    | 1        | 10             |
| Register      | 000                | 0011               | 0               | 0     | 0         | 0         | 0        | 1         | 0011    | 1        | 10             |
| Shift         | 000                | 0100               | 0               | 0     | 0         | 0         | 0        | 1         | 0100    | 1        | 10             |
|               | 000                | 0101               | 0               | 0     | 0         | 0         | 0        | 1         | 0101    | 1        | 10             |
|               | 000                | 0110               | 0               | 0     | 0         | 0         | 0        | 1         | 0110    | 1        | 10             |
|               | 000                | 0111               | 0               | 0     | 0         | 0         | 0        | 1         | 0111    | 1        | 10             |
|               | 000                | 1000               | 0               | 0     | 0         | 0         | 0        | 1         | 1000    | 1        | 10             |
|               | 000                | 1001               | 0               | 0     | 0         | 0         | 0        | 1         | 1001    | 1        | 10             |
|               | 000                | 1010               | 0               | 0     | 0         | 0         | 0        | 1         | 1010    | 1        | 10             |
|               | 000                | 1011               | 0               | 0     | 0         | 0         | 0        | 1         | 1011    | 1        | 10             |
|               | 000                | 1100               | 0               | 0     | 0         | 0         | 0        | 1         | 1100    | 1        | 10             |
|               | 000                | 1101               | 0               | 0     | 0         | 0         | 0        | 1         | 1101    | 1        | 10             |
|               | 000                | 1110               | 0               | 0     | 0         | 0         | 0        | 1         | 1110    | 1        | 10             |
|               | 000                | 1111               | 0               | 0     | 0         | 0         | 0        | 1         | 1111    | 1        | 10             |
|               | 000                | 0000               | 1               | 1     | 0         | 0         | 0        | 1         | 0000    | 1        | 10             |
|               | 000                | 0001               | 1               | 1     | 0         | 0         | 0        | 1         | 0001    | 1        | 10             |
|               | 000                | 0010               | 1               | 1     | 0         | 0         | 0        | 1         | 0010    | 1        | 10             |
|               | 000                | 0011               | 1               | 1     | 0         | 0         | 0        | 1         | 0011    | 1        | 10             |
|               | 000                | 0100               | 1               | 1     | 0         | 0         | 0        | 1         | 0100    | 1        | 10             |
|               | 000                | 0101               | 1               | 1     | 0         | 0         | 0        | 1         | 0101    | 1        | 10             |
|               | 000                | 0110               | 1               | 1     | 0         | 0         | 0        | 1         | 0110    | 1        | 10             |
|               | 000                | 0111               | 1               | 1     | 0         | 0         | 0        | 1         | 0111    | 1        | 10             |
|               | 000                | 1000               | 1               | 1     | 0         | 0         | 0        | 1         | 1000    | 1        | 10             |
|               | 000                | 1001               | 1               | 1     | 0         | 0         | 0        | 1         | 1001    | 1        | 10             |
|               | 000                | 1010               | 1               | 1     | 0         | 0         | 0        | 1         | 1010    | 1        | 10             |
|               | 000                | 1011               | 1               | 1     | 0         | 0         | 0        | 1         | 1011    | 1        | 10             |
|               | 000                | 1100               | 1               | 1     | 0         | 0         | 0        | 1         | 1100    | 1        | 10             |

| 000 | 1101 | 1 | 1 | 0 | 0 | 0 | 1 | 1101 | 1 | 10 |
|-----|------|---|---|---|---|---|---|------|---|----|
| 000 | 1110 | 1 | 1 | 0 | 0 | 0 | 1 | 1110 | 1 | 10 |
| 000 | 1111 | 1 | 1 | 0 | 0 | 0 | 1 | 1111 | 1 | 10 |

| •          | l <sub>27-25</sub> | l <sub>24-21</sub> | l <sub>20</sub> | Bit_S | ID_B_inst | Br_L_Inst | Shift_im | Load_inst | $ALU_o$ | RF_enabl | Data_Mem_Opcod |
|------------|--------------------|--------------------|-----------------|-------|-----------|-----------|----------|-----------|---------|----------|----------------|
|            |                    |                    |                 |       | r         | r         | m        | r         | Р       | e        | е              |
| Data       | 001                | 0000               | 0               | 0     | 0         | 0         | 1        | 1         | 0000    | 1        | 10             |
| Processing | 001                | 0001               | 0               | 0     | 0         | 0         | 1        | 1         | 0001    | 1        | 10             |
| Immediat   | 001                | 0010               | 0               | 0     | 0         | 0         | 1        | 1         | 0010    | 1        | 10             |
| е          | 001                | 0011               | 0               | 0     | 0         | 0         | 1        | 1         | 0011    | 1        | 10             |
|            | 001                | 0100               | 0               | 0     | 0         | 0         | 1        | 1         | 0100    | 1        | 10             |
|            | 001                | 0101               | 0               | 0     | 0         | 0         | 1        | 1         | 0101    | 1        | 10             |
|            | 001                | 0110               | 0               | 0     | 0         | 0         | 1        | 1         | 0110    | 1        | 10             |
|            | 001                | 0111               | 0               | 0     | 0         | 0         | 1        | 1         | 0111    | 1        | 10             |
|            | 001                | 1000               | 0               | 0     | 0         | 0         | 1        | 1         | 1000    | 1        | 10             |
|            | 001                | 1001               | 0               | 0     | 0         | 0         | 1        | 1         | 1001    | 1        | 10             |
|            | 001                | 1010               | 0               | 0     | 0         | 0         | 1        | 1         | 1010    | 1        | 10             |
|            | 001                | 1011               | 0               | 0     | 0         | 0         | 1        | 1         | 1011    | 1        | 10             |
|            | 001                | 1100               | 0               | 0     | 0         | 0         | 1        | 1         | 1100    | 1        | 10             |
|            | 001                | 1101               | 0               | 0     | 0         | 0         | 1        | 1         | 1101    | 1        | 10             |
|            | 001                | 1110               | 0               | 0     | 0         | 0         | 1        | 1         | 1110    | 1        | 10             |
|            | 001                | 1111               | 0               | 0     | 0         | 0         | 1        | 1         | 1111    | 1        | 10             |
|            | 001                | 0001               | 1               | 1     | 0         | 0         | 1        | 1         | 0001    | 1        | 10             |
|            | 001                | 0010               | 1               | 1     | 0         | 0         | 1        | 1         | 0010    | 1        | 10             |
|            | 001                | 0011               | 1               | 1     | 0         | 0         | 1        | 1         | 0011    | 1        | 10             |
|            | 001                | 0100               | 1               | 1     | 0         | 0         | 1        | 1         | 0100    | 1        | 10             |
|            | 001                | 0101               | 1               | 1     | 0         | 0         | 1        | 1         | 0101    | 1        | 10             |
|            | 001                | 0110               | 1               | 1     | 0         | 0         | 1        | 1         | 0110    | 1        | 10             |
|            | 001                | 0111               | 1               | 1     | 0         | 0         | 1        | 1         | 0111    | 1        | 10             |
|            | 001                | 1000               | 1               | 1     | 0         | 0         | 1        | 1         | 1000    | 1        | 10             |
|            | 001                | 1001               | 1               | 1     | 0         | 0         | 1        | 1         | 1001    | 1        | 10             |
|            | 001                | 1010               | 1               | 1     | 0         | 0         | 1        | 1         | 1010    | 1        | 10             |

| 001 | 1011 | 1 | 1 | 0 | 0 | 1 | 1 | 1011 | 1 | 10 |
|-----|------|---|---|---|---|---|---|------|---|----|
| 001 | 1100 | 1 | 1 | 0 | 0 | 1 | 1 | 1100 | 1 | 10 |
| 001 | 1101 | 1 | 1 | 0 | 0 | 1 | 1 | 1101 | 1 | 10 |
| 001 | 1110 | 1 | 1 | 0 | 0 | 1 | 1 | 1110 | 1 | 10 |
| 001 | 1111 | 1 | 1 | 0 | 0 | 1 | 1 | 1111 | 1 | 10 |

|          | l <sub>27-25</sub> | I <sub>22</sub> - B | I <sub>23</sub> - U | l <sub>20</sub> | Bit_S | ID_B_i<br>nstr | Br_L_I<br>nstr | Shift_i<br>mm | Load_in<br>str | $ALU_OP$ | RF_ena<br>ble | Data_Mem_O<br>pcode |
|----------|--------------------|---------------------|---------------------|-----------------|-------|----------------|----------------|---------------|----------------|----------|---------------|---------------------|
| Load/St  | 010                | 0                   | 0                   | 0               | 0     | 0              | 0              | 1             | 0              | 0100     | 0             | 10                  |
| ore      | 010                | 0                   | 1                   | 0               | 0     | 0              | 0              | 1             | 0              | 0100     | 0             | 10                  |
| Immedia  | 010                | 1                   | 0                   | 0               | 0     | 0              | 0              | 1             | 0              | 0100     | 0             | 00                  |
| te       | 010                | 1                   | 1                   | 0               | 0     | 0              | 0              | 1             | 0              | 0100     | 0             | 00                  |
| Offset   | 010                | 0                   | 0                   | 0               | 0     | 0              | 0              | 1             | 1              | 0100     | 1             | 10                  |
|          | 010                | 0                   | 1                   | 0               | 0     | 0              | 0              | 1             | 1              | 0100     | 1             | 10                  |
|          | 010                | 1                   | 0                   | 0               | 0     | 0              | 0              | 1             | 1              | 0100     | 1             | 00                  |
|          | 010                | 1                   | 1                   | 0               | 0     | 0              | 0              | 1             | 1              | 0100     | 1             | 00                  |
| Load/St  | 011                | 0                   | 0                   | 0               | 0     | 0              | 0              | 0             | 0              | 0100     | 0             | 10                  |
| ore      | 011                | 0                   | 1                   | 0               | 0     | 0              | 0              | 0             | 0              | 0100     | 0             | 10                  |
| Register | 011                | 1                   | 0                   | 0               | 0     | 0              | 0              | 0             | 0              | 0100     | 0             | 00                  |
| Offset   | 011                | 1                   | 1                   | 0               | 0     | 0              | 0              | 0             | 0              | 0100     | 0             | 00                  |
|          | 011                | 0                   | 0                   | 0               | 0     | 0              | 0              | 0             | 1              | 0100     | 1             | 10                  |
|          | 011                | 0                   | 1                   | 0               | 0     | 0              | 0              | 0             | 1              | 0100     | 1             | 10                  |
|          | 011                | 1                   | 0                   | 0               | 0     | 0              | 0              | 0             | 1              | 0100     | 1             | 00                  |
|          | 011                | 1                   | 1                   | 0               | 0     | 0              | 0              | 0             | 1              | 0100     | 1             | 00                  |

|        | l <sub>27-25</sub> | I <sub>24</sub> - L | l <sub>20</sub> | Bit_S | ID_B_in<br>str | Br_L_In<br>str | Shift_i<br>mm | Load_in<br>str | $ALU_OP$ | B_instr | RF_ena<br>ble | Data_Mem_<br>Opcode |
|--------|--------------------|---------------------|-----------------|-------|----------------|----------------|---------------|----------------|----------|---------|---------------|---------------------|
| Branch | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
|        | 101                | 0                   | 0               | 0     | 1              | 0              | 0             | 1              | *        | 1       | 0             | 10                  |
| Branch | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
| and    | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
| Link   | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |
|        | 101                | 1                   | 0               | 0     | 1              | 1              | 0             | 1              | *        | 1       | 1             | 10                  |

| Condcode | Description             | Flag tested     |
|----------|-------------------------|-----------------|
| 0000     | Equal                   | Z = 1           |
| 0001     | Not equal               | Z = 0           |
| 0010     | Unsigned higher or same | C = 1           |
| 0011     | Unsigned lower          | C = 0           |
| 0100     | Minus                   | N = 1           |
| 0101     | Positive or zero        | N = 0           |
| 0110     | Overflow                | V = 1           |
| 0111     | No Overflow             | V = 0           |
| 1000     | Unsigned higher         | C = 1 & Z = 0   |
| 1001     | Unsigned lower or same  | C = 0 or Z = 1  |
| 1010     | Greater or equal        | N = V           |
| 1011     | Less than               | N != V          |
| 1100     | Greater than            | Z = 0 & N = V   |
| 1101     | Less than or equal      | Z = 1    N != V |
| 1110     | Always                  |                 |