cs 152 lec 8.1 cs152: computer architecture and engineering lecture 9 designing single cycle control...

40
CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching Assistant George Porter, Teaching Assistant

Upload: cordelia-fowler

Post on 04-Jan-2016

214 views

Category:

Documents


1 download

TRANSCRIPT

Page 1: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152Lec 8.1

CS152: Computer Architecture

and Engineering

Lecture 9

Designing Single Cycle Control

Randy H. Katz, InstructorSatrajit Chatterjee, Teaching Assistant

George Porter, Teaching Assistant

Page 2: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.2

Recap: Summary from last time 5 steps to design a processor• 1. Analyze instruction set => datapath requirements

• 2. Select set of datapath components & establish clock methodology

• 3. Assemble datapath meeting the requirements

• 4. Analyze implementation of each instruction to determine setting of control points that effects the register transfer.

• 5. Assemble the control logic

MIPS makes it easier• Instructions same size

• Source registers always in same place

• Immediates same size, location

• Operations always on registers/immediates

Single cycle datapath CPI=1, Cycle Time = long!

Page 3: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.3

Recap: The MIPS Instruction Formats All MIPS instructions are 32 bits long. The 3 instruction formats:

• R-type

• I-type

• J-type

The different fields are:• op: operation of the instruction

• rs, rt, rd: the source and destination registers specifier

• shamt: shift amount

• funct: selects the variant of the operation in the “op” field

• address / immediate: address offset or immediate value

• target address: target address of the jump instruction

op target address

02631

6 bits 26 bits

op rs rt rd shamt funct

061116212631

6 bits 6 bits5 bits5 bits5 bits5 bits

op rs rt immediate016212631

6 bits 16 bits5 bits5 bits

Page 4: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.4

An Abstract View of the Implementation

DataOut

Clk

5

Rw Ra Rb

32 32-bitRegisters

Rd

ALU

Clk

Data In

DataAddress

IdealData

Memory

Instruction

InstructionAddress

IdealInstruction

Memory

Clk

PC

5Rs

5Rt

32

323232

A

B

Next

Ad

dre

ss

Control

Datapath

Control SignalsConditions

Page 5: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.5

Recap: A Single Cycle Datapath Rs, Rt, Rd and Imed16 hardwired into datapath from Fetch Unit

We have everything except control signals (underline)• Today’s lecture will show you how to generate the control signals

32

ALUctr

Clk

busW

RegWr

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

Rd

RegDst

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc

ExtOp

Mu

x

MemtoReg

Clk

Data InWrEn

32Adr

DataMemory

32

MemWrA

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0>

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

nPC_sel

Page 6: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.6

Recap: Meaning of the Control Signals

nPC_MUX_sel: 0 PC <– PC + 4 1 PC <– PC + 4 + SignExt(Im16) || 00

Later in lecture: higher-level connection between mux and branch cond

Adr

InstMemory

Ad

der

Ad

der

PC

Clk

00

Mu

x

4

nPC_MUX_sel

PC

Extim

m1

6

Page 7: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.7

Recap: Meaning of the Control Signals ExtOp: “zero”, “sign”

ALUsrc: 0 regB; 1 immed

ALUctr: “add”, “sub”, “or”

MemWr: 1 write memory

MemtoReg: 0 ALU; 1 Mem

RegDst: 0 “rt”; 1 “rd”

RegWr: 1 write register

32

ALUctr

Clk

busW

RegWr

32

32

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst

Exte

nd

er

Mu

x

3216imm16

ALUSrcExtOp

Mu

x

MemtoReg

Clk

Data InWrEn32 Adr

DataMemory

MemWr

ALU

Equal

0

1

0

1

01

=

Page 8: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.8

RTL: The Add Instruction

add rd, rs, rt

• mem[PC] Fetch the instruction from memory

• R[rd] <- R[rs] + R[rt] The actual operation

• PC <- PC + 4 Calculate the next instruction’s address

op rs rt rd shamt funct

061116212631

6 bits 6 bits5 bits5 bits5 bits5 bits

Page 9: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.9

Instruction Fetch Unit at the Beginning of Add Fetch the instruction from Instruction memory: Instruction <- mem[PC]

• This is the same for all instructions

PC

Ext

Adr

InstMemory

Ad

der

Ad

der

PC

Clk

00

Mu

x

4

nPC_MUX_sel

imm

16

Instruction<31:0>

Page 10: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.10

The Single Cycle Datapath During Add

32

ALUctr = Add

Clk

busW

