

Notes

## Central Processing Unit (CPU)

### Introduction:

CPU: The part of the computer that performs the bulk of data-processing operations is called the CPU. The CPU is made up of three major parts as shown in fig:



\* The Register set stores intermediate data used during the execution of the instructions. The ALU performs the required micro-operations for executing the instructions. The control unit supervises the transfer of information among the registers and instructs the ALU as to which operation to perform.

### General Register Organization:

A bus organization for seven CPU registers as shown in fig. The output of each register is connected to two multiplexers to form the two buses A and B. The selection lines in each multiplexers select one register or the input data for particular bus.

MAY 2012



|       |       |       |     |
|-------|-------|-------|-----|
| 3     | 3     | 3     | 5   |
| SEL A | SEL B | SEL D | OPR |

control word

The A and B buses form the inputs to a ALU. The operation selected by the ALU

MAY || 2012

May 03 Thursday determines the arithmetic or logic micro-operation that is to be performed. The result of the operation is available for output data and also goes to the inputs of all the registers. The register that receives the information from output bus is selected by a decoder.

E.g:-

$$R1 \leftarrow R2 + R3$$

1. MUX A selector (SEL A): to place the content of  $R_2$  into bus A.
2. MUX B selector (SEL B): to place the content of  $R_3$  into bus B.
3. ALU operation selector (OPR): to provide the arithmetic addition  $A + B$ .
4. Decoder destination selector (SEL D): to transfer the content of the output bus into  $R_1$ .

### Control Word:

There are 14 bit binary input in the unit and these combined value specifies a control word. It consists of four fields. Three fields contains three bits each and one field has five bits.

\* Three bits of SEL A select a source register for A input of the ALU

May 05 Saturday & The Three bits of SELB select a register for B input of the ALU. The three <sup>bits of</sup> SELD select a destination register using decoder. PEA.

& The five bits of OPR select one of the operations in the ALU. The 14-bit control word when applied to the selection inputs specify a particular microoperation.

| Binary code       | SELA  | SELB  | SELD |
|-------------------|-------|-------|------|
| 000               | Input | Input | Now  |
| 001               | R1    | R1    | R1   |
| 010               | R2    | R2    | R2   |
| 011               | R3    | R3    | R3   |
| May 06 Sunday 190 | R4    | R4    | R4   |
| 101               | R5    | R5    | R5   |
| 110               | R6    | R6    | R6   |
| 111               | R7    | R7    | R7   |

- \* When SELA or SELB is 000, the corresponding multiplexers select the external inputs data.
- \* When SELD = 000, no destination register is selected.

### ALU operations:

| OPR   | operation    | Symbol |
|-------|--------------|--------|
| 00000 | TFA          | TSFA   |
| 00001 | Increment A  | JCA    |
| 00010 | Add A+B      | ADD    |
| 00101 | Subtract A-B | SUB    |

MAY 2012

May 07 Monday

0011 0

Decrement

DECA

0100 0

AND A, B

AND

0101 0

OR A, B

OR

0110 0

XOR A, B

XOR

0111 0

complement

COMA

1000 0

shift right A

SHRA

1100 0

shift left A

SHLA

Example :

R1  $\leftarrow$  R2 - R3

Field:

SEL A

SEL B

SEL D

OPR

Symbol:

R2

R3

R1

SUB

May 08 Tuesday Control Word: 010

011

001

00101

1) R1  $\leftarrow$  R2 - R3

2) R4  $\leftarrow$  R4 VR5

3) R6  $\leftarrow$  R6 + 1

4) R7  $\leftarrow$  R1

5) R4  $\leftarrow$  Shl R4

|     |     |     |       |
|-----|-----|-----|-------|
| 110 | 000 | 110 | 00001 |
| 001 | 000 | 111 | 00000 |
| 100 | 000 | 100 | 11000 |

May 09 Wednesday Stack Organization: A useful feature that is included in the CPU is a stack or last-in, first out (LIFO). A stack is a storage device that stores information in such a manner that the item stored last is the first item retrieved.

The register that holds the address for the stack is called stack pointer (SP) because its value always points at the top item in the stack.

The two operations of a stack are the insertion and deletion of items. The operation of insertion is called push. The operation of deletion is called pop.

