Chap. 8 Central Processing Unit - Philadelphia University

Chap. 8 Central Processing Unit

8-1

8-1 Introduction

3 major parts of CPU : Fig. 8-1

z 1) Register Set

z 2) ALU

z 3) Control

Design Examples of simple CPU

z Hardwired Control : Chap. 5

z Microprogrammed Control : Chap. 7

In this chapter : Chap. 8

Computer Architecture as seen by the programmer

z Describe the organization and architecture of the CPU with an emphasis on the user's view of the computer

z User who programs the computer in machine/assembly language must be aware of

? 1) Instruction Formats ? 2) Addressing Modes

Chap. 8

? 3) Register Sets

z The last section presents the concept of Reduced Instruction Set Computer (RISC)

Computer System Architecture

Chap. 8 Central Processing Unit

? Korea Univ. of Tech. & Edu. Dept. of Info. & Comm.

8-2

8-2 General Register Organization

Register

z Memory locations are needed for storing pointers, counters, return address, temporary results, and partial products during multiplication (in the programming examples of Chap. 6)

z Memory access is the most time-consuming operation in a computer

z More convenient and efficient way is to store intermediate values in processor registers

Bus organization for 7 CPU registers : Fig. 8-2

z 2 MUX : select one of 7 register or external data input by SELA and SELB

z BUS A and BUS B : form the inputs to a common ALU

z ALU : OPR determine the arithmetic or logic microoperation

? The result of the microoperation is available for external data output and also goes into the inputs of all the registers

z 3 X 8 Decoder : select the register (by SELD) that receives the information from ALU

Clock

R1 R2 R3 R4 R5 R6 R7

Load (7 lines)

SELA

External Input

Input

MUX

MUX

SELB

3?8 decoder

A bus

B bus

SELD OPR

Arithmetic logic unit (ALU)

3

SELA

Output

(a) Block diagram

3

3

SELB SELD

(b) Control word

External Output

5

OPR

Computer System Architecture

Chap. 8 Central Processing Unit

? Korea Univ. of Tech. & Edu. Dept. of Info. & Comm.

8-3

Binary selector input : R1 R2 + R3

z 1) MUX A selector (SELA) : to place the content of R2 into BUS A

z 2) MUX B selector (SELB) : to place the content of R3 into BUS B

z 3) ALU operation selector (OPR) : to provide the arithmetic addition R2 + R3

z 4) Decoder selector (SELD) : to transfer the content of the output bus into R1

Control Word

z 14 bit control word (4 fields) : Fig. 8-2(b)

? SELA (3 bits) : select a source register for the A input of the ALU ? SELB (3 bits) : select a source register for the B input of the ALU

Tab. 8-1

? SELD (3 bits) : select a destination register using the 3 X 8 decoder

? OPR (5 bits) : select one of the operations in the ALU

Tab. 8-2

z Encoding of Register Selection Fields : Tab. 8-1

? SELA or SELB = 000 (Input) : MUX selects the external input data

? SELD = 000 (None) : no destination register is selected but the contents of the output

bus are available in the external output

z Encoding of ALU Operation (OPR) : Tab. 8-2

Control Word Control Memory Microprogrammed

Examples of Microoperations : Tab. 8-3

Control

z TSFA (Transfer A) : R7 R1, External Output R2, External Output External Input

z XOR : R5 0 ( XOR R5 R5)

Computer System Architecture

Chap. 8 Central Processing Unit

? Korea Univ. of Tech. & Edu. Dept. of Info. & Comm.

8-4

8-3 Stack Organization

Stack or LIFO(Last-In, First-Out)

z A storage device that stores information

? The item stored last is the first item retrieved = a stack of tray

z Stack Pointer (SP)

? The register that holds the address for the stack

? SP always points at the top item in the stack

z Two Operations of a stack : Insertion and Deletion of Items

? PUSH : Push-Down = Insertion

? POP : Pop-Up = Deletion

z Stack

? 1) Register Stack (Stack Depth )

a finite number of memory words or register(stand alone)

? 2) Memory Stack (Stack Depth )

a portion of a large memory

Register Stack : Fig. 8-3

FULL EMTY SP

z PUSH : SP SP + 1

: Increment SP

* SP = 0, EMTY = 1,

M [SP ] DR

: Write to the stack

If (SP = 0) then ( FULL 1) : Check if stack is full

FULL = 0

EMTY 0

: Mark not empty

Last Item

Computer System Architecture

Chap. 8 Central Processing Unit

Address 64

4

C

3

B

2

A

1

0

DR

? Korea Univ. of Tech. & Edu. Dept. of Info. & Comm.

8-5

? The first item is stored at address 1, and the last item is stored at address 0

z POP : DR M [SP ]

: Read item from the top of stack

SP SP - 1

: Decrement Stack Pointer

If (SP = 0) then ( EMTY 1) : Check if stack is empty

* Memory Stack PUSH = Address

* Register Stack PUSH = Address

FULL 0

: Mark not full

Memory Stack : Fig. 8-4

PC

z PUSH : SP SP - 1

*

M [SP ] DR

SP = 4001 ? The first item is stored at address 4000

AR

z POP : DR M [SP ]

Memory unit

Program (instructions)

Address 1000

Data (operands)

2000

SP SP + 1

Stack Limits

* Error Condition PUSH when FULL = 1 POP when EMTY = 1

Stack

3000

z Check for stack overflow(full)/underflow(empty)

? Checked by using two register

Upper Limit and Lower Limit Register

? After PUSH Operation

SP compared with the upper limit register

? After POP Operation

SP compared with the lower limit register

SP

Start Here

3997 3998 3999 4000 4001

DR

Computer System Architecture

Chap. 8 Central Processing Unit

? Korea Univ. of Tech. & Edu. Dept. of Info. & Comm.

................
................

In order to avoid copyright disputes, this page is only a partial summary.

Google Online Preview   Download