#### **ALU Control**

### A. Instruction Type

| Field                        | 0        | rs    | rt    | rd    | shamt   | funct |  |  |
|------------------------------|----------|-------|-------|-------|---------|-------|--|--|
| Bit positions                | 31:26    | 25:21 | 20:16 | 15:11 | 10:6    | 5:0   |  |  |
| a. R-type instruction        |          |       |       |       |         |       |  |  |
|                              |          |       |       |       |         |       |  |  |
| Field                        | 35 or 43 | rs    | rt    |       | address |       |  |  |
| Bit positions                | 31:26    | 25:21 | 20:16 |       | 15:0    |       |  |  |
| b. Load or store instruction |          |       |       |       |         |       |  |  |

| Field         | 4     | rs    | rt    | address |
|---------------|-------|-------|-------|---------|
| Bit positions | 31:26 | 25:21 | 20:16 | 15:0    |

c. Branch instruction

### **B.** Computer Diagram with Control



## C. ALU Control

| ALU control lines | Function         |
|-------------------|------------------|
| 0000              | AND              |
| 0001              | OR               |
| 0010              | add              |
| 0110              | subtract         |
| 0111              | set on less than |
| 1100              | NOR              |

# D. ALU Operation VS ALU Control

| Instruction opcode | ALUOp | Instruction operation | Funct field | Desired<br>ALU action | ALU control<br>input |
|--------------------|-------|-----------------------|-------------|-----------------------|----------------------|
| LW                 | 00    | load word             | XXXXXX      | add                   | 0010                 |
| SW                 | 00    | store word            | XXXXXX      | add                   | 0010                 |
| Branch equal       | 01    | branch equal          | XXXXXX      | subtract              | 0110                 |
| R-type             | 10    | add                   | 100000      | add                   | 0010                 |
| R-type             | 10    | subtract              | 100010      | subtract              | 0110                 |
| R-type             | 10    | AND                   | 100100      | AND                   | 0000                 |
| R-type             | 10    | OR                    | 100101      | OR                    | 0001                 |
| R-type             | 10    | set on less than      | 101010      | set on less than      | 0111                 |

## E. ALU Operation VS ALU Control + Don't Care term

| ALI    | Funct field |    |    |    |    |    |    |           |
|--------|-------------|----|----|----|----|----|----|-----------|
| ALUOp1 | ALUOp0      | F5 | F4 | F3 | F2 | F1 | F0 | Operation |
| 0      | 0           | X  | X  | X  | X  | X  | Х  | 0010      |
| 0      | 1           | Χ  | Х  | Х  | Х  | Х  | Х  | 0110      |
| 1      | 0           | Х  | Х  | 0  | 0  | 0  | 0  | 0010      |
| 1      | X           | X  | Х  | 0  | 0  | 1  | 0  | 0110      |
| 1      | 0           | X  | Х  | 0  | 1  | 0  | 0  | 0000      |
| 1      | 0           | X  | Х  | 0  | 1  | 0  | 1  | 0001      |
| 1      | X           | X  | Х  | 1  | 0  | 1  | 0  | 0111      |

### F. Computer Diagram



### G. Control Signal Meaning

| Signal<br>name | Effect when deasserted                                                                       | Effect when asserted                                                                                          |
|----------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| RegDst         | The register destination number for the Write register comes from the rt field (bits 20:16). | The register destination number for the Write register comes from the rd field (bits 15:11).                  |
| RegWrite       | None.                                                                                        | The register on the Write register input is written with the value on the Write data input.                   |
| ALUSrc         | The second ALU operand comes from the second register file output (Read data 2).             | The second ALU operand is the sign-<br>extended, lower 16 bits of the instruction.                            |
| PCSrc          | The PC is replaced by the output of the adder that computes the value of PC + 4.             | The PC is replaced by the output of the adder that computes the branch target.                                |
| MemRead        | None.                                                                                        | Data memory contents designated by the address input are put on the Read data output.                         |
| MemWrite       | None.                                                                                        | Data memory contents designated by the<br>address input are replaced by the value on<br>the Write data input. |
| MemtoReg       | The value fed to the register Write data input comes from the ALU.                           | The value fed to the register Write data input comes from the data memory.                                    |

#### **H.** Control of Each Instructions

| Instruction | RegDst | ALUSTC | Memto-<br>Reg | Reg-<br>Write | Mem-<br>Read | Mem-<br>Write | Branch | ALUOp1 | ALUOp0 |
|-------------|--------|--------|---------------|---------------|--------------|---------------|--------|--------|--------|
| R-format    | 1      | 0      | 0             | 1             | 0            | 0             | 0      | 1      | 0      |
| 1w          | 0      | 1      | 1             | 1             | 1            | 0             | 0      | 0      | 0      |
| SW          | X      | 1      | Х             | 0             | 0            | 1             | 0      | 0      | 0      |
| beq         | X      | 0      | Х             | 0             | 0            | 0             | 1      | 0      | 1      |

# I. Control and Operation Code

| Input or output | Signal name | R-format | 1w | SW | beq |
|-----------------|-------------|----------|----|----|-----|
| Inputs          | Op5         | 0        | 1  | 1  | 0   |
|                 | Op4         | 0        | 0  | 0  | 0   |
|                 | Op3         | 0        | 0  | 1  | 0   |
|                 | Op2         | 0        | 0  | 0  | 1   |
|                 | Op1         | 0        | 1  | 1  | 0   |
|                 | Op0         | 0        | 1  | 1  | 0   |
| Outputs         | RegDst      | 1        | 0  | χ  | Х   |
|                 | ALUSrc      | 0        | 1  | 1  | 0   |
|                 | MemtoReg    | 0        | 1  | Х  | Х   |
|                 | RegWrite    | 1        | 1  | 0  | 0   |
|                 | MemRead     | 0        | 1  | 0  | 0   |
|                 | MemWrite    | 0        | 0  | 1  | 0   |
|                 | Branch      | 0        | 0  | 0  | 1   |
|                 | ALUOp1      | 1        | 0  | 0  | 0   |
|                 | ALUOp0      | 0        | 0  | 0  | 1   |