

## -C-S-E\_=2021== -C-O-M-FU-T-E-R==-O-R-G-A-N-I-Z-A-T-I-O-N

| ]-         | لل<br>ر   |           | FI<br>SE     | <u>}</u>  |             | <b>C</b> | _]-<br>]_[     | -<br>           | <u>2</u>   | <b>S-S</b><br>U | Ē                     | <u>-</u> R | □ <u>+</u> | E N<br>Y T<br>O T<br>U R<br>T | もレ保の文頼な    | Late 12 and |   |       | の文積なフト社        | 一点方子花町・ |          | 「保の」文精なフィ      |
|------------|-----------|-----------|--------------|-----------|-------------|----------|----------------|-----------------|------------|-----------------|-----------------------|------------|------------|-------------------------------|------------|-------------|---|-------|----------------|---------|----------|----------------|
| THOFT NR M | Z UFBOKEN | - ac uzco | - 右部 をじ美と 学印 | く きちょうちょう | 8 mg ~ 2 mg | IS YHE M | 1 第11日初報 中部日 3 | 17 び技す国出のシ品     | 8 0 0 UE 8 | EO ANAGEN       | の 文 頼 な つ 、 ト 社 明 、 ・ |            |            |                               | ラト社開たに美と学の | HTEELBARDS  |   | E THE | は明 をに美と 学印 び技力 |         | WHEN YOU | 上 加賀 をに美と 字印 び |
| N H E N    | E O A N   | I - + 0 I | び技す 国出       | Mag.      | 22.47 00    | A<br>T   |                | 3 <b>11</b> 叶德湖 |            |                 | をに美と 字印               | 4<br>P     |            |                               |            | 8           | G | -W    | 10-]           | M       |          | 技吉             |

DR

## Agenda

#### Topics:

- 1. Multiple cycle implementation review
- 2. State Machine
- 3. Control Unit implementation for Multi-cycle core

#### Patterson: Section 4.5

Reminder: Quiz #2 – Wednesday (November 10)

## Breaking the Instruction Execution into Clock Cycles

Execution of each instruction is broken into a series of steps

- Each step is balanced to do almost equal amount of work
- Each step takes one clock cycle
- Each step contains at the most 1 ALU operation, or 1 register file access, or 1 memory access
- Operations listed in 1 step occurs in parallel in 1 clock cycle
- Different steps occur in different clock cycles
  - Different steps are:
    - 1. IF: Instruction fetch step
    - 2. ID: Instruction decode and register fetch step
    - 3. EX: Execution, memory address computation, or branch completion step
    - 4. MEM: Memory access of R-type instruction completion step
    - 5. WB: Write back completion step

#### Multicycle Implementation: Control Units added



### Action of 2-bit Control Signals

| Control<br>Input | Value | Effect                                                                                                                          |
|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------|
|                  | 00    | ALU performs an add operation                                                                                                   |
| ALUOp            | 01    | ALU performs a subtract operation                                                                                               |
|                  | 10    | The function field of Instruction defines the operation of ALU                                                                  |
|                  | 00    | The second operand of ALU comes from Register B                                                                                 |
|                  | 01    | The second operand of ALU = 4                                                                                                   |
| ALUSrcB          | 10    | The second operand of ALU is sign extended Instruction[15-0]                                                                    |
|                  | 11    | The second operand of ALU is sign extended, 2-bit left shifted Instruction[15-0]                                                |
|                  | 00    | Output of ALU (PC + 4) is sent to PC                                                                                            |
| PCSource         | 01    | <b>Contents of ALUOut (branch target address = PC + 4 + 4 x offset) is sent to PC</b>                                           |
|                  | 10    | Contents of Instruction[25-0], shift left by 2, and concatenated with the MSB 4-<br>bits of PC is sent to PC (jump instruction) |

....

#### Action of 1-bit Control Signals

| <b>Control Input</b> | Effect when Deasserted (0)                                               | Effect when asserted (1)                                                                 |
|----------------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| IorD                 | PC supplies address to memory (instruction fetch)                        | ALUout supplies address to memory (lw/sw)                                                |
| MemRead              | None                                                                     | Memory content specified by address is placed on<br>"Memdata" o/p (lw/any instruction)   |
| MemWrite             | None                                                                     | I/p "Write data" is stored at specified address (sw)                                     |
| IRWrite              | None                                                                     | "MemData" o/p is written on IR (instruction fetch)                                       |
| RegDst               | "Write Register" specified by Instruction[20-16] (lw)                    | "WriteRegister" specified by Instruction[15-11] (R-<br>type)                             |
| RegWrite             | None                                                                     | Data from "WriteData" i/p is written on the register specified by "WriteRegister" number |
| ALUSrcA              | PC is the first operand in ALU (increment PC)                            | Register A is the first operand in ALU                                                   |
| MemtoReg             | "WriteData" of the register file comes from ALUOut                       | "WriteData" of the register file comes from MDR                                          |
| PCWrite              | <b>Operation at PC depends on PCWriteCond and zero<br/>output of ALU</b> | PC is written; Source is determined by PCSource                                          |
| PCWriteCond          | <b>Operation at PC depends on PCWrite</b>                                | PC is written if zero o/p of ALU = 1; Source is determined by PCSource                   |



