# Control Unit IF/ID

### TABLE OF CONTENTS

- 1 IMPLEMENTATION OF CONTROL UNIT Determining the opcodes of instructions and control signals
- 2 CONDITIONAL OPERATOR (NESTED)
  Introducing a useful operator used for inspecting multiple conditions
- 3 IMPLEMENTATION OF IF/ID REGISTER
  Implementing IF/ID
  pipeline register to store
  required data

- INTEGRATING ALL MODULES
   Integrate all modules which have been implemented up to now
- 5 INPUTS & OUTPUTS
  Describe inputs and outputs of required modules

# 1. IMPLEMENTATION OF CONTROL UNIT

|             | Control Signals |            |            |              |                |             |              |        |       |
|-------------|-----------------|------------|------------|--------------|----------------|-------------|--------------|--------|-------|
| Instruction | OpCode          | Reg<br>Dst | ALU<br>Src | Memto<br>Reg | Reg<br>Write ⊳ | Mem<br>Read | Mem<br>Write | Branch | ALUOp |
| R-type      | 000000          | 1          | 0          | 0            | 1              | 0           | 0            | 0      | 000   |
| lw          | 000100          | 0          | 1          | 1            | 1              | 1           | 0            | 0      | 011   |
| SW          | 000101          | 0          | 1          | 0            | 0              | 0           | 1            | 0      | 011   |
| addi        | 000111          | 0          | 1          | 0            | 1              | 0           | 0            | 0      | 011   |
| beq         | 000110          | 0          | 0          | 0            | 0              | 0           | 0            | 1      | 001   |
| slti        | 000001          | 0          | 1          | 0            | 1              | 0           | 0            | 0      | 010   |

## 2. CONDITIONAL OPERATOR (NESTED)

Just like the ternary operator in C (?:)

Example:

## 3. INTRODUCTION TO PIPELINE REGISTERS

- Placed between Fetch & Decode stages
- The outputs are produced on the positive edge of the clock in the stages, therefore, to make sure the data from pipeline registers are reliable, they need to output on the negative edge of the clock



## 4. INTEGRATING ALL MODULES



#### 5. INPUTS & OUTPUTS

Finally, it's time to instantiate the modules and connect them together. Modules which need to be instantiated and connected are as follows:

#### Control Unit:

- Inputs: Opcode (6 bits)
- Outputs: RegDst (1), ALUSrc (1), MemtoReg (1), RegWrite (1), MemRead (1), MemWrite (1),
   Branch (1), ALUOp (3)

#### IF/ID Register:

- Inputs:clk(1), next\_pc (32), instruction (32), hit (1)
- Outputs: instruction\_out (32), next\_pc\_out (3), hit\_out (1)

#### MIPS: (Instantiate Fetch, Decøde, Control Unit)