l’unità di elaborazione e di controllo _elaborazione.pdfuniversità degli studi di bergamo -...

106
1 Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 L’unità di elaborazione e di controllo

Upload: others

Post on 03-Jul-2020

0 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

1Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

L’unità di elaborazione e di controllo

Page 2: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

2Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• We're ready to look at an implementation of the MIPS

• Simplified to contain only:

– memory-reference instructions: lw, sw

– arithmetic-logical instructions: add, sub, and, or, slt

– control flow instructions: beq, j

• Generic Implementation:

– use the program counter (PC) to supply instruction address

– get the instruction from memory

– read registers

– use the instruction to decide exactly what to do

• All instructions use the ALU after reading the registers

Why? memory-reference? arithmetic? control flow?

The Processor: Datapath & Control

Page 3: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

3Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Abstract / Simplified View:

Two types of functional units:

– elements that operate on data values (combinational)

– elements that contain state (sequential)

More Implementation Details

Registers

Register #

Data

Register #

Data

memory

Address

Data

Register #

PC Instruction ALU

Instructionmemory

Address

Page 4: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

4Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

•Segnale affermato = livello logico vero (1)

•Elementi combinatori:

le uscite dipendono solo dagli ingressi nello stesso istante

•Elementi sequenziali:

le uscite dipendono sia dagli ingressi che dallo stato memorizzato ad un dato

momento (memorie, registri, flip flop).

Sarebbe possibile far ripartire un elemento dopo un’interruzione caricando gli stessi

elementi contenuti prima di essa.

Almeno due ingressi: valore da scrivere e segnale di sincronismo (clock) per

determinare la scrittura.

La lettura può avvenire in qualunque istante.

Convenzioni logiche e temporizzazioni

Page 5: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

5Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Unclocked vs. Clocked

• Clocks used in synchronous logic

– when should an element that contains state be updated?

cycle time

rising edge

falling edge

State Elements

Page 6: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

6Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• The set-reset latch

– output depends on present inputs and also on past inputs

An unclocked state element

Q

_Q

R

S

SET RESET Q not Q

0 0 Q not Q

0 1 0 1

1 0 1 0

1 1 non permessa

Page 7: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

7Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Output is equal to the stored value inside the element(don't need to ask for permission to look at the value)

• Change of state (value) is based on the clock

• Latches: whenever the inputs change, and the clock is asserted

• Flip-flop: state changes only on a clock edge(edge-triggered methodology)

"logically true",

— could mean electrically low

A clocking methodology defines when signals can be read and written

— wouldn't want to read a signal at the same time it was being written

Latches and Flip-flops

Page 8: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

8Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Two inputs:

– the data value to be stored (D)

– the clock signal (C) indicating when to read & store D

• Two outputs:

– the value of the internal state (Q) and it's complement

D-latch

Q

C

D

_Q

D

C

Q

Page 9: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

9Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

D flip-flop

• Output changes only on the clock edge

QQ

_Q

Q

_Q

Dlatch

D

C

Dlatch

DD

C

C

D

C

Q

Page 10: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

10Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Our Implementation

• An edge triggered methodology

• Typical execution:

– read contents of some state elements,

– send values through some combinational logic

– write results to one or more state elements

Clock cycle

Stateelement

1Combinational logic

Stateelement

2

Page 11: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

11Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Built using D flip-flops

Register File

Read registernumber 1 Read

data 1

Readdata 2

Read registernumber 2

Register fileWriteregister

Writedata Write

Nell’architettura MIPS si ha un register file a 4 ingressi e 2 uscite: due ingressi rappresentano la coppia di registri in lettura, un ingresso è per selezionare il registro da scrivere ed uno per il dato da scrivere.

Le due uscite permettono di leggere 2 dati allo stesso tempo.

Inoltre c’è un segnale di sincronismo per la scrittura.

Page 12: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

12Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Built using D flip-flops

Register File: lettura

Mux

Register 0

Register 1

Register n – 1

Register n

Mux

Read data 1

Read data 2

Read registernumber 1

Read registernumber 2

Implementazione lettura 2 registri tramite due multiplexer (mux) in cui l’ingresso di selezione è il numero fornito in uno dei due ingressi al register file

Page 13: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

13Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Register File: scrittura

• Note: we still use the real clock to determine when to write

n-to-1decoder

Register 0

Register 1

Register n – 1C

C

D

D

Register n

C

C

D

D

Register number

Write

Register data

0

1

n – 1

n

Il decodificatore seleziona il registro per la scrittura: il n° del registro fornito in ingresso seleziona solo una delle n uscite e quindi uno solo dei registri.

La scrittura avviene solo quando il write è affermato sul pin di clock del registro selezionato.

Non è possibile leggere e scrivere dallo stesso registro nello stesso ciclo di clock:o si legge il valore scritto nel ciclo precedente o si dovrà attendere un prossimociclo per poter leggere il valore appena scritto.

Page 14: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

14Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Simple Implementation

• Include the functional units we need for each instruction

Why do we need this stuff?

PC

Instructionmemory

Instructionaddress

Instruction

a. Instruction memory b. Program counter

Add Sum

c. Adder

ALU control

RegWrite

RegistersWriteregister

Readdata 1

Readdata 2

Readregister 1

Readregister 2

Writedata

ALUresult

ALU

Data

Data

Registernumbers

a. Registers b. ALU

Zero5

5

5 3

16 32Sign

extend

b. Sign-extension unit

MemRead

MemWrite

Datamemory

Writedata

Readdata

a. Data memory unit

Address

Page 15: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

15Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Instruction & PC

Page 16: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

16Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Registers and ALU

Page 17: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

17Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Adding the data memory

Page 18: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

18Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Branch data path

Page 19: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

19Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Putting things together

Page 20: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

20Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Adding the instruction fetch unit

Page 21: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

21Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Adding branch logic

Page 22: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

22Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Control

• Selecting the operations to perform (ALU, read/write, etc.)

• Controlling the flow of data (multiplexor inputs)

• Information comes from the 32 bits of the instruction

• Example:

add $8, $17, $18 Instruction Format:

000000 10001 10010 01000 00000 100000

op rs rt rd shamt funct

• ALU's operation based on instruction type and function code

Page 23: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

23Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• e.g., what should the ALU do with this instruction

• Example: lw $1, 100($2)

35 2 1 100

op rs rt 16 bit offset

• ALU control input

000 AND

001 OR

010 add

110 subtract

111 set-on-less-than

• Why is the code for subtract 110 and not 011?

Control

Page 24: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

24Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Basic control

Page 25: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

25Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

ALU control

Page 26: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

26Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Funzione di controllo ALU

Operation2

Operation1

Operation0

Operation

ALUOp1

F3

F2

F1

F0

F (5– 0)

ALUOp0

ALUOp

ALU control block

ALUop1 ALUop0 F5 F4 F3 F2 F1 F0

x 1 x x x x x x

1 x x x x x 1 x

ALUop1 ALUop0 F5 F4 F3 F2 F1 F0

0 x x x x x x x

x x x x x 0 x x

ALUop1 ALUop0 F5 F4 F3 F2 F1 F0

1 x x x x x x 1

1 x x x 1 x x x

Operation 0

Operation 1

Operation 2

Page 27: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

27Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Main control

Page 28: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

28Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Extended data path

Page 29: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

29Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Summary of control lines

Page 30: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

30Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Control

Instruction RegDst ALUSrc

Memto-

Reg

Reg

Write

Mem

Read

Mem

Write Branch ALUOp1 ALUp0

R-format 1 0 0 1 0 0 0 1 0lw 0 1 1 1 1 0 0 0 0sw X 1 X 0 0 1 0 0 0beq X 0 X 0 0 0 1 0 1

PC

Instructionmemory

Readaddress

Instruction[31– 0]

Instruction [20– 16]

Instruction [25– 21]

Add

Instruction [5– 0]

MemtoReg

ALUOp

MemWrite

RegWrite

MemRead

Branch

RegDst

ALUSrc

Instruction [31– 26]

4

16 32Instruction [15– 0]

0

0Mux

0

1

Control

Add ALUresult

Mux

0

1

RegistersWriteregister

Writedata

Readdata 1

Readdata 2

Readregister 1

Readregister 2

Signextend

Shiftleft 2

Mux

1

ALUresult

Zero

Datamemory

Writedata

Readdata

Mux

1

Instruction [15– 11]

ALUcontrol

ALUAddress

Page 31: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

31Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Main control

• Simple combinational logic (truth tables)

R-format Iw sw beq

Op0

Op1

Op2

Op3

Op4

Op5

Inputs

Outputs

RegDst

ALUSrc

MemtoReg

RegWrite

MemRead

MemWrite

Branch

ALUOp1

ALUOpO

Page 32: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

32Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Jump instruction

Page 33: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

33Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Data path supporting jump

Page 34: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

34Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• All of the logic is combinational

• We wait for everything to settle down, and the right thing to be done

– ALU might not produce “right answer” right away

– we use write signals along with clock to determine when to write

• Cycle time determined by length of the longest path

Our Simple Control Structure

We are ignoring some details like setup and hold times

Clock cycle

Stateelement

1Combinational logic

Stateelement

2

Page 35: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

35Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Where we are headed

• Single Cycle Problems:

– what if we had a more complicated instruction like floating point?

– wasteful of area

• One Solution:

– use a “smaller” cycle time

– have different instructions take different numbers of cycles

– a “multicycle” datapath:

PC

Memory

Address

Instructionor data

Data

Instructionregister

Registers

Register #

Data

Register #

Register #

ALU

Memorydata

register

A

B

ALUOut

Page 36: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

36Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• We will be reusing functional units

– ALU used to compute address and to increment PC

– Memory used for instruction and data

• Our control signals will not be determined solely by instruction

– e.g., what should the ALU do for a “subtract” instruction?

• We’ll use a finite state machine for control

Multicycle Approach

Page 37: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

37Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Finite state machines:

– a set of states and

– next state function (determined by current state and the input)

– output function (determined by current state and possibly input)

– We’ll use a Moore machine (output based only on current state)

Review: finite state machines

Next-statefunction

Current state

Clock

Outputfunction

Nextstate

Outputs

Inputs

Page 38: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

38Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Break up the instructions into steps, each step takes a cycle

– balance the amount of work to be done

– restrict each cycle to use only one major functional unit

• At the end of a cycle

– store values for use in later cycles (easiest thing to do)

– introduce additional “internal” registers

Multicycle Approach

Shift

left 2

PC

Memory

M emData

Writedata

Mux

0

1

RegistersW ritereg ister

W ritedata

Readda ta 1

Readda ta 2

Readregister 1

Readregister 2

Mux

0

1

Mux

0

1

4

Instruction[15– 0]

Sign

extend

3216

Instruction[25– 21]

Instruction[20– 16]

Instruction[15– 0]

Instruction

regis ter1 M

ux

0

3

2

Mux

ALUresult

ALU

Zero

Memorydata

reg ister

Instruction[15– 11]

A

B

ALUO ut

0

1

Address

Page 39: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

39Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Data path

Page 40: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

40Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Data path with control signals

Page 41: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

41Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

PC handling

Page 42: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

42Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Complete data path & control

Page 43: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

43Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Control signals

Page 44: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

44Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Control signals

Page 45: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

45Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Breaking the instructions

Page 46: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

46Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Instruction Fetch

• Instruction Decode and Register Fetch

• Execution, Memory Address Computation, or Branch Completion

• Memory Access or R-type instruction completion

• Write-back step

INSTRUCTIONS TAKE FROM 3 - 5 CYCLES!

Five Execution Steps

Page 47: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

47Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Use PC to get instruction and put it in the Instruction Register.

• Increment the PC by 4 and put the result back in the PC.

• Can be described succinctly using RTL "Register-Transfer Language"

IR = Memory[PC];

PC = PC + 4;

Can we figure out the values of the control signals?

What is the advantage of updating the PC now?

Step 1: Instruction Fetch

Page 48: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

48Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Step 1: Instruction Fetch

Page 49: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

49Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Read registers rs and rt in case we need them

• Compute the branch address in case the instruction is a branch

• RTL:

A = Reg[IR[25-21]];

B = Reg[IR[20-16]];

ALUOut = PC + (sign-extend(IR[15-0]) << 2);

• We aren't setting any control lines based on the instruction type (we are busy "decoding" it in our control logic)

Step 2: Instruction Decode and Register Fetch

Page 50: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

50Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Step 2: Instruction Decode and Register Fetch

Page 51: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

51Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• ALU is performing one of three functions, based on instruction type

• Memory Reference:

ALUOut = A + sign-extend(IR[15-0]);

• R-type:

ALUOut = A op B;

• Branch:

if (A==B) PC = ALUOut;

Step 3 (instruction dependent)

Page 52: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

52Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Step 3 (instruction dependent)

Page 53: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

53Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Step 3 (instruction dependent)

Page 54: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

54Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Loads and stores access memory

MDR = Memory[ALUOut];

or

Memory[ALUOut] = B;

• R-type instructions finish

Reg[IR[15-11]] = ALUOut;

The write actually takes place at the end of the cycle on the edge

Step 4 (R-type or memory-access)

Page 55: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

55Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Step 4 (R-type or memory-access)

Page 56: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

56Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Step 4 (R-type or memory-access)

Page 57: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

57Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Reg[IR[20-16]]= MDR;

What about all the other instructions?

Write-back step

Page 58: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

58Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Write-back step

Page 59: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

59Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Summary

Step name

Action for R-type

instructions

Action for memory-reference

instructions

Action for

branches

Action for

jumps

Instruction fetch IR = Memory[PC]

PC = PC + 4

Instruction A = Reg [IR[25-21]]

decode/register fetch B = Reg [IR[20-16]]

ALUOut = PC + (sign-extend (IR[15-0]) << 2)

Execution, address ALUOut = A op B ALUOut = A + sign-extend if (A ==B) then PC = PC [31-28] II

computation, branch/ (IR[15-0]) PC = ALUOut (IR[25-0]<<2)

jump completion

Memory access or R-type Reg [IR[15-11]] = Load: MDR = Memory[ALUOut]

completion ALUOut or

Store: Memory [ALUOut] = B

Memory read completion Load: Reg[IR[20-16]] = MDR

Page 60: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

60Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Value of control signals is dependent upon:

– what instruction is being executed

– which step is being performed

• Use the information we’ve accumulated to specify a finite state machine

– specify the finite state machine graphically, or

– use microprogramming

• Implementation can be derived from specification

Implementing the Control

Page 61: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

61Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

General decomposition

Page 62: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

62Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Common part

Page 63: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

63Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Memory access

Page 64: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

64Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

R-type instruction

Page 65: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

65Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Branch instruction

Page 66: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

66Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Jump instruction

Page 67: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

How many state bits will we need?

Graphical Specification of FSM

PCWritePCSource = 10

ALUSrcA = 1ALUSrcB = 00ALUOp = 01PCWriteCond

PCSource = 01

ALUSrcA =1ALUSrcB = 00ALUOp= 10

RegDst = 1RegWrite

MemtoReg = 0

MemWriteIorD = 1

MemReadIorD = 1

ALUSrcA = 1ALUSrcB = 10ALUOp = 00

RegDst = 0RegWrite

MemtoReg = 1

ALUSrcA = 0ALUSrcB = 11ALUOp = 00

MemReadALUSrcA = 0

IorD = 0IRWrite

ALUSrcB = 01ALUOp = 00

PCWritePCSource = 00

Instruction fetchInstruction decode/

register fetch

Jumpcompletion

BranchcompletionExecution

Memory addresscomputation

Memoryaccess

Memoryaccess R-type completion

Write-back step

(Op

='J

')

(Op

='L

W')

4

01

9862

753

Start

Page 68: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

68Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Control signal summary

Page 69: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

69Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Implementation possibilities

Page 70: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

70Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Unità di controllo multi-ciclo realizzata come FSM

PCWrite

PCWriteCond

IorD

MemtoReg

PCSource

ALUOp

ALUSrcB

ALUSrcA

RegWrite

RegDst

NS3

NS2

NS1

NS0

Op5

Op4

Op3

Op2

Op1

Op0

S3

S2

S1

S0

State register

IRWrite

MemRead

MemWrite

Instruction register

opcode field

Outputs

Control logic

Inputs

S3, S2, S1, S0 bit usati per la codifica dello stato presente

NS3, NS2, NS1, NS0 bit usati per la codifica dello stato futuro

La logica di controllo implementa una tabella di verità con le uscite di controllo e lo stato futuro (vedi tabella seguente)

Page 71: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

71Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Equazioni logiche per unità di controllo

I valori dei segnali di controllo dipendono solo dagli stati correnti

PCWrite

PCWriteCond

IorD MemRead

Memwrite

IRWrite

Memtoreg

PCSrc1

PCSrc0

ALUOp1

ALUOp0

ALUSrcB1

ALUSrcB0

ALUSrcA

RegWrite

RegDst

0+9 8 3+5 0+3 5 0 4 9 8 6 8 1+2 0+1 2+6+8

4+7 7

StatoFuturo

0 1 2 3 4 5 6 7 8 9

Statocorrente

4+5+7+8+9 0 1 2 3 2 1 6 1 1

S3 S2 S1 S00 0 0 0

1 0 0 1

Frammento di tabella della verità corrispondente al segnale PCWrite attivo

Page 72: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

72Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Esempio: tabella per bit 0 dello stato futuro (NS0)

Op5 Op4 Op3 Op2 Op1 Op0 S3 S2 S1 S0

x x x x x x 0 0 0 0

1 0 0 0 1 1 0 0 1 0

1 0 1 0 1 1 0 0 1 0

x x x x x x 0 1 1 0

0 0 0 0 1 0 0 0 0 1

NS0=1 negli stati futuri 1, 3, 5, 7, 9 (0001, 0011, 0101, 0111, 1001)

st. fut.1= st. corr. 0 st. fut.3= st. corr. 2 AND lw st. fut.5=st. corr. 2 AND sw

st. fut.7= st. corr. 6 st. fut.9= st. corr. 1 AND jump

NS0 or di tutti questi stati

Page 73: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

73Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• ROM = "Read Only Memory"

– values of memory locations are fixed ahead of time

• A ROM can be used to implement a truth table

– if the address is m-bits, we can address 2m entries in the ROM.

– our outputs are the bits of data that the address points to.

m is the "height", and n is the "width"

ROM Implementation

m n

0 0 0 0 0 1 1

0 0 1 1 1 0 0

0 1 0 1 1 0 0

0 1 1 1 0 0 0

1 0 0 0 0 0 0

1 0 1 0 0 0 1

1 1 0 0 1 1 0

1 1 1 0 1 1 1

Page 74: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

74Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• How many inputs are there?6 bits for opcode, 4 bits for state = 10 address lines(i.e., 210 = 1024 different addresses)

• How many outputs are there?16 datapath-control outputs, 4 state bits = 20 outputs

• ROM is 210 x 20 = 20K bits (and a rather unusual size)

• Rather wasteful, since for lots of the entries, the outputs are the same— i.e., opcode is often ignored

ROM Implementation

Page 75: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

75Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Implementazione tramite ROM1 - uscite controlli

ROM da 20 Kbit = 210x20: 10 ingressi (6 opcode + 4 bit di stato corrente), 20 uscite (16 linee di controllo + 4 bit di stato futuro)

Nel nostro caso 10 ingressi implicano 1024 possibili righe: complesso.

IDEA: separare controllo e stato futuro e ottenere 2 ROM più facilmente gestibili

Il codice operativo non conta sul valore dei controlli. Per questo motivo se usassimo una ROM unica avremmo le stesse combinazioni uscite ripetute 64 volte (duplicazione e spreco).

Uscite/Ingressi 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001

PCWrite 1 0 0 0 0 0 0 0 0 1

PCWrite Cond

0 0 0 0 0 0 0 0 1 0

IorD 0 0 0 1 0 1 0 0 0 0

MemRD 1 0 0 1 0 0 0 0 0 0

MemWR 0 0 0 0 0 1 0 0 0 0

IRWrite 1 0 0 0 0 0 0 0 0 0

Memtoreg 0 0 0 0 1 0 0 0 0 0

PCSrc1 0 0 0 0 0 0 0 0 0 1

PCSrc0 0 0 0 0 0 0 0 0 1 0

AluOp0 0 0 0 0 0 0 1 0 0 0

AluOp1 0 0 0 0 0 0 0 0 1 0

AlusrcB1 0 1 1 0 0 0 0 0 0 0

AlusrcB0 1 1 0 0 0 0 0 0 0 0

AlusrcA 0 0 1 0 0 0 1 0 1 0

RegWr 0 0 0 0 1 0 0 1 0 0

RegDst 0 0 0 0 0 0 0 1 0 0

Page 76: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

76Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Implementazione tramite ROM2 - stato futuro

L’ultima colonna corrisponde a codici operativi non permessi

Con 2 ROM risparmio:

24x16 + 210x4 = 4.3 Kbit

anziché 20 Kbit

No ottimizzazione: codici don’t care ⇒ ancora spreco (< di prima però).

Statocorrente/Opcode

ADD000000

Jump000010

Branch000100

LW SW Altrivalori

0000 0001 0001 0001 0001 0001 0001

0001 0110 1001 1000 0010 0010 ILLEG.

0010 xxxx xxxx xxxx 0011 0101 ILLEG.

0011 0100 0100 0100 0100 0100 ILLEG.

0100 0000 0000 0000 0000 0000 ILLEG.

0101 0000 0000 0000 0000 0000 ILLEG.

0110 0111 0111 0111 0111 0111 ILLEG.

0111 0000 0000 0000 0000 0000 ILLEG.

1000 0000 0000 0000 0000 0000 ILLEG.

1001 0000 0000 0000 0000 0000 ILLEG.

Page 77: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

77Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

PLA

Page 78: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

78Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Implementazione tramite PLA

Meno memoria ma circuito di decodifica indirizzi più complesso.

Ogni uscita è l’or logico (pallino scuro) di più mintermini (colonne verticali).

17 mintermini di cui 10 dipendenti dallo stato corrente ed altri 7 che dipendono da stato corrente e opcode.

Ogni mintermine è l’and dei termini corrispondenti (pallini chiari).

Dimensione = piano AND + piano OR = (10x17)+(20x17)=510 bit.

Si potrebbe suddividerla in 2 minimizzando ulteriormente: 10 ingressi con 7 mintermini e 4 uscite di stato futuro + 4 ingressi e 10 mintermini a generare le uscite di controllo.

Op5

Op4

Op3

Op2

Op1

Op0

S3

S2

S1

S0

IorD

IRWrite

MemRead

MemWrite

PCWrite

PCWriteCond

MemtoReg

PCSource1

ALUOp1

ALUSrcB0

ALUSrcA

RegWrite

RegDst

NS3

NS2

NS1

NS0

ALUSrcB1

ALUOp0

PCSource0

Page 79: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

79Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

• Break up the table into two parts

— 4 state bits tell you the 16 outputs, 24 x 16 bits of ROM

— 10 bits tell you the 4 next state bits, 210 x 4 bits of ROM

— Total: 4.3K bits of ROM

• PLA is much smaller

— can share product terms

— only need entries that produce an active output

— can take into account don't cares

• Size is (#inputs × #product-terms) + (#outputs × #product-terms)

For this example = (10x17)+(20x17) = 460 PLA cells

• PLA cells usually about the size of a ROM cell (slightly bigger)

ROM vs PLA

Page 80: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

80Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Microprogramming

Page 81: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

81Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Micro instructions

Page 82: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

82Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

A simple implementation

Page 83: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

83Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Elements

Page 84: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

84Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Data path

Page 85: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

85Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Micro instruction format

Page 86: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

86Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Microprogram

Page 87: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

87Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Control signals

Page 88: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

88Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Creating the microprogram

Page 89: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

89Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

The start sequence

Page 90: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

90Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Memory access

Page 91: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

91Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Memory access

Page 92: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

92Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

R-format

Page 93: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

93Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Branch & Jump

Page 94: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

94Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Complete microprogram

Page 95: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

95Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Architettura unità di controllo per microistruzioni (1)

+

State

Op

Adder

1

PLA or ROM

Mux

3 2 1 0

Dispatch ROM 1Dispatch ROM 2

0

AddrCtl

Address select logic

Instruction register

opcode field

Page 96: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

96Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Architettura unità di controllo per microistruzioni (2)

State

Op

Adder

1

PLA or ROM

Mux

3 2 1 0

Dispatch ROM 1Dispatch ROM 2

0

AddrCtl

Address select logic

Instruction register opcode field

GESTIONE SALTI

Il salto dispatch verrà gestito da una ROM/PLA esterna indirizzata da linee apposite della logica di controllo. Il salto allo stato 0 codificato esplicitamente.

La selezione tra le diverse possibilità viene fatta dalle linee AddrCtl della logica di controllo.

Page 97: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

97Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Architettura unità di controllo per microistruzioni (3)

Dispatch ROM 1 Dispatch ROM 2

Op Opcode name Value Op Opcode name Value

000000 R-format 0110 100011 lw 0011

000010 jmp 1001 101011 sw 0101

000100 beq 1000

100011 lw 0010

101011 sw 0010

State number Address-control action Value of AddrCtl

0 Use incremented state 3

1 Use dispatch ROM 1 1

2 Use dispatch ROM 2 2

3 Use incremented state 3

4 Replace state number by 0 0

5 Replace state number by 0 0

6 Use incremented state 3

7 Replace state number by 0 0

8 Replace state number by 0 0

9 Replace state number by 0 0

State

Op

Adder

1

PLA or ROM

Mux

3 2 1 0

Dispatch ROM 1Dispatch ROM 2

0

AddrCtl

Address select logic

Instruction register

opcode field

Page 98: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

98Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Untreated situations

Page 99: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

99Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Exception detection

Page 100: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

100Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Exception handling

Page 101: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

101Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

MIPS handling

Page 102: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

102Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

MIPS handling

Page 103: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

103Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Extended architecture

Page 104: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

104Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Extended architecture

Page 105: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

105Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

Exception handling

Page 106: L’unità di elaborazione e di controllo _elaborazione.pdfUniversità degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020 4 •Segnale

106Università degli Studi di Bergamo - corso di Informatica (modulo di Calcolatori Elettronici) – a.a. 2019/2020

State machine with exception