

P150



\* UNIVERSAL REGISTER :- (Universal Shift Register)

↳ It is a register which such a design that multiple operations can be performed.



Ques Design a universal register to perform i) 3-bit operations as below.

Ques Design a universal register to perform i) 3-bit operations as below.

00 - SET  
 01 - LEFT SHIFT  
 10 - CLEAR  
 11 - HOLD

Show serial I/P & O/p lines correctly.  
 // Circular shift, o/p will never go out.  
 I/P will be circular.



## \* CHARACTERISTIC EQUATIONS:-

$$Q^+ = f(\text{Inputs}; Q)$$

↳ eqn: which describes the behaviour of each FF such that they describe next state depending upon current state (Q).

## NEXT STATE TABLE OF SR FF:

| S | R | Q | Q <sup>+</sup> |
|---|---|---|----------------|
| 0 | 0 | 0 | 0 } retains    |
| 0 | 0 | 1 | 1              |
| 0 | 1 | 0 | Q } reset      |
| 0 | 1 | 1 | 0              |
| 1 | 0 | 0 | 1 } set        |
| 1 | 0 | 1 | 1              |
| 1 | 1 | 0 | X } don't care |
| 1 | 1 | 1 | X              |

K-map

|                |   | 00 | 01 | 11 | 10 |
|----------------|---|----|----|----|----|
|                |   | 0  | 1  | 0  | 0  |
| S              |   | 0  | 1  | X  | X  |
| R              | S | 0  | 1  | X  | X  |
| Q <sup>+</sup> |   |    |    |    |    |

$$\{ Q^+ = S + \bar{R}Q \} \rightarrow \text{Characteristic eqn of S-R Flip flop.}$$

### \* J-K Flip flop:

Next state Table

| J | K | Q | Q <sup>+</sup>     |
|---|---|---|--------------------|
| 0 | 0 | 0 | 0 } retain         |
| 0 | 1 | 1 | 1 }                |
| 0 | 1 | 0 | 0 } reset          |
| 0 | 1 | 1 | 0 }                |
| 1 | 0 | 0 | 1 } set            |
| 1 | 0 | 1 | 1 }                |
| 1 | 1 | 0 | 1 } toggle Effect. |
| 1 | 1 | 1 | 0 }                |

K-map

|                |   | 00 | 01 | 11 | 10 |
|----------------|---|----|----|----|----|
|                |   | 0  | 1  | 0  | 0  |
| J              |   | 1  | 1  | 0  | 1  |
| R              | S | 0  | 1  | X  | X  |
| Q <sup>+</sup> |   |    |    |    |    |

$$\therefore Q^+ = \bar{R}Q + S\bar{Q}$$

$$Q^+ = \bar{K}Q + J\bar{Q}$$

### \* D-Flip flop:

Next State Table

| D | Q | Q <sup>+</sup> |
|---|---|----------------|
| 0 | 0 | 0 } reset      |
| 0 | 1 | 0 }            |
| 1 | 0 | 1 } set        |
| 1 | 1 | 1 }            |

D

|                |   | 0 | 1 |
|----------------|---|---|---|
|                |   | 0 | 0 |
| D              |   | 1 | 1 |
| Q              | 0 | 0 | 0 |
| Q <sup>+</sup> |   |   |   |

$$Q^+ = D$$

### \* T-Flip flop:

Next State Table

| T | Q | Q <sup>+</sup> |
|---|---|----------------|
| 0 | 0 | 0 } retains    |
| 0 | 1 | 1 }            |
| 1 | 0 | 1 } toggles    |
| 1 | 1 | 0 }            |

K-map

|                |   | Q | 0 |
|----------------|---|---|---|
|                |   | 0 | 1 |
| T              |   | 0 | 1 |
| Q              | 0 | 0 | 1 |
| Q <sup>+</sup> |   |   |   |

$$Q^+ = \bar{T}Q + T\bar{Q}$$

$$= T \oplus Q$$

\* Encoders :



| $i_0$ | $i_1$ | $i_2$ | $i_3$ | $y_1$ | $y_0$ |  |
|-------|-------|-------|-------|-------|-------|--|
| 1     | 0     | 0     | 0     | 0     | 0     |  |
| 0     | 1     | 0     | 0     | 0     | 1     |  |
| 0     | 0     | 1     | 0     | 1     | 0     |  |
| 0     | 0     | 0     | 1     | 1     | 1     |  |

$$y_1 = i_2 + i_3$$

$$y_0 = i_1 + i_3$$

↙ 1 0 1 0 [1 0] → ? limitation