### Register Stack

A stack can be placed in a portion of a memory or it can be organized as a collection of no. of registers. The SP contains a binary number whose value is equal to the address of the word that is currently on the top of the stack. Three items are placed in the stack: A, B, and C. Item C is on top of the stack so that the content of SP is now 3. To remove the top item, the stack is popped by reading the word at address 3 and decrementing the content of SP.

(2)

MAY 2012

May 11 Friday



In a 64-word stack, the SP contains 6 bits because  $2^6 = 64$ . Since SP has only 6 bits, it cannot exceed a no. greater than 63. When 63 is incremented by 1, the result is 0 since  $111111 + 1 = 1000000$  in binary, but SP can consider only six least significant bits. The 1 bit register FULL is set to 1 when the stack is full, and the one-bit register EMTY is set to 1 when the stack is ~~empty~~ empty. DR is a data register that holds the data to be written into or read out of the stack.

Initially, SP is cleared to 0, EMTY is set to 1, and FULL is set to 0, so that SP points to the word at address 0 and stack is marked empty. If the stack is not full, a new item can be inserted with a push operation. The push operation is implemented as follows:

May 14 Monday

 $SP \leftarrow SP + 1$ 

Increment SP

 $M[SP] \leftarrow DR$ 

Write item on top of the stack.

If ( $SP = 0$ ) then ( $FULL \leftarrow 1$ ) Check if stack is full.~~EMTY~~  $EMTY \leftarrow 0$ 

Mark the stack not empty.

The first item stored in stack at address 1. The last item is stored at address 0. If SP reaches 0, the stack is full of items, so FULL = 1.

A new item is deleted from the stack if the stack is not empty.

May 15 Tuesday

 $DR \leftarrow M[SP]$ 

Read item from the top of stack.

 $SP \leftarrow SP - 1$ 

Decrement SP

If ( $SP = 0$ ) then ( $EMTY \leftarrow 1$ ) check if stack is empty. $FULL \leftarrow 0$ 

Memory Stack & Memory stack can be implemented in a RAM attached to CPU. The fig. shows a portion of memory partitioned into three segments i.e program, data and stack.

→ PC for address of next inst.

→ AR for data

→ SP for top of the stack.

MAY 2012

(5)

May 16 Wednesday

| PC | Memory                     | Address |
|----|----------------------------|---------|
| AR | Programs<br>(Instructions) | 1000    |
| SP | DATA<br>(Operands)         | 2000    |
|    |                            | 3000    |
|    |                            | 3997    |
|    |                            | 3998    |
|    |                            | 3999    |
|    |                            | 4000    |
|    |                            | 4001    |

May 17 Thursday



DR

A new item is inserted with push operation:

$$SP \leftarrow SP - 1$$

$$M[SP] \leftarrow DR$$

A new item is deleted with a pop operation:

$$DR \leftarrow M[SP]$$

$$SP \leftarrow SP + 1$$

## Stack overflow or underflow:

May 18 Friday The stack ~~overflow~~ limits can be checked by using two processor registers: one to hold the upper limit (3000) and other to hold the lower limit (4001). After a push operation, SP is compared with the upper limit register and after a pop operation, SP is compared with the lower limit register.

## Instruction format (Address field format)

① Three-Address Instruction

② Two Address Inst.

③ One-Address Inst.

May 19 Saturday ④ zero Address Inst.

$$X = (A + B) * (C + D)$$

① Three-Address Instruction:

Computer with three-address instruction formats can use each address field to specify either a processor register or a memory operand.

e.g.

May 20 Sunday ADD R1, A, B  $R1 \leftarrow M[A] + M[B]$

ADD R2, C, D  $R2 \leftarrow M[C] + M[D]$

MUL X, R1, R2  $M[X] \leftarrow R1 * R2$

**MAY** || **2012**

May 21 Monday ~~\* Advantage of three 3-Address format is that it results in ~~it results in~~ short programs when evaluating arithmetic expression.~~  
The disadvantage is that the binary coded inst. requires too many bits to specify the three address.

### Two-Address Inst's

~~(Format - 16 bit)~~ Each address field can specify either a. processor register or a memory word.

MOV R1, A       $R1 \leftarrow M[A]$   
ADD R1, B       $R1 \leftarrow R1 + M[B]$