#### Summary of Steps used in different Instructions

|                                                               | Action for                                                                                                 |                                                                           |                                         |                                                  |  |  |  |  |  |  |
|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------|--|--|--|--|--|--|
| Step Name                                                     | <b>R-type Instruction</b>                                                                                  | Memory Reference<br>Instruction                                           | Branch                                  | Jump                                             |  |  |  |  |  |  |
| <b>IF</b> - Instruction<br>fetch                              | IR = Memory[PC]; $PC = PC + 4;$                                                                            |                                                                           |                                         |                                                  |  |  |  |  |  |  |
| ID - Instruction<br>decode /<br>Register fetch                | <pre>A = Reg[IR[25-21]];<br/>B = Reg[IR[20-16]];<br/>ALUOut = PC + (sign-extend(IR[15-0])&lt;&lt;2);</pre> |                                                                           |                                         |                                                  |  |  |  |  |  |  |
| EX –<br>R-type Execution /<br>address comp. /<br>Branch /Jump | ALUOut=A op B                                                                                              | ALUOut = A + sign-<br>extend(IR[15-0])                                    | <pre>if(A == B) then PC = ALUOut;</pre> | <pre>PC = PC[31-28]   (IR[25-0)&lt;&lt;2);</pre> |  |  |  |  |  |  |
| MEM - Memory<br>Access /<br>R-type Completion                 | Reg[IR[15-11]]<br>= ALUOut;                                                                                | <pre>lw:<br/>MDR = Memory[ALUOut]<br/>or sw:<br/>Memory[ALUOut] = B</pre> |                                         |                                                  |  |  |  |  |  |  |
| WB - Memory Read<br>Completion                                |                                                                                                            | lw:<br>Reg[IR[20-16]]=MDR;                                                |                                         |                                                  |  |  |  |  |  |  |



#### Multipath Datapath Implementation: Control

- Recall that design of single cycle datapath was based on a combinational circuit
- Design of multicycle datapath is more complicated
  - 1. Instructions are executed in a series of steps
  - 2. Each step must occur in a sequence
  - 3. Control of multicycle must specify both the control signals and the next step

Wll-M

- The control of a multicycle datapath is based on a sequential circuit referred to as a finite state machine State 0
- A finite state diagram for a 2-bit counter
- Each state specifies a set of outputs
- By default, unspecified outputs are assumed disabled
- The number of the arrows identify inputs



묘

# Finite State Machine?

- See Appendix C
  - A sequential logic function which has a state and inputs

     the logic function determines the next state and outputs
    - Moore machine outputs depend on just the current state
    - Mealy machine outputs depend on current state and inputs
  - Book uses Moore machine description



### Finite State Machine Control of Multicycle Datapath (1)



High-Level View

۳٢

### Finite State Machine Control of Multicycle Datapath (2)



Fig. D.3.1: Steps 1 and 2: Instruction Fetch and Decode Instructions

-• C



Finite State Machine Control of Multicycle Datapath (3)

> Finite State Machine for Memory Reference Instructions

> > **₩**



### Finite State Machine Control of Multicycle Datapath (4)



Finite State Machines for R-type Instructions

-• C

wll-M

#### Finite State Machine Control of Multicycle Datapath (5)





Finite State Machine for Branch Instruction

۳Ţ

Finite State Machine for Jump Instruction





#### Finite State Machine Control of Multicycle Datapath (5)



## Control Logic – Truth Table

Note that control outputs depend only on current state (Op column is blank for all output rows)

Next state depends on current state and inputs (opcode from instruction)

| Output      | Current states                             | Ор                        |
|-------------|--------------------------------------------|---------------------------|
| PCWrite     | state0 + state9                            |                           |
| PCWriteCond | state8                                     |                           |
| lorD        | state3 + state5                            |                           |
| MemRead     | state0 + state3                            |                           |
| MemWrite    | state5                                     |                           |
| IRWrite     | state0                                     |                           |
| MemtoReg    | state4                                     |                           |
| PCSource1   | state9                                     |                           |
| PCSource0   | state8                                     |                           |
| ALUOp1      | state6                                     |                           |
| ALUOp0      | state8                                     |                           |
| ALUSrcB1    | state1 +state2                             |                           |
| ALUSrcB0    | state0 + state1                            |                           |
| ALUSrcA     | state2 + state6 + state8                   |                           |
| RegWrite    | state4 + state7                            |                           |
| RegDst      | state7                                     |                           |
| NextState0  | state4 + state5 + state7 + state8 + state9 |                           |
| NextState1  | state0                                     |                           |
| NextState2  | state1                                     | (Op = '1w') + (Op = 'sw') |
| NextState3  | state2                                     | (Op = '1w')               |
| NextState4  | state3                                     |                           |
| NextState5  | state2                                     | (Op = 'sw')               |
| NextState6  | state1                                     | (Op = 'R-type')           |
| NextState7  | state6                                     |                           |
| NextState8  | state1                                     | (Op = 'beq')              |
| NextState9  | state1                                     | (Op = 'jmp')              |