$$\therefore y_1 = i_2 + i_3 = 1+0=1$$

$$y_0 = i_1 + i_3 = 0+0=0$$

\* Priority Encoder gives ~~the~~ priority to the highest bit.

| $i_0$ | $i_1$ | $i_2$ | $i_3$ | $y_1$ | $y_0$ |
|-------|-------|-------|-------|-------|-------|
| 1     | 0     | 0     | 0     | 0     | 0     |
| X     | 1     | 0     | 0     | 0     | 1     |
| X     | X     | 1     | 0     | 1     | 0     |
| X     | X     | X     | 1     | 1     | 1     |

It will give priority  
any to 1 value

1 0 [1 0] ?

↳ gives priority  
to this highest. bit.

LP ISA-1 (Sample)

⑥ Assumption let shop No. be 1-8.

| $S_3$ | $S_2$ | $S_1$ | $S_0$ | $f_1$ | $f_0$ |
|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | X X   |       |
| 0     | 0     | 0     | 1     | 1     | 0     |
| 0     | 0     | 1     | 0     | 1     | 0     |
| 0     | 0     | 1     | 1     | 0     | 1     |
| 0     | 1     | 0     | 0     | 0     | 1     |
| 0     | 1     | 0     | 1     | 0     | 1     |
| 0     | 1     | 1     | 0     | 0     | 0     |
| 0     | 1     | 1     | 1     | 0     | 0     |
| 1     | 0     | 0     | 0     | 0     | 0     |
| 1     | 0     | 0     | 1     | X X   |       |
| 1     | 0     | 1     | 0     | X X   |       |
| 1     | 0     | 1     | 1     | X X   |       |
| 1     | 1     | 0     | 0     | X X   |       |
| 1     | 1     | 0     | 1     | X X   |       |
| 1     | 1     | 1     | 0     | X X   |       |
| 1     | 1     | 1     | 1     | X X   |       |

If we solve using MUX:



| $S_2$ | $S_1$ | $S_0$ | $f_1$ | $f_0$ |
|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 1     | 0     |
| 0     | 0     | 1     | 1     | 0     |
| 0     | 1     | 0     | 0     | 1     |
| 0     | 1     | 1     | 0     | 1     |
| 1     | 0     | 0     | 0     | 1     |
| 1     | 0     | 1     | 0     | 0     |
| 1     | 1     | 0     | 0     | 0     |
| 1     | 1     | 1     | 1     | 0     |

Using DECODER:



COUNTERS: →

- NO ext. flip or switch.
- It is a self-driven circuit.
- Once the clock pulse is given it will start generating sequence or pattern.

also called as

Sequence Generator

Pattern Generator

|                |       |
|----------------|-------|
| S <sub>0</sub> | 0 0 0 |
| S <sub>1</sub> | 0 0 1 |
| S <sub>2</sub> | 0 1 0 |
| S <sub>3</sub> | 0 1 1 |



Random Counter

### State Diagram



- It is a counter with 4 states.
- It changes its state in every clock pulse.
- 5 stable states.
- Since, the transition is counting up,  
∴ It is mod-5 up counter.

### ① Synchronous Counter:

- Design is feasible. (easier)
- One single master clock that is driving all the flip flops.
- Output is predictable.

### ② Asynchronous Counter:

- Each flip flop has different clock.
- Design is complex.

Mod-N Counter: Counter with N stable states.

## Mod-6 Counter (Up Counter)



It should have 06 stable states.

Ques

### Design a 3-bit Up Counter:

In a 3-bit up counter, there can be 08 different states.

S<sub>0</sub> 0 0 0

S<sub>1</sub> 0 0 1

S<sub>2</sub> 0 1 0

S<sub>3</sub> 0 1 1

S<sub>4</sub> 1 0 0

S<sub>5</sub> 1 0 1

S<sub>6</sub> 1 1 0

S<sub>7</sub> 1 1 1



- for designing, we are designing synchronous counter. ∵ There will be a master clock.
- Let we are designing it with JK FF.
- Counter does not have external flip or switch. It is driven itself in such a way that the present state generates the next state.

For down



PoToO

# Excitation Table :