RegWr = 1

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst = 1

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc = 0

ExtOp = x

Mu

x

MemtoReg = 0

Clk

Data InWrEn

32Adr

DataMemory

32

MemWr = 0A

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0> R[rd] <- R[rs] + R[rt]

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

op rs rt rd shamt funct

061116212631

nPC_sel= +4

Page 11: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.11

Instruction Fetch Unit at the End of Add PC <- PC + 4

• This is the same for all instructions except: Branch and Jump

Adr

InstMemory

Ad

der

Ad

der

PC

Clk

00

Mu

x

4

nPC_MUX_sel

imm

16

Instruction<31:0>

0

1

Page 12: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.12

The Single Cycle Datapath During Or Immediate

R[rt] <- R[rs] or ZeroExt[Imm16]

op rs rt immediate

016212631

32

ALUctr =

Clk

busW

RegWr =

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst =

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc =

ExtOp =

Mu

x

MemtoReg =

Clk

Data InWrEn

32Adr

DataMemory

32

MemWr = A

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0>

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

nPC_sel =

Page 13: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.14

The Single Cycle Datapath During Load

32

ALUctr = Add

Clk

busW

RegWr = 1

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst = 0

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc = 1

ExtOp = 1

Mu

x

MemtoReg = 1

Clk

Data InWrEn

32Adr

DataMemory

32

MemWr = 0A

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0>

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

R[rt] <- Data Memory {R[rs] + SignExt[imm16]}

op rs rt immediate

016212631

nPC_sel= +4

Page 14: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.15

The Single Cycle Datapath During Store

Data Memory {R[rs] + SignExt[imm16]} <- R[rt]

op rs rt immediate

016212631

32

ALUctr =

Clk

busW

RegWr =

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst =

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc =

ExtOp =

Mu

x

MemtoReg =

Clk

Data InWrEn

32Adr

DataMemory

32

MemWr = A

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0>

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

nPC_sel =

Page 15: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.16

The Single Cycle Datapath During Store

32

ALUctr = Add

Clk

busW

RegWr = 0

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst = x

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc = 1

ExtOp = 1

Mu

x

MemtoReg = x

Clk

Data InWrEn

32Adr

DataMemory

32

MemWr = 1A

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0>

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

Data Memory {R[rs] + SignExt[imm16]} <- R[rt]

op rs rt immediate

016212631

nPC_sel= +4

Page 16: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.17

The Single Cycle Datapath During Branch

32

ALUctr =Sub

Clk

busW

RegWr = 0

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst = x

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc = 0

ExtOp = x

Mu

x

MemtoReg = x

Clk

Data InWrEn

32Adr

DataMemory

32

MemWr = 0A

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0>

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

if (R[rs] - R[rt] == 0) then Zero <- 1 ; else Zero <- 0

op rs rt immediate

016212631

nPC_sel= “Br”

Page 17: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.18

Instruction Fetch Unit at the End of Branch

if (Zero == 1) then PC = PC + 4 + SignExt[imm16]*4; else PC = PC + 4

op rs rt immediate

016212631

What is encoding of nPC_sel?• Direct MUX select?

• Branch / not branch

Let’s choose second optionnPC_sel zero? MUX

0 x 01 0 01 1 1

Adr

InstMemory

Ad

der

Ad

der

PC

Clk

00

Mu

x

4

nPC_sel

imm

16

Instruction<31:0>

0

1

Zero

nPC_MUX_sel

Page 18: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.19

Step 4: Given Datapath: RTL -> Control

ALUctrRegDst ALUSrcExtOp MemtoRegMemWr Zero

Instruction<31:0><2

1:2

5>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

nPC_sel

Adr

InstMemory

DATA PATH

Control

Op

<2

1:2

5>

Fun

RegWr

Page 19: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.20

Summary of Control Signals

inst Register Transfer

ADD R[rd] <– R[rs] + R[rt]; PC <– PC + 4

ALUsrc = RegB, ALUctr = “add”, RegDst = rd, RegWr, nPC_sel = “+4”

SUB R[rd] <– R[rs] – R[rt]; PC <– PC + 4

ALUsrc = RegB, ALUctr = “sub”, RegDst = rd, RegWr, nPC_sel = “+4”

ORi R[rt] <– R[rs] + zero_ext(Imm16); PC <– PC + 4

ALUsrc = Im, Extop = “Z”, ALUctr = “or”, RegDst = rt, RegWr, nPC_sel = “+4”

LOAD R[rt] <– MEM[ R[rs] + sign_ext(Imm16)]; PC <– PC + 4