May 22 Tuesday MOV R2, C       $R2 \leftarrow M[C]$   
ADD R2, D       $R2 \leftarrow R2 + M[D]$   
MUL R1, R2       $R1 \leftarrow R1 * R2$   
MOV X, R1       $M[X] \leftarrow R1$

### One Address Inst's

One address instructions use an implied accumulator (AC) register for all data manipulation.

LOAD A       $AC \leftarrow M[A]$   
ADD B       $AC \leftarrow AC + M[B]$   
STORE T       $M[T] \leftarrow AC$   
LOAD C       $AC \leftarrow M[C]$   
ADD D       $AC \leftarrow AC + M[D]$   
MUL T       $AC \leftarrow AC * M[T]$   
STORE X       $M[X] \leftarrow AC$

May 23 Wednesday All operations are done b/w AC register and memory operand. - T is the address of temporary memory location required for storing the intermediate result.

### 2nd - Address Inst's

A stack-organized computer does not use an address field for the instruction ADD and MUL.

|        |                                |
|--------|--------------------------------|
| PUSH A | TOS $\leftarrow$ A             |
| PUSH B | TOS $\leftarrow$ B             |
| ADD    | TOS $\leftarrow$ (A+B)         |
| PUSH C | Tos $\leftarrow$ C             |
| PUSH D | Tos $\leftarrow$ D             |
| ADD    | Tos $\leftarrow$ (C+D)         |
| MUL    | Tos $\leftarrow$ (C+D) * (A+B) |
| POP X  | M[X] $\leftarrow$ Tos.         |

May 24 Thursday

To evaluate arithmetic expressions in a stack computer, it is necessary to convert the expression into Reverse Polish Notation.

MAY 2012

May 25 Friday

## Subroutine Call and Return:

A subroutine is a self-contained sequence of instructions that performs a given task. During the execution of a program, a subroutine may be called to perform its function many times in the main program. Each time a subroutine is called, a branch is executed to the beginning of the subroutine to start executing its set of instructions. After the subroutine has been executed, a branch is made back to the main program.

The instruction that transfers program control to a subroutine is known by different names like call subroutine, jump to subroutine, branch to subroutine or branch and save address. A call subroutine instruction consists of an operation code together with an address that specifies the beginning of the subroutine. The last instruction of every subroutine is called return from the subroutine, transfers the return address from the temporary location into the program counter.

A subroutine call is implemented with the following microoperation:

SP  $\leftarrow$  SP - 1

Decrement the stack pointer

$M[SP] \leftarrow PC$

Push content of PC onto the stack

May 28 Monday

$PC \leftarrow$  effective address T/F control to the subroutine.

The instruction that returns from the last subroutine is implemented by the micro operation:

$$PC \leftarrow M[SP]$$

$$SP \leftarrow SP + 1$$

Pop stack and T/F to PC

Increment stack pointer.

### Program Interrupt :-

Program interrupt refers to the transfer of program control from a currently running program to another service program as a result of external or internal generated May 29 Tuesday request. The control returns to the original program after the service program is executed.

The interrupt procedure is quite similar to a subroutine call except for three points:

- ① The interrupt is usually initiated by an internal or external signal rather than from the execution of an instruction (except for S/W interrupt).
- ② The address of the interrupt service program is determined by hardware rather than from the address field of an instruction.
- ③ An interrupt procedure stores all the

MAY 2012

May 30 Wednesday Information necessary to define the state of the CPU rather than storing only the program counter.

PSW: The collection of all status bit conditions in the CPU is sometimes called a program status word or PSW.

### Types of Interrupts:

- ① External interrupts
- ② Internal //
- ③ Software //

May 31 Thursday

- ① External interrupts come from I/O devices.  
C: 9:- I/O device requesting T/F of data,  
I/O device finished T/F of data, power failure.
- ② Internal interrupts occur from illegal or wrong instruction. Internal interrupts are also called traps.

Examples:- register overflow, attempt to divide by zero, an invalid operation code

Note Stack overflow etc.

### (3) Software Interrupts:-

A software interrupt is initiated by executing an instruction. S/w interrupt is a special call instruction that behaves like an interrupt rather than a subroutine call.