| Present State     | Next State              | Excitation Q/p. |             |             |
|-------------------|-------------------------|-----------------|-------------|-------------|
| $Q_2 \ Q_1 \ Q_0$ | $Q_2^+ \ Q_1^+ \ Q_0^+$ | $J_2 \ K_2$     | $J_1 \ K_1$ | $J_0 \ K_0$ |
| 0 0 0             | 0 0 1                   | 0 X 0           | 0 X 1       | 1 X         |
| 0 0 1             | 0 1 0                   | 0 0 X           | 1 X         | X 1         |
| 0 1 0             | 0 1 1                   | 0 X X           | 0 1         | 1 X         |
| 0 1 1             | 1 0 0                   | 1 X X           | 1 X         | X 1         |
| 1 0 0             | 1 0 1                   | X X 0           | 0 X 1       | 1 X         |
| 1 0 1             | 1 1 0                   | X X 0           | 1 X         | X 1         |
| 1 1 0             | 1 1 1                   | X X X           | 0 0 1       | 1 X         |
| 1 1 1             | 0 0 0                   | X 1 X           | 1 X         | 1           |

Now, for  $J_i = f(Q_2, Q_1, Q_0)$

$$\Phi \quad K_i = f(Q_2, Q_1, Q_0)$$

| $J_2 \ Q_1 \ Q_0$ |             |
|-------------------|-------------|
| $Q_2$             | 00 01 11 10 |
| 0                 | 0 0   1 0   |
| 1                 | X X   X X   |

$$J_2 = Q_1 Q_0$$

| $J_1 \ Q_1 \ Q_0$ |             |
|-------------------|-------------|
| $Q_2$             | 00 01 11 10 |
| 0                 | 0 1   X X   |
| 1                 | 0 1   X X   |

$$J_1 = Q_0$$

| $J_0 \ Q_1 \ Q_0$ |             |
|-------------------|-------------|
| $Q_2$             | 00 01 11 10 |
| 0                 | X X   X X   |
| 1                 | 1 X   X X   |

$$J_0 = \overline{Q_0} \ 1 \ (V_{cc})$$

| $K_2 \ Q_1 \ Q_0$ |             |
|-------------------|-------------|
| $Q_2$             | 00 01 11 10 |
| 0                 | X X   X X   |
| 1                 | 0 0   1 0   |

$$K_2 = Q_1 Q_0$$

| $K_1 \ Q_1 \ Q_0$ |             |
|-------------------|-------------|
| $Q_2$             | 00 01 11 10 |
| 0                 | X X   1 0   |
| 1                 | X X   1 0   |

$$K_1 = \overline{Q}_0$$

| $K_0 \ Q_1 \ Q_0$ |             |
|-------------------|-------------|
| $Q_2$             | 00 01 11 10 |
| 0                 | X 1   Q 1 X |
| 1                 | K 1   1 X   |

$$K_0 = 1 \ (V_{cc})$$



Ques Draw Excitation table for

We can start from any state. Here we have started from  $S_4$ .



| Present State      |       |       | Next State |         |         | EXCITATION INPUTS |       |       |       |       |       |
|--------------------|-------|-------|------------|---------|---------|-------------------|-------|-------|-------|-------|-------|
| $Q_2$              | $Q_1$ | $Q_0$ | $Q_2^+$    | $Q_1^+$ | $Q_0^+$ | $J_2$             | $K_2$ | $J_1$ | $K_1$ | $J_0$ | $K_0$ |
| 0                  | 0     | 0     | 0          | 1       | 1       | X                 | 1     | 1     | X     | 1     | X     |
| 0                  | 1     | 1     | 0          | 0       | 1       | 0                 | X     | X     | 1     | X     | 0     |
| 0                  | 0     | 1     | 0          | 1       | 0       | 0                 | X     | 1     | X     | X     | 1     |
| 0                  | 1     | 0     | 1          | 1       | 0       | 1                 | X     | X     | 0     | 0     | X     |
| 1                  | 1     | 0     | 1          | 0       | 1       | X                 | 0     | X     | 1     | 1     | X     |
| 1                  | 0     | 1     | 1          | 0       | 0       | X                 | 0     | 0     | X     | X     | 1     |
| undefined<br>state | 1     | 1     | 0          | 1       | 1       | X                 | 1     | X     | 0     | X     | 0     |
|                    | 0     | 0     | 0          | 1       | 0       | 0                 | 1     | X     | 0     | X     | 0     |

If by chance, counter enters into undefined state i.e.  $S_0$  and  $S_7$  in this case; then we can modify the design of the counter in such a way that it becomes self-correcting counter i.e. whenever ~~it reaches~~ it reaches to  $S_0$  &  $S_7$  it will move to next state (any stable state).



## \* Mod-4 Ring Counter :-

- They are other form synchronous counter.
- Its design is similar to shift ~~register~~ register.
- There are 04 states & there is a ring operation (counter).