ALUsrc = Im, Extop = “Sn”, ALUctr = “add”, MemtoReg, RegDst = rt,

RegWr, nPC_sel = “+4”

STORE MEM[ R[rs] + sign_ext(Imm16)] <– R[rs];PC <– PC + 4

ALUsrc = Im, Extop = “Sn”, ALUctr = “add”, MemWr, nPC_sel = “+4”

BEQ if ( R[rs] == R[rt] ) then PC <– PC + sign_ext(Imm16)] || 00 else PC <– PC + 4

nPC_sel = “Br”, ALUctr = “sub”

Page 20: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.21

Summary of the Control Signals

add sub ori lw sw beq jump

RegDst

ALUSrc

MemtoReg

RegWrite

MemWrite

nPCsel

Jump

ExtOp

ALUctr<2:0>

1

0

0

1

0

0

0

x

Add

1

0

0

1

0

0

0

x

Sub

0

1

0

1

0

0

0

0

Or

0

1

1

1

0

0

0

1

Add

x

1

x

0

1

0

0

1

Add

x

0

x

0

0

1

0

x

Sub

x

x

x

0

0

0

1

x

xxx

op target address

op rs rt rd shamt funct

061116212631

op rs rt immediate

R-type

I-type

J-type

add, sub

ori, lw, sw, beq

jump

func

op 00 000000 000000 110110 0011 10 1011 00 010000 0010Appendix A10 0000See 10 0010 We Don’t Care :-)

Page 21: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.22

Concept of Local Decoding

R-type ori lw sw beq jump

RegDst

ALUSrc

MemtoReg

RegWrite

MemWrite

Branch

Jump

ExtOp

ALUop<N:0>

1

0

0

1

0

0

0

x

“ R-type”

0

1

0

1

0

0

0

0

Or

0

1

1

1

0

0

0

1

Add

x

1

x

0

1

0

0

1

Add

x

0

x

0

0

1

0

x

Sub

x

x

x

0

0

0

1

x

xxx

op 00 0000 00 1101 10 001110 1011 00 0100 00 0010

MainControl

op

6

ALUControl(Local)

func

N

6ALUop

ALUctr

3

ALU

Page 22: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.23

Encoding of ALUop

In this exercise, ALUop has to be 2 bits wide to represent:• (1) “R-type” instructions

• “I-type” instructions that require the ALU to perform:

- (2) Or, (3) Add, and (4) Subtract

To implement the full MIPS ISA, ALUop has to be 3 bits to represent:

• (1) “R-type” instructions

• “I-type” instructions that require the ALU to perform:- (2) Or, (3) Add, (4) Subtract, and (5) And (Example: andi)

MainControl

op

6

ALUControl(Local)

func

N

6ALUop

ALUctr

3

R-type ori lw sw beq jump

ALUop (Symbolic) “ R-type” Or Add Add Sub xxx

ALUop<2:0> 1 00 0 10 0 00 0 00 0 01 xxx

Page 23: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.24

Decoding of the “func” Field

R-type ori lw sw beq jump

ALUop (Symbolic) “ R-type” Or Add Add Subtract xxx

ALUop<2:0> 1 00 0 10 0 00 0 00 0 01 xxx

MainControl

op

6

ALUControl(Local)

func

N

6ALUop

ALUctr

3

op rs rt rd shamt funct

061116212631

R-type

funct<5:0>Instruction Operation

10 0000

10 0010

10 0100

10 0101

10 1010

add

subtract

and

or

set-on-less-than

ALUctr<2:0>ALU Operation

000

001

010

110

111

And

Or

Add

Subtract

Set-on-less-than

P. 286 text:

ALUctr

ALU

Page 24: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.25

Truth Table for ALUctr

R-type ori lw sw beqALUop(Symbolic)“ R-type” Or Add Add Subtract

ALUop<2:0> 1 00 0 10 0 00 0 00 0 01

ALUop func

bit<2>bit<1>bit<0> bit<2>bit<1>bit<0>bit<3>

0 0 0 x x x x

ALUctrALUOperation

Add 0 1 0

bit<2>bit<1>bit<0>

0 x 1 x x x x Subtract 1 1 0

0 1 x x x x x Or 0 0 1

1 x x 0 0 0 0 Add 0 1 0

1 x x 0 0 1 0 Subtract 1 1 0

1 x x 0 1 0 0 And 0 0 0

1 x x 0 1 0 1 Or 0 0 1

1 x x 1 0 1 0 Set on < 1 1 1

