## COMPUTER ASSIGNMENT 2 (SINGLE CYCLE MIPS PROCESSOR)

سید محمد امین اطیابی (۸۱۰۱۹۸۵۵۹)

محمد سعادتی (۱۹۸۴۱۰)

## Data Path:



## CONTROLLER:

|      | REG_DST | REG_WRITE | ALU_SRC | MEMREAD | MEMWRITE | MEM_TO_REG | WRITE_DATA | BRANCH | BRANCH_NOT_EQUAL | ALU_OPERATION | JUMP | JR |
|------|---------|-----------|---------|---------|----------|------------|------------|--------|------------------|---------------|------|----|
| LW   | 00      | 1         | 1       | 1       | 0        | 1          | 00         | 0      | 0                | 00            | 0    | 0  |
| SW   | -       | 0         | 1       | 0       | 1        | -          | 00         | 0      | 0                | 00            | 0    | 0  |
| BEQ  | -       | 0         | 0       | 0       | 0        | -          | 00         | 1      | 0                | 01            | 0    | 0  |
| BNE  | -       | 0         | 0       | 0       | 0        | -          | 00         | 0      | 1                | 01            | 0    | 0  |
| SUB  | 01      | 1         | 0       | 0       | 0        | 0          | 00         | 0      | 0                | 10            | 0    | 0  |
| ADD  | 01      | 1         | 0       | 0       | 0        | 0          | 00         | 0      | 0                | 10            | 0    | 0  |
| ADDI | 00      | 1         | 1       | 0       | 0        | 0          | 00         | 0      | 0                | 00            | 0    | 0  |
| SLT  | 01      | 1         | 0       | 0       | 0        | 0          | 00         | 0      | 0                | 10            | 0    | 0  |
| SLTI | 00      | 1         | 1       | 0       | 0        | 0          | 10         | 0      | 0                | 11            | 0    | 0  |
| J    | 00      | 0         | 0       | 0       | 0        | 0          | 00         | 0      | 0                | 00            | 1    | 0  |
| JAL  | 10      | 0         | 0       | 0       | 0        | 0          | 01         | 0      | 0                | 00            | 1    | 0  |
| JR   | 00      | 0         | 0       | 0       | 0        | 0          | 00         | 0      | 00               | 10            | 1    | 1  |

## TEST BENCH ASSEMBLY:

| PC | OPCODE                               | OPCODE BITFIELDS                        |  |  |  |
|----|--------------------------------------|-----------------------------------------|--|--|--|
| 0  | ADD R1,R0,R0                         | 0000000000000000001000001               |  |  |  |
| 4  | SW R1, 2000(R0)                      | 1010110000000010000011111010000         |  |  |  |
| 8  | FOR Slti R2,R1,10*4                  | 001010000010001000000000101000          |  |  |  |
| 12 | BEQ.R2,R0, END_FOR<br>(PC +=6*4 + 4) | 000100000100000000000000000110          |  |  |  |
| 16 | LW R3,1000(R1)                       | 10001100001000110000001111101000        |  |  |  |
| 20 | LW R4,2000(R0)                       | 1000110000000100000011111010000         |  |  |  |
| 24 | ADD R5,R4,R3                         | 00000000110010000101000001              |  |  |  |
| 28 | SW R5, 2000(R0)                      | 10101100000001010000011111010000        |  |  |  |
| 32 | Addi R1,R1,4                         | 00100000010000100000000000100           |  |  |  |
| 36 | J FOR (PC =4*2)                      | 000010000000000000000000000000000000000 |  |  |  |
| 40 | LW R6,2000(R0)<br>End for            | 10001100000001100000011111010000        |  |  |  |