## \* TWISTED RING COUNTER: (Swatch-Tall or Johnson)



Ques write the state for this: & draw state diagram.



State diagram:-



Rules:

- Transition should not be bidirectional.
  - Each state has only one transition.
- But a transition can have more than one input.

## \* Asynchronous Counter:



- When count enable is 0, the state of T flip flop will be retained.
- When count enable is 1, it will toggle with every clock pulse.



In Asynchronous Counter, the state of the first FF will be the clock pulse for second FF & so on.

Ques Design a. mod 4 Synchronous  
SOLN: Counter using T FF that counts  
Later even numbers.

Count Enable



Soh Synchronous Counter that counts even.

No. (mod-4).



∴ 3 bits are used to represent the highest no. 6.  
∴ 3 flip flops (T-FF) are used

Excitation Table

| Present                                      | Next                                                                                | T <sub>2</sub> | T <sub>1</sub> | T <sub>0</sub> |
|----------------------------------------------|-------------------------------------------------------------------------------------|----------------|----------------|----------------|
| Q <sub>2</sub> Q <sub>1</sub> Q <sub>0</sub> | Q <sub>2</sub> <sup>+</sup> Q <sub>1</sub> <sup>+</sup> Q <sub>0</sub> <sup>+</sup> |                |                |                |
| 0 0 0                                        | 0 1 0                                                                               | 0              | 1              | 0              |
| 0 1 0                                        | 1 0 0                                                                               | 1              | 1              | 0              |
| 1 0 0                                        | 1 1 0                                                                               | 0              | 1              | 0              |
| 1 1 0                                        | 0 0 0                                                                               | 1              | 1              | 0              |
| 0 0 1                                        | x x x                                                                               | x              | x              | x              |
| 0 1 1                                        | x x x                                                                               | x              | x              | x              |
| 1 0 1                                        | x x x                                                                               | x              | x              | x              |
| 1 1 1                                        | x x x                                                                               | x              | x              | x              |

self-correcting

| T <sub>2</sub> Q <sub>2</sub> Q <sub>0</sub> |   | 00 | 01 | 11 | 10 |
|----------------------------------------------|---|----|----|----|----|
| Q <sub>2</sub>                               | 0 | 0  | x  | x  | 1  |
| 1                                            | 0 | x  | x  | 1  | 1  |

$$T_2 = Q_1$$

| T <sub>1</sub> Q <sub>1</sub> Q <sub>0</sub> |   | 00 | 01 | 11 | 10 |
|----------------------------------------------|---|----|----|----|----|
| Q <sub>1</sub>                               | 0 | 1  | x  | x  | 1  |
| 1                                            | 1 | x  | x  | 1  | 1  |

$$T_1 = 1 \text{ (V}_{cc}\text{)}$$

| T <sub>0</sub> Q <sub>0</sub> |   | 00 | 01 | 11 | 10 |
|-------------------------------|---|----|----|----|----|
| Q <sub>0</sub>                | 0 | 0  | x  | x  | 0  |
| 1                             | 0 | x  | x  | 0  | 0  |

$$T_0 = 0 \text{ (Gnd)}$$



09/10/19

Unit 02

## Chapter 03 : Basic Structure Processing Unit

- \*  $C = a + b$ ;  $\rightarrow$  read 'a'  $\rightarrow$  reading from memory  
↓  
2 read operations  
1 memory write operation.  
Select '+' for ALU  
write to 'C'
- \* `scanf ("%d", &a);`  $\rightarrow$  data has to be read from I/O then written to memory

# LOAD R2, LOC

- ~~Reads~~ the contents from memory location whose address is symbolically given by LOC  $\Phi$  loads them into processor register R2.
- Contents of LOC is preserved.
- Content of R2 is overwritten.



- 64 - Bit machine. (WORD LENGTH)
  - It can read 64 bits to a variable A.
  - It can write 64 bits.
  - It can perform 64 ALU operations at a time.
  - It can even read more than 64 bit.

→ Every memory location stores a WORD.

- For 64 Bit machine we have 8 BYTES in one WORD.
- For 32 bit machine, one WORD has 4 BYTES.



- Every memory location has its own unique address.
- Processor-memory Interface has two special registers: MAR & MDR.

MAR : (memory address Register)  
It holds the address of operand.

MDR : (memory data Register)  
It holds the data. (the states of all 64 bits / 32 bits).

{ Data can vary whereas addresses are unique & do not change. }