funct<3:0>Instruction Op.

0000

0010

0100

0101

1010

add

subtract

and

or

set-on-less-than

Page 25: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.26

Logic Equation for ALUctr<2>

ALUop func

bit<2>bit<1>bit<0> bit<2>bit<1>bit<0>bit<3> ALUctr<2>

0 x 1 x x x x 1

1 x x 0 0 1 0 1

1 x x 1 0 1 0 1

ALUctr<2> = !ALUop<2> & ALUop<0> +

ALUop<2> & !func<2> & func<1> & !func<0>

This makes func<3> a don’t care

Page 26: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.27

Logic Equation for ALUctr<1>

ALUop func

bit<2>bit<1>bit<0> bit<2>bit<1>bit<0>bit<3>

0 0 0 x x x x 1

ALUctr<1>

0 x 1 x x x x 1

1 x x 0 0 0 0 1

1 x x 0 0 1 0 1

1 x x 1 0 1 0 1

ALUctr<1> = !ALUop<2> & !ALUop<1> +

ALUop<2> & !func<2> & !func<0>

Page 27: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.28

Logic Equation for ALUctr<0>

ALUop func

bit<2>bit<1>bit<0> bit<2>bit<1>bit<0>bit<3> ALUctr<0>

0 1 x x x x x 1

1 x x 0 1 0 1 1

1 x x 1 0 1 0 1

ALUctr<0> = !ALUop<2> & ALUop<1>

+ ALUop<2> & !func<3> & func<2> & !func<1> & func<0>

+ ALUop<2> & func<3> & !func<2> & func<1> & !func<0>

Page 28: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.29

ALU Control Block

ALUControl(Local)

func

3

6ALUop

ALUctr

3

ALUctr<2> = !ALUop<2> & ALUop<0> +

ALUop<2> & !func<2> & func<1> & !func<0>

ALUctr<1> = !ALUop<2> & !ALUop<1> +

ALUop<2> & !func<2> & !func<0>

ALUctr<0> = !ALUop<2> & ALUop<1> + ALUop<2> & !

func<3> & func<2>

& !func<1> & func<0> + ALUop<2> &

func<3> & !func<2> & func<1> & !func<0>

Page 29: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.30

Step 5: Logic For Each Control Signal

nPC_sel <= if (OP == BEQ) then “Br” else “+4”

ALUsrc <= if (OP == “Rtype”) then “regB” else “immed”

ALUctr <= if (OP == “Rtype”) then functelseif (OP == ORi) then “OR”

elseif (OP == BEQ) then “sub” else “add”

ExtOp <= _____________

MemWr <= _____________

MemtoReg <= _____________

RegWr: <=_____________

RegDst: <= _____________

Page 30: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.32

“ Truth Table” for the Main Control

R-type ori lw sw beq jump

RegDst

ALUSrc

MemtoRegRegWrite

MemWrite

nPC_sel

JumpExtOp

ALUop (Symbolic)

1

0

01

0

0

0x

“ R-type”

0

1

01

0

0

00

Or

0

1

11

0

0

01

Add

x

1

x0

1

0

01

Add

x

0

x0

0

1

0x

Subtract

x

x

x0

0

0

1x

xxx

op 00 0000 00 1101 10 001110 1011 00 0100 00 0010

ALUop <2> 1 0 0 0 0 xALUop <1> 0 1 0 0 0 x

ALUop <0> 0 0 0 0 1 x

MainControl

op

6

ALUControl(Local)

func

3

6

ALUop

ALUctr

3

RegDst

ALUSrc

:

Page 31: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.33

“ Truth Table” for RegWrite

R-type ori lw sw beq jump

RegWrite 1 1 1 0 0 0

op 00 0000 00 110110 001110 1011 00 010000 0010

RegWrite = R-type + ori + lw= !op<5> & !op<4> & !op<3> & !op<2> & !op<1> & !

op<0>(R-type)

+ !op<5> & !op<4> & op<3> & op<2> & !op<1> & op<0>(ori)

+ op<5> & !op<4> & !op<3> & !op<2> & op<1> & op<0>(lw) op<0>

op<5>..op<5>..<0>

op<5>..<0>

op<5>..<0>

op<5>..<0>

op<5>..<0>

R-type ori lw sw beq jump

RegWrite

Page 32: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.34

PLA Implementation of the Main Control

op<0>

op<5>..op<5>..<0>

op<5>..<0>

op<5>..<0>

op<5>..<0>

op<5>..<0>

