

# UNIT - 5

1. Define Pipeline. Explain 3 stage pipeline execution mechanism in a RISC processor.

→ Pipeline: A pipeline is the mechanism a RISC processor uses to execute instrn. Using a pipeline speeds up the execution by fetching the next instruction while other instructions are being decoded & executed.

## Three stage pipeline:

- Fetch loads an instruction from memory.
- Decode identifies an instruction to be executed.
- Execute processes the instruction and writes the result back to a register.



## Three stage pipeline

Ex:

|             | Fetch | Decode | Execute |
|-------------|-------|--------|---------|
| Time cycles | ADD   | ADD    |         |
| Cycle 2     | SUB   | ADD    |         |
| Cycle 3     | CMP   | SUB    | ADD     |

Pipeline instruction sequence

Q) 2) Discuss with diagram for a simplified data flow of a 5 stage RISC pipeline.



## Q) RISC design philosophy and design rules.

→ RISC is design philosophy aimed at delivering simple but powerful instructions that execute within a single cycle at a high clock speed. The RISC philosophy concentrates on reducing complexities of instructions performed by the hardware bcz it's easier to provide greater flexibilities & intelligence in software.

⇒ The RISC philosophy is implemented with 4 major design rules:

1.) Instructions: RISC processors have a reduced number of instruction classes. These classes provide simple operation that can each execute in a single cycle. The compiler or programmer synthesizes complicated operations by combining several simple instructions.

2.) Pipeline: The processing of instruction is broken down into smaller units that can be executed in parallel by pipelines.

3.) Registers: RISC machines have a large general purpose register set. Any register

Can contain either data or address.

Registers act as <sup>the fast</sup> ~~memory~~ local memory store for all data processing operations.

- 4) Load-store architecture: The processor operates on data held in registers. Separate load & store instructions transfer data b/w register bank & external memory.

Q.) Draw and discuss an ARM based embedded device, as a microcontroller.



An ARM based embedded device, as a microcontroller

→ We can separate the device into 4 main components:

i) The ARM processor controls the embedded device. Different versions of the RAM processor are available to suit the desired operating characteristics.

ii) Controllers coordinate important functional blocks of the system. Two important commonly found controllers are interrupt & memory controllers.

Ques. 6

- The peripherals provide all the input output capability external to the chip & are responsible for the uniqueness of the embedded device.
- A Bus. is used to communicate b/w different parts of the device.

Q.) Discuss ARM core data flow model.



## ARM core data flow

# The instruction decoder translates instructions before they are executed.

# The ARM processor, like all RISC processors uses a load-store architecture. Load instruction copies ~~instructions~~ data from memory to registers in core, & conversely.

the store instruction copy data from register to memory.

- Data items are ~~stored~~<sup>placed</sup> in register file - a storage bank made up of 32-bit registers.
- ARM instructions typically have two source registers, Rn & Rm and a single destination register, ~~Rn~~ Rd
- The ALU or MAC takes the register value Rm & Rn from the A & B buses & compute a result. Data processing instructions write the result in Rd directly to the register file. Load & store instr\* use the ALU to generate an address to be held in address register & broadcast on the Address Bus.
- Rm alternatively can be preprocessed in the barrel shifter <sup>before</sup> it enters the ALU.

Q.) Discuss with a neat diagram for ARM's register organization.

|   |                    |
|---|--------------------|
| → | r <sub>0</sub>     |
|   | r <sub>1</sub>     |
|   | r <sub>2</sub>     |
|   | r <sub>3</sub>     |
|   | r <sub>4</sub>     |
|   | r <sub>5</sub>     |
|   | r <sub>6</sub>     |
|   | r <sub>7</sub>     |
|   | r <sub>8</sub>     |
|   | r <sub>9</sub>     |
|   | r <sub>10</sub>    |
|   | r <sub>11</sub>    |
|   | r <sub>12</sub>    |
|   | r <sub>13</sub> sp |
|   | r <sub>14</sub> pc |
|   | r <sub>15</sub> pc |

|      |
|------|
| cpsr |
| -    |

→ Registers available in user mode

A protected mode normally used when executing applications.

There are upto 18 active registers :  
16 data register & 2 processor status

(Cortex)

registers. The data registers are visible to programmers (as  $r_0$  to  $r_{15}$ ).

- $r_{13}, r_{14}, r_{15}$  are assigned to a particular task.
- $r_{13}$  is traditionally used as the stack pointer (sp) to store the head of the stack in current processor mode.
- $r_{14}$  is called the link register (lr) and is where the core puts the return address whenever it calls a subroutine.
- $r_{13}$  &  $r_{14}$  can also be used as general purpose register. But it's dangerous to use  $r_{13}$  as a general register when the processor is running any form of operating system bcz OS often assumes that  $r_{13}$  is always points to a valid stack frame.
- In addition to these, there are 2 program status register: CPSR & SPSR.

## Q) Conditional flags of ARM processor.

| → Flag | Flag name  | set when                        |
|--------|------------|---------------------------------|
| S      | Saturation | result causes overflow          |
| V      | overflow   | the result causes sign overflow |
| C      | carry      | result causes unsigned carry    |
| Z      | zero       | result is zero                  |
| N      | negative   | bit 31 of result is 1           |

## Q) Addressing modes for load-store.

→ There are different modes for addressing memory. These modes incorporate one of the indexing methods: preindex, preindex with writeback, postindex.

Addressing modes & index method

Preindex with immediate offset

Preindex with register offset

Preindex with scaled register offset

Preindex writeback with imm. offset

Preindex writeback with register offset

Preindex writeback with scaled register offset

~~Post~~ Immediate postindex

Register postindex

Scaled register postindex

Addressing mode for single-register load store

## Addressing mode for multiple load store instructions

| <u>Addressing mode</u> | <u>Description</u> |
|------------------------|--------------------|
| IA                     | increment after    |
| IB                     | increment before   |
| DA                     | decrement after    |
| DB                     | decrement before   |