- \* Load R2, Loc → 0x4000 (Self).
  - It means there is a memory whose address is 0x4000.
  - Its content is 0x56 (let).
  - There is a register R2.
  - The content of 0x4000 is stored to R2.
  - It is a memory read operation.
  - So, the control unit will load the address into MAR. ∴ MAR 0x4000.
  - It will generate control signal READ.
  - After completion of this READ signal, the address' content will be loaded into MDR. ∴ MDR 0x56.
  - This MDR data is written into R2.



#### \* WRITE:

For WRITE operation, Control unit will generate WRITE signal & the contents present in MDR will be written to the memory.

- \* Program Counter (PC): It holds (points) the address of the instruction ~~to~~. that is supposed to be executed next.
- It does not always point to the sequential next instruction. There may be a function call.

\* IR (Instruction Register): It holds the instructions that is being executed.

\* General Purpose Register

- # R<sub>0</sub>, ..., R<sub>n-1</sub> are general purpose registers.  
• They are fastest accessed in the memory processor.

- RISC : Reduced Instruction Set Computer
- CISC : Complex Instruction Set Computer

→ Every instruction is only one word long.  
(" " " will be stored in 1 memory loc.)

\* LOAD R<sub>2</sub>, LOC : (S<sub>10</sub>)

- Instruction fetch
- Decode
- Execute

} Phases

1). Instruction fetch : Instruction from the main memory is loaded on instruction register i.e. IR (via memory-processor interface).

2). Decode : Control signals are generated by control unit to load the address into MAR & content into MDR.

3). Execute : Load internally generates memory Read signal to read from LOC  
Register write signal to store (write) to the content of register R<sub>2</sub>.

## \* Store R4, LOC :

- It will copy the content of R4 to a memory location pointed by LOC.
- The state of R4 will be retained whereas content of LOC will be overwritten.

1). Instruction fetch: Instruction from Instruction register (R4) is copied to main-memory location pointed by LOC via processor memory interface.

2). Execute: The address of R4 will be stored in MAR & its content in MDR. Then control unit will generate write signal to write the content present in MDR to LOC which is present in main-memory.

3). Decode: Control unit generates Read signal to read from R4 & then generate write signal to write it to the memory location pointed by LOC.

## \* ADD R4, R2, R3 :

Execute

$$R4 = R2 + R3.$$

- R2 & R3 will be fetched to ALU.
- Add<sup>n</sup> operation will take place. & data will be stored back to R4.
- No memory & processor interaction.

## \* Memory locations & Addresses:

① Data line : It includes the data which is supposed to be read or write.  
(Bidirectional)  
Processor  $\longleftrightarrow$  Memory.

② Address line : It includes the address:  
~~It holds the no. of memory~~  
location is same as its bits.

From 'n' address line, we can access  $2^n$  memory locations (address from 0 to  $2^n - 1$ ).



③ Control lines : It is responsible for generating control signals (Read (R) | Write (W))  
(Bidirectional)

## BIG ENDIAN :

- lower byte addresses are used for the most significant byte of the word.
- higher order byte stored at lowest address.



|   |   |   |   |
|---|---|---|---|
| 0 | 1 | 2 | 3 |
| 4 | 5 | 6 | 7 |
|   |   |   |   |

## LITTLE ENDIAN:

- It is scheme where the lowest address is used for the least significant byte of the word.

|    |    |    |    |    |
|----|----|----|----|----|
| 16 | 19 | 18 | 17 | 16 |
| 20 | 23 | 22 | 21 | 20 |

### \* MEMORY LOCATIONS AND ADDRESSES:

- Each storage cell in memory can store a bit of information (0 or 1).
- Group of 'm' bits (word) can be stored or retrieved in a single basic operation.
- 'm' is the word length.
- Memory is schematically represented as a collection of words, as shown.
- Each memory location has a distinct name or address.
- Addresses of successive locations in the memory are typically numbered from 0 to  $2^k - 1$ .
- $2^k$  addresses constitute the address space of the computer.



# Word address must be an even number  
SMP that is words must be aligned on an even boundary.

## \* BUS STRUCTURE:



Bus: It is a collection of control line, data line & address line.

- Multiple I/O devices may be connected to the processor & the memory via a bus.
- Bus consists of three sets of lines to carry address, data & control signals.
- Each I/O device is assigned an unique address.
- To access an I/O device, the processor places the address on the address lines.
- The device recognizes the address, & responds to the control signals.

## \* BUS OPERATION:

- A bus requires a set of rules, often called a bus protocol.
- The bus protocol determines when a device may place information on the bus, when it may load the data on the bus into one of its registers, & so on.
- These rules are implemented by control signals to indicate what & when actions are to be taken.