R-type ori lw sw beq jumpRegWrite

ALUSrc

MemtoReg

MemWrite

Branch

Jump

RegDst

ExtOp

ALUop<2>

ALUop<1>

ALUop<0>

Page 33: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.35

A Real MIPS Datapath (CNS T0)

Page 34: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.36

Putting it All Together: A Single Cycle Processor

32

ALUctr

Clk

busW

RegWr

3232

busA

32busB

55 5

Rw Ra Rb32 32-bitRegisters

Rs

Rt

Rt

RdRegDst

Exte

nd

er

Mu

x

Mux

3216imm16

ALUSrc

ExtOp

Mu

x

MemtoReg

Clk

Data InWrEn

32Adr

DataMemory

32

MemWrA

LU

InstructionFetch Unit

Clk

Zero

Instruction<31:0>

0

1

0

1

01<

21

:25

>

<1

6:2

0>

<1

1:1

5>

<0

:15

>

Imm16RdRsRt

MainControl

op

6

ALUControlfunc

6

3

ALUopALUctr

3RegDst

ALUSrc

:Instr<5:0>

Instr<31:26>

Instr<15:0>

nPC_sel

Page 35: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.37

Recap: An Abstract View of the Critical Path (Load) Register file and ideal memory:

• The CLK input is a factor ONLY during write operation

• During read operation, behave as combinational logic:- Address valid => Output valid after “access time.”

Critical Path (Load Operation) = PC’s Clk-to-Q + Instruction Memory’s Access Time + Register File’s Access Time + ALU to Perform a 32-bit Add + Data Memory Access Time + Setup Time for Register File Write + Clock Skew

Clk

5

Rw Ra Rb

32 32-bitRegisters

RdA

LU

Clk

Data In

DataAddress

IdealData

Memory

Instruction

InstructionAddress

IdealInstruction

Memory

Clk

PC

5Rs

5Rt

16Imm

32

323232

A

B

Next

Ad

dre

ss

Page 36: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.38

Worst Case Timing (Load)Clk

PC

Rs, Rt, Rd,Op, Func

Clk-to-Q

ALUctr

Instruction Memory Access Time

Old Value

New Value

RegWr

Old Value

New Value

Delay through Control Logic

busARegister File Access Time

Old Value

New Value

busB

ALU Delay

Old Value

New Value

Old Value

New Value

New Value

Old Value

ExtOp Old Value

New Value

ALUSrc Old Value

New Value

MemtoReg

Old Value

New Value

Address

Old Value

New Value

busW Old Value

New

Delay through Extender & Mux

RegisterWrite Occurs

Data Memory Access Time

Page 37: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.39

Drawback of this Single Cycle Processor

Long cycle time:• Cycle time must be long enough for the load instruction:

PC’s Clock -to-Q +

Instruction Memory Access Time +

Register File Access Time +

ALU Delay (address calculation) +

Data Memory Access Time +

Register File Setup Time +

Clock Skew

Cycle time for load is much longer than needed for all other instructions

Page 38: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.40

Preview

Next Time: MultiCycle Data Path•CPI 1, CycleTime much shorter (~1/5 of time)

Page 39: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.41

Single cycle datapath => CPI=1, CCT => long

5 steps to design a processor• 1. Analyze instruction set => datapath requirements

• 2. Select set of datapath components & establish clock methodology

• 3. Assemble datapath meeting the requirements

• 4. Analyze implementation of each instruction to determine setting of control points that effects the register transfer.

• 5. Assemble the control logic

Control is the hard part

MIPS makes control easier• Instructions same size

• Source registers always in same place

• Immediates same size, location

• Operations always on registers/immediates

Summary

Control

Datapath

Memory

ProcessorInput

Output

Page 40: CS 152 Lec 8.1 CS152: Computer Architecture and Engineering Lecture 9 Designing Single Cycle Control Randy H. Katz, Instructor Satrajit Chatterjee, Teaching

CS 152 Lec 8.42

Where To Get More Information?

Chapter 5.1 to 5.3 of your text book:• David Patterson and John Hennessy, “Computer

Organization & Design: The Hardware / Software Interface,” Second Edition, Morgan Kaufman Publishers, San Mateo, California, 1998.

One of the best PhD thesis on processor design:• Manolis Katevenis, “Reduced Instruction Set Computer

Architecture for VLSI,” PhD Dissertation, EECS, U C Berkeley, 1982.

For a reference on the MIPS architecture:• Gerry Kane, “MIPS RISC Architecture,” Prentice Hall.