- Every peripheral will have its own unique address. Corresponding to the address & data that is loaded on the bus, only that I/O device will respond.

Master (as of now), here.



### \* Notations :

- ① RTN  
(Register transfer notation)
  - Include symbols:
    - ( ) Index
    - [ ] contents of
  - ← Flow of data
  - E.g.  $R_2 \leftarrow [loc]$
  - destination ← source
- ② ALN  
(Assembly language notation)
  - Include Mnemonics which are 02 or 03 letter words used for instruction.
  - E.g. Load R2, loc  
Mnemonics  
↓ Add, store, etc
  - E.g. Add R2, R3, R4
  - E.g. Add R2, R3, R4  
(ALN)
  - ~~$R_2 \leftarrow [R_3] + [R_4]$  : (RTN)~~
  - Ques Explain the process for executing an instruction.
  - Ans first explain RTN, ALN & then executing part.

## Executing an Instruction:

- 5-M  
Don't  
use  
this  
much.  
Only will  
be given.
- Fetch the contents of the memory location pointed to by the PC. The contents of this location are loaded into IR (Fetch Phase).



- Assuming that the memory is byte addressable, increment the contents of PC by 4. (Fetch phase).

$$PC \leftarrow [PC] + 4.$$

↳ If word length is  
4-bytes

If word-length is 8-bytes, then

$$\underline{PC \leftarrow [PC] + 8.}$$

- Carry out the actions specified by the instruction in the IR (Execution phase).

{ PC is a pointer which always holds }  
address & never stores data {

↳ If the content of PC is loaded into

IR, then it is a data.

↳ Or, it can also be instructions  
to be executed next.



## Processor-memory Interface.

### \* Stages of Operation:

Stage 1 : fetch.

2 : Source Registers. (Reading Register)

3 : ALU.

4 : Memory Access (Read/Write)

5 : Destination Registers.

(write to register)

① Load RS, X(R7)

$x = \text{base address.}$

(i) ~~Get~~ Fetch the instruction  $x + [R7] = \text{effective address.}$   
~~contents from~~  $\Phi$  increment P.C.

(ii) Read the contents of register R7.  
 $\Phi$  decode the instruction.

(iii) Perform ALU operations to get the effective address  $x + [R7]$ .

(iv) Read from the source memory location.

(v) Store the (load) the contents to the destination register, RS.

```

E.g. int var;
      int *pvar;
      pvar = 0x2000;

```

$\rightarrow \&var - 0x1000$

$\rightarrow var - 0x24$

$\rightarrow pvar - 0x2000$

$\rightarrow \&pvar - 0x1010$

$\rightarrow *pvar - 0x40$

#### (Imp)

- $R_2 \leftarrow PC$

↳ in RTN, it

has no meaning.



0x1000

0x1010

0x2000



- $R_2 \leftarrow [PC]$  : Valid

0x1010 will be loaded  
into R2.  $\&$  R2 will  
consider it as data.

- $IR \leftarrow [PC]$  : 0x1010 will be loaded into  
IR  $\&$  IR will interpret  
0x1010 as instruction  $\&$   
accordingly it will be  
decoded.

- $IR \leftarrow [PC] = *PC$  : The instruction stored at  
[PC] i.e. 0x1010 will be  
interpreted by IR.

⑥ Add R3, R4, R5.

(i) Fetch the instruction & increment PC.

(ii) Read the contents of R4, R5 & decode  
the instructions.

(iii) Compute [R4] + [R5]

(iv) NO action

(v) Store load the result into destination  
register R3.

③ Store R6, X[R8].

- (i) Fetch the instruction & also increment the program counter (PC).
- (ii) Decode the instruction & read contents from Register R6 & R8.
- (iii) Compute the effective address i.e.  $X + [R8]$ .
- (iv) Write the contents to  $X + [R8]$  of R6.

(V) No action. {Memory Access}

anything (any operation) related to memory will be written.

Here destination is not a register.  
No action.

• 32 registers in Register file.

↓  
Each register has 32 bits.

Every Instruction is of word long (32-bit).

\* RISC: → It directly does not support memory access.

→ For a RISC processor, every instruction is of fixed length.

→ The operations of RISC processor include:

- Load/Store instructions to access the operands.

- ALU operations.

→ Assumptions :

- There are 32 Registers each of 32 bit length.

- The word length is 32 bits.

→ The execution of instruction is done in 05 stages.

## # Stages :

- 1). Fetch an instruction & increment the program counter.

- 2). { Fetching the instruction from memory } & incrementing the PC to point to the next instruction to be executed in the memory.

Load R3, N

- Every instruction has 02 parts :

Opcode : Load

Operands : R3 & N.

- Instruction Register (IR) is 32 bit long.



- 2). Decode the instruction & read registers from the register file.

Decoding the instruction refers to generating appropriate control signals by CU to perform the instructions in Instruction Register (IR).

First part (some part) of IR is opcode

& some part of IR is operand.

3). Perform an ALU operation.

E.g. Load R5, X(R7).

ALU op: address Computation  
i.e.  $X + [R7]$

E.g. 2 Store R2, X(R)  
ALU:  
 $X + [R3]$

E.g. 3 Add R2, R3, R4

ALU operation =  $[R3] + [R4]$ .

4). Read or write memory data if the instruction involves a memory operand.

|                                  |                 |                               |
|----------------------------------|-----------------|-------------------------------|
| Load R3, X(R7)                   | Store R2, X(R3) | Add R2, R3, R4                |
| Memory $\rightarrow$ memory read | memory write    | No memory operation involved. |

5). Write the result into destination register, if needed.

|                                                |                                                                                                                         |                     |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------|
| Load R3, X(R7)                                 | Store R2, X(R3)                                                                                                         | Add R2, R3, R4      |
| Destination $\rightarrow$ Register write to R3 | NO destination register involved.<br>$\because R2$ is source register & destination is a memory location not a register | Write result to R2. |

One write all 05 stages for instruction

Clear R3

R3   $\rightarrow$  ps[0 0 0 0 0]  $\rightarrow$  ps[0 0 0 0 0]  
write operation to P3 so that every FF is reset.

- 1). Fetch the instruction into IR.  $\Phi$  increment PC.
- 2). Decode the instruction. ( $\Phi$  read content of R3) (no need to read R3)
- 3). Perform ALU operation ~~involved~~ to clear.
- 4). No memory operation (No action)
- 5). ~~No dest. reg. involved.~~ (Write 0 to R3).

ALU operations Clear R<sub>3</sub>

or  $\rightarrow R_3 \& R_3' = 0$  } so that all values (each  
or  $\rightarrow R_3 \& 0 = 0$  } FF) of R<sub>3</sub> is reset &  
or  $\rightarrow R_3 = 0$  becomes 0.

If we are writing R<sub>3</sub> to 0,  
then no need to read R<sub>3</sub> in step 2.

## \* HARDWARE COMPONENTS:

- 1). Register File
- 2). ALU
- 3). Datapath
- 4). Instruction Fetch Section

can read 02 registers at a time but  
can write only 01 register at a time.

### Register File :

- Register file allows to read two registers from the file at one instant & the content of registers are available at both A & B.

If the address of the registers to be read (source registers) are provided to the register file interface circuitry (RFC) through lines address A & address B.

- The register file allows to write to a single register at a time and the content to be written to the register (destination register) is made on code 'C' and the address of destination register should be provided at add. line numbered as address C here.

(Fig. behind)



ALU:

**IMP**

In RISC operation, both operands must be register. RISC does not allow direct memory access. The contents of memory need to be stored in register file first & then ALU operation is performed.

must write for ALU operation while CISC allows memory access as operands.



- MUXB is used to select between register operands & Immediate Value.

## Datapath :

- In datapath, there is a need of temporary register so that the value can be stored and used at next stage.
- 'Memory address line' is connected to processor memory interface in MAR.
- 'Memory data line' is connected to MDR. in stage 04, in processor memory interface.  
↳ of datapath diagram.
- From Register to ALU, R2 stores the effective address<sup>of data</sup> and sends to MAR.

- In Stage 4, Return Address comes from program counter which stores the address of instruction to be executed next.

## Instruction Fetch Section :

- It's objective is to fetch the instruction from the memory location to the instruction register in stage 01.



Once the address of instruction is known, it is stored in MAR. Now, the instruction falls into from that address falls into MDR.

Now, from MDR it comes to IR.

∴ we only need to know the add. of inst. which we can get from instruction Address Generator.

- Once the instruction is loaded into IR, it is decoded by control procedely. Appropriate control signals are generated.
- The immediate values are extracted from IR and given to MUXB through the immediate block.



### # Updation of PC {How PC is modified}

1). Sequential Execution: current value will be incremented by 4.

$$PC \leftarrow PC + 4$$

2). Branching Instructions: current value will be incremented by offset.

$$PC \leftarrow PC + \text{offset}$$

Jump offset is difference bet<sup>n°</sup> current value & target value of PC.

- 3). Subroutine (Function) Calls: PC will be updated with a new address.
- This new address is coming from the instruction, after the instruction is decoded in IR. Here the immediate value is extracted.

- 4). Subroutine Return: New address will be stored in PC. This new add. is ~~is~~ return address coming from Register file.

\* PC-temp is a temporary register where the processor stores the ~~return address~~ content of PC before updating the PC in case of func<sup>n</sup> call type of instructions.

- This the address stored in PC-temp is backed up as return address in link register of Register file via MUX Y (lpp<sup>2</sup>) and register RY.

Read section 2.7 Pg 56, 57, 58, 6<sup>th</sup> Edition for Subroutine Call Instruction. Also Pg 61

Ques Write sequence of actions (5 stages) to fetch & execute an instruction with reference to RISC datapath.

- ADD R3, R4, R5.
- Fetch the instruction & read the content of source registers R4 & R5. increment the PC.
  - Decide the instruction & read the content of source registers R4 & R5.
  - Store these content into temporary registers.
  - ALU  $\xrightarrow{ } [R4] + [R5]$
  - Write to R3.

- 1). Fetch the instruction & increment PC.
- ~~Memory~~ Address Line  $\leftarrow [PC]$   $\rightarrow$  Address of the instruction.
- Read Memory : reads the memory location whose address is in memory address line.
  - $FIR \leftarrow$  Memory data ,  $PC \leftarrow [PC] + 4$ , such that it starts pointing to the next inst.

## 2). DECODE

- Decode the instruction

- Address A should be  $R_4$  & B should be after decoding.

$RA \leftarrow [R_4]$  .  $RB \leftarrow [R_5]$  {Read register}

## 3). ALU : ALU result is stored in $R_2$ .

$R_2 \leftarrow [RA] + [RB]$

## 4). Memory Access : Since, there is no memory operation, memory read or memory write signal will not be generated. $\therefore R_y$ will be loaded with the content of $R_2$ .

$R_y \leftarrow [R_2]$

## 5). Destination Register ; here to destination register. $R_3 \leftarrow [R_y]$ .

|      |                                |
|------|--------------------------------|
| :RTN | $R_3 \leftarrow [R_4] + [R_5]$ |
| ALN  | Add $R_3, R_4, R_5$            |

# \* Load R5, X(R7);

1). Memory Add. line  $\leftarrow [PC]$

- Read Memory
- IR  $\leftarrow$  Memory data line.
- PC  $\leftarrow [PC] + 4$ .

2). • Decode

- RA  $\leftarrow [R7]$

3). • calculate effective Address:

$Rz \leftarrow [RA] + \text{Immedate Value}$   
 // Rz is add. of memo. we want to read.

4).  $Ry \leftarrow [X + (Rz)]$ . Memory Read.

$= Ry \leftarrow [Rz]$       Memory Add.  $\leftarrow [Rz]$ ,  
 memory read,  
 $Ry \leftarrow$  Memory data

5).  $R5 \leftarrow Ry$



# \* STORE R2, X(R3);

1). Memory Add. line  $\leftarrow [PC]$

- Read Memory
- IR  $\leftarrow$  Memory data line
- PC  $\leftarrow [PC] + 4$ .

2). • Decode

- RA  $\leftarrow [R2]$

3).  $R2 \leftarrow [R3] + \text{Immedate Value.}$

4). Memory Add.  $\leftarrow [Rz]$

- Memory write
- Ry  $\leftarrow$  Memory data
- $Ry \rightarrow$  Memory data



mem.read  
 \* Load dest, source  
 mem.write  
 \* Store dest, source  
 source dest.



P.T.O.



- 1). - same
- 2). Decode
  - $R_B \leftarrow [R_2]$
  - $R_A \leftarrow [R_3]$  // To compute effective memory address
- 3).   
  - $R_M \leftarrow [R_B]$  // RM is used for memory write
  - $R_z \leftarrow [R_A] + X$   
address where we want to write
  - content we need to write
- 4).   
 • Memory Address line  $\leftarrow [R_z]$   
 $\text{MAR} \leftarrow [R_z]$ 
  - Memory Data line  $\leftarrow [R_M]$   
 $\text{MDR} \leftarrow [R_M]$
  - Memory Write signal
- 5). NO action.

// If instruction involves memory,  
ALU will calculate Effective memory Add

// If instruction involves +, -, \*, / ...  
ALU will do the desired operation.

// Else, ALU will perform nothing.  
( Control signals will be generated  
in such a way that ALU is  
disabled).