

## Architecture

~~Q2~~ draw and explain 8086 microprocessor

Ans:



the 8086 divided into two section - namely

- The bus interfacing unit (BIU)
- The executing unit (EU)

- BIU is mainly responsible for external access i.e. read or writing from memory or I/O devices.
- Hence it is called the external world interface of the processor.

- Execution unit (EU) is the main processing section of the processor. It is responsible for doing all calculation, arithmetic and logical operation.
- It also controls the different operation in the processor.
- EU takes care of performs operations on the data.
- EU is called as the execution heart of the processor.

### 7 The execution unit (EU)

Arithmetic Logic Unit

Flag Register

General purpose Register

control unit

decoder

pointer and index register

• 8086 pin diagram



~~(Q)~~ explain pin configuration of 8086 MP  
Ans: (draw that block diagram here)

The 8086 MP has 40 pins and can operate in two modes.

- minimum mode (single processor system)
- maximum mode (multi - 1-1-1-1-1)

## (1) Power and clock signals.

- through diagram
- V<sub>CC</sub> — Pin. 40 → +5V power supply
  - GND — 1, 20 → electrical ground
  - CLK — 19 → provides clock signals to synchronize operations

## (2) Address / Data bus

- A<sub>0</sub> ~ A<sub>15</sub> → ~~2<sub>16</sub>, 2-16, 39~~ → multiplexed for Address and data
- A<sub>16</sub> ~ A<sub>19</sub> / S<sub>3</sub> ~ S<sub>6</sub> → 35-38 → higher address bits and status signals.

### (3) control & status signals.

|          |    |                            |
|----------|----|----------------------------|
| - ALE    | 25 | → Add latches enable       |
| - M/I/O  | 28 | → Memory or I/O operations |
| - RD     | 32 | → Read signal              |
| - WR     | 29 | → write -1-                |
| - BHR/ST | 34 | → Burst high enable,       |

### (4) interrupt & DMA signals.

|      |    |                          |
|------|----|--------------------------|
| NMI  | 17 | → Non maskable interrupt |
| INTA | 27 | → interrupt Acknowledge  |
| HOLD | 31 | → DMA req.               |
| HLDA | 30 | → DMA acknowledge        |

### (5) other signals

|       |    |                                |
|-------|----|--------------------------------|
| Reset | 18 | Reset processor                |
| Ready | 22 | Synchronise slow memory or I/O |
| DRN   | 28 | data enable                    |
| DT/R  | 24 | data transfer transmit/receive |
| TEST  | 23 | debugging                      |
| MN/MX | 33 | minimum(1), maximum(0) mode    |

## \* minimum mode

- ALE -
- M<sub>I/O</sub> -
- RD ✓
- WR ✓
- INTR ✓

## \* maximum mode

- S<sub>2</sub>, S<sub>1</sub>, S<sub>0</sub>
- CCLK
- RQ1/GT1, RQ0/GT0

~~Q)~~ explain flag registers of 8086 microprocessor.  
(How many active flags?)

Ans:

The flag register in the 8086 microprocessor is a 16-bit register that indicates the status of the processor after an operation. It contains 9 active flags which are divided into:

① Status Flag (6 Flags)

② Control Flags (3 Flags)



OF → overflow Flag

{ DF → direction ← 1 ←

{ IF → External / interrupt

{ TF → Trap

{ SF → Sign

{ ZF → Zero

{ AF → Auxiliary

{ PF → Priority Parity

{ CF → carry Flag.

OF

DF

IF

TF

SF

ZF

AF

PF

CF

A ←

P ←

R ←

## (1) control Flags: (3 flags)

- As discussed, out of nine flags of 8086, three are control flags that are used to control certain operation of the processor.



~~① Trap Flag → used for debugging a program. To see step execution this flag should be set to 1.~~

This help the user to detect the error in the program or help programmer debug a program

$TF = 1 \rightarrow$  single step on,  $TF = 0 \rightarrow$  off

~~② The interrupt Flag → used to markable as well as non-markable interrupts.~~

→ used to enable or disable the markable interrupt i.e. INTB

~~$TF = 0 \rightarrow$  disable,~~  
 ~~$TF = 1 \rightarrow$  enable~~

~~③ The direction Flag: There are special type of instruction that can work on an entire array of data.~~

|          |     |
|----------|-----|
| PAGE No. |     |
| DATE     | / / |

- (4) zero  $\rightarrow$  Set if the result is zero.
- (5) sign  $\rightarrow$  Set if the result is negative ( $MSB = 1$ )
- (6) overflow  $\rightarrow$  Set if the result overflows beyond the signed range.

~~Q7~~ explain programmer model

Ans:

|                    |    |                     |
|--------------------|----|---------------------|
|                    | R3 | extra segment       |
| B I U<br>Registers | SS | code ← - -          |
|                    | SS | Stack ← - -         |
|                    | DS | Data ← - -          |
|                    | IP | instruction pointer |

The 8086 programmer Model is a picture of the processor as variable to the programmer. These are the registers used to hold numbers and address, as well as indicators, flags and control.

(a)

- Data registers (16 bit each for AX, BX, CX and DX)

|                        |       |    |    |                       |
|------------------------|-------|----|----|-----------------------|
| <b>Register</b><br>R/W | AX    | AH | AL | Accumulator           |
|                        | BX    | BH | BL | base register         |
|                        | CX    | CH | CL | count - 1             |
|                        | DX    | DH | DL | data - 1              |
| <b>Registers</b>       | SP    |    |    | Stack Pointer         |
|                        | BP    |    |    | Base - 1              |
|                        | SI    |    |    | source index register |
|                        | DI    |    |    | destination index - 1 |
|                        | Flags |    |    |                       |

- For 16 bit data registers can be accessed by names AX, BX, CX and DX
- Individual bytes of these registers can be accessed by AH, AL, BH, CH, DH and DL
- The segment registers are CS, DS, ES and SS and offset is stored in instruction pointer or stack pointer or base register or one of the index registers

- Flag Registers (16-bit) draw diagram as previously I drew

(1) Status - CF, PF, AF, ZF, SF, OF

(2) control - IF, FF, DF

~~(Q)~~ explain demultiplexing of address and data signals.

Ans:



- We have discussed the use of 8282 latches in address latching and 8286 as data buffer.
- If we use them simultaneously then we can demultiplex the address data bus as shown in Fig.
- Thus we required three octal latch chips and two octal transceiver chips in order to completely demultiplex the address and data bus.
- The simplified equivalent circuit show below:

(O.L.C.)



~~(1)~~ explain features of 8086 mp

Ans:

~~(2)~~ it is a 16-bit microprocessor

~~(2)~~ it has 16-bit ALU so it can perform 16-bit operations simultaneously

~~(3)~~ similarly it has 16-bit registers & 16-bit internal and external buses

~~(4)~~ the speed of processor depends on frequency of operation or clock speed.

~~(5)~~ 8086 has 5 mega

8086 - 1

8086 - 2

10 mega

8 mega

~~(6)~~ 8086 has ~~20~~ bit address line to access memory  
hence it can access 1 MB ~~2<sup>20</sup>~~

a add

~~(7)~~ It has 16 bits address line to I/O devices so  
it ~~can~~ can access 64 kb of I/O devices.

~~(8)~~ It supports 2 stage pipelining (Fetch & Execute)

~~(9)~~ It has 14 ~~is~~ 16-bit registers

~~(10)~~ It has 256 vector interrupt

~~(11)~~ It uses memory banking system (even odd)  
total memory size 1 MB

even bank

512 kb

odd bank

512 kb

~~(12)~~ It has instruction set to perform many operations.

~~(Q)~~ explain addressing modes 8086 microprocessor

Ans:

- Addressing modes (method) refer to the different method of addressing (selecting) the operands
- we can categorize addressing mode of 8086 as follows:

- (1) Register
  - (2) Immediate
  - (3) Memory
  - (4) String
  - (5) 10
  - (6) Implied
- } addressing modes

### Addressing Modes

Register

Immediate

String

Implied

10

memory

Direct

Register

Indirect

Based

Register

Indirect

Relative

Relative

Direct

Indirect

part

part

Relative based  
indirect.

## (1) Register Addressing Mode.

F In this mode of addressing operand is in the register, and instruction specifies the particular register as shown below.



② The advantage of this addressing mode is that the access is faster.

## (2) Immediate Operand Addressing Mode.



- in this case the operand is in the instruction itself.
- it said to be immediate addressing mode as the operand is in immediate next location of the opcode.

### B) Memory Addressing Mode.

PA = Segment



Segment Register

offset



:EA

= segment register : BASE + INDEX + DISPLACEMENT

~~{ CS, SS }  
DS, ES }~~ : { BX } + { SI } + { 8 or 16 bit  
displacement }  
BP DI

① Memory addressing mode defines how memory locations are assigned in the 8086 MP

② These modes determine how the effective address (EA) of an operand is calculated  
Segment registers + Base + index + displacement

#### Types of memory Addressing modes

① direct ✓

② Register indirect ✓

③ Based indexed ✓

④ Register relative ✓

⑤ Relative based indexed. ✓

#### 4) String Addressing Mode:

- string instruction use a different addressing mode where the pointers SS and DI along with segment register D1 and RS, respectively are used to access the source and destination memory location
- These pointers are also automatically incremented or decremented according to the value of direction flag (DF)

#### 5) I/O addressing modes

- we have
  - (1) Memory mapped I/O
  - (2) I/O mapped I/O

##### \* Memory mapped I/O

\* As the name says, memory mapped I/O refers to an I/O location mapped in memory i.e. given a memory address

\* advantage of this that any instruction can access this data directly and hence giving a eas of access

- disadvantage: of such I/O location is that the access for I/O location being normally slower it makes the processor to wait.
  - \* makes it slower or process to wait

## \* I/O mapped I/O

- in this I/O mapped to support two different addressing modes

- (1) Direct port addressing
- (2) Indirect port - 1-1-1-

~~(1)~~ Direct port addressing: As the name says, direct port addressing in this case the address of I/O devices is given in instruction itself.

~~(2)~~ Indirect port addressing: In this case a pointer register i.e. the register DX is used to give the address of the I/O location.

## (6) Prolonged Addressing Modes:

In this case the operand or reference to operand is not specified in the instruction. Instead the operand is obvious in the mnemonic or the instruction

Eg: XLAT

CMA

STC

STD

(3) Ready: The Ready signal causes 8086 processor to wait for slow peripherals.

(4) Synchronization (CSYNC & SYNC)

CSYNC & SYNC signals allow multiple 8086 MP to run synchronously in a system.

~~IMP Q)~~ explain memory segmentation:

Ans:

- Memory segmentation is a technique used in 8086 microprocessor to efficiently manage 1MB of memory.
- The 8086 has 20-bit address bus, allowing it to address up to  $2^{20} = 1,048,576$  bytes (1MB) of memory.
- Instead of handling the entire memory 1MB linearly, 8086 divides it into segments of 64KB to make memory management different and structured.

### Segmentation in 8086

| Segment Register | Segment Name | Purpose                     |
|------------------|--------------|-----------------------------|
| CS               | Code segment | Store execution programs    |
| DS               | Data - I -   | Variables and constants     |
| SS               | Stack - I -  | Store stack of data         |
| ES               | Extra - I -  | Additional data             |
|                  |              | Storage or string operation |

memory



### \* Advantage

- The most imp advantage is that the programmer can access a memory that required 20-bit address by using 16-bit register only

### \* disadvantage

- It becomes complicated for the programmer as multiple register to access a memory location
- Limited segment size

- The program, data, and stack are stored in separate blocks in memory and hence they are organised in a modular fashion
- It also help in OOP to store data of an object

- Complex Addressing calculation

Efficient memory usage

Faster execution

Support multi-tasking

Q) Explain following instruction of 8086 mp

### (1) complement carry - CM C

- function: complements (toggles) the carry flag

$$\text{if } CF = 1 \rightarrow CF = 0$$

$$\text{if } CF = 0 \rightarrow CF = 1$$

Syntax: CM C

Affected Flags: CF only

Use case: Used in arithmetic or logic operations

where carry needs to be inverted manually.

### (2) XCHG — Exchange Register / memory with register

- function: swaps the content of two registers or a register and a memory location

Syntax: XCHG reg1, reg2

XCHG reg, mem

Affected Flags: None

Use case: Used to exchange values without using a temporary register.

(3) **MOVSB** - Move string byte

function: Moves a bytes from [DI: SI] to [ES: DI]

Syntax: **MovSB**

Affected flag: None (but direction of movement controlled by DF (direction flag))

Use case: Used for copying a string <sup>of</sup> bytes from source to destination.

(Copy)

|          |     |
|----------|-----|
| PAGE NO. | / / |
| DATE     | / / |

### ~~(1) LAHF (Load AH Register Flags)~~

- Function: Copies the lower bytes (Mftr's Flag) or the Flags register into the AH Register
- Syntax: LAHF
- Affected Flags: None
- Use Case: Used to store the status flags before modifying them or for debugging purpose

### ~~(2) XLAT (Translate byte)~~

- Function: Uses the AT Register as index to a lookup table located at DS:BX and replace AL with the corresponding byte from the table (table lookup)
- Syntax: XLAT or XLATB
- Affected Flags: None
- Use Cases: Used for the lookups, such as character translations or encryptions

### (3) DAA (Decimal Adjust After Addition)

- Function: Adjust the AL Register after a BCD addition to ensure a correct BCD result

Syntax: DAA

Affected Flags: AF, CF

In Case: Used in BCD arithmetic operations

### (4) JNE (Jump if Not equal)

- Function: Jumps to a specific address if zero flag (ZF)  $\neq 0$

meaning is the two compared values are not equal

Syntax: JNE

Affected Flags: None

In Case: Used in conditional branching to execute instruction based on inequality

(5) AAA ( ASCII Adjust after Addition)

function : Adjust the result in AL adding two ASCII coded decimal digits to ensure a valid ASCII decimal result

Syntax : AAA

Affected Flags : AF CF

use case : used in ALU arithmetic to convert invalid result.

(4) STOSB ( store string byte ) :

Function : stores the value in AL register into memory location pointed by DT

Syntax : STOSB

Affected Flags : None

use case : used for storing strings or repeating bytes value in memory.

(1) ~~dedicate interrupt in 8086 MP~~

(2) In 8086 there are 5 dedicated interrupts that have ~~had~~ ~~fixed~~ interrupt vector addresses and one used for specific purpose.

(3) divide by zero interrupt

~~• type 0~~

trigger condn: division by zero or overflow in  
OPV / ZPV

vector Address: 0000H

use case: prevents invalid division

(2) single step

type: T

trigger condn: Trap flags = 1

vector Address = 0004H

use case: debugging (step-by-step execution)

### (3) Non-Maskable Interrupts (NMIs)

Type: 2

trigger condn: critical hardware error

vector Address: 000.8H

use case: Power Failure, memory error

### (4) break points.

Type: 3

trigger condn: INT 3 instruction executed

vector Address: 00EH

use case: debugging, setting breakpoints

### (5) overflow (arithmetic overflows)

Type: 4

trigger condn: PINTO instruction and OF=1

vector Add = 050H

use case: handles arithmetic overflows

# ALP

|          |       |
|----------|-------|
| PAGE No. | / / / |
| DATE     | / / / |

Q) Write ALP for 8086 to exchange content of two memory blocks

Ans:

.model small  
.stack 100h  
.code

main :

mov ax, @data .

mov ds, ax ; Set DS Segment

mov si, 1100h ; block 1

mov di, 1200h ; block 2

mov cx, 10 ; no. of bytes to exchange

next :

mov al, [si] ; get byte from block 1

mov bl, [di] ; — 1 — block 2

mov [si], bl ; block 2 into block 1

mov [di], al ; block 1 into block 2

inc si;

inc di;

loop next ; Repeat till cx = 0

mov ah, ~~4ch~~ 4ch ;

int 21h

end main

Q) Write ALP for searching a character in given string  
 (consider your own string)

Ans:

string : "HELLO"  
 Search : 'L'

.model small

.stack 100h

.data

str db 'HELLO';  
 ch db 'L';  
 flag db 0;      0 = not found, 1 = found

.code

main:

mov ax, @data;

mov ds, ax

lea si, str

mov cx, 5

Next:

mov al, [si];

comp al, ch

je found

inc si

loop Next

jmp end

db

found :

mov flag, 1

end :

mov ah, 4ch

int 21h

end main

Q) Write ALP for 8086 to reverse a string of 10 characters

Ans:

- model small

- stack 10h

- data

```
str db 'ABCDEFGHIJ'
```

```
len db 10
```

- code

main:

mov ax, @data

mov ds, ax

lea si, str

lea di, str+9

mov cx, 5

reverse-loop:

mov al, [si]

mov bl, [di]

mov [di], bl

mov [di], al

inc si  
dec di  
loop reverse-loop

; exit program

mov ah, 4ch

int 21h

end main

Q) write ALP for 8086 to transfer blocks of data

Ans:

- model small

- stack 100h

- data

source db 10h, 20h, 30h, 40h, 50h, 60, 70h, 80h,  
90h, Ah

dest db 10 dup(?)

- code

main:

mov ax, @data

mov ds, ax

lea si, source

lea di, dest

mov cx, 10

transferLoop :

    mov al, [si]

    mov [di], al

    inc si

    inc di

loop transferLoop

; Exit program

    mov ah, 4ch

    int 21h

end main.

Q) Write ALP for 8086 to arrange 10 numbers in ascending order.

Ans:

- model small

- stacks 10h

- data

numbers db 10, 2, 30, 5, 17, 40, 9, 7, 60, 11;

.code

main :

    mov ax, @data

    mov ds, ax

    lea si, numbers

    mov cx, 9

outerLoop :

    lea di, numbers

    mov bx, cx

inner-loop:

mov al, [di]

mov ah, [dit1]

cmp al, ah

jbe no-swap

exchange al, ah

mov [dit1], al

mov [dit12], ah

no swap:

inc di

dec bx

jnz innerloop

dec cx

jnz outerloop

mov ah, 4ch

int 1h

end main.

# Minimum Mode

|          |     |
|----------|-----|
| PAGE No. |     |
| DATE     | / / |

Q) draw and discuss timing diagram for read operation and write operation in minimum mode

Ans:

(9) CLK



Minimum mode read cycle

### minimum mode write cycle



## \* Minimum mode read cycle:

This cycle is used when the 8086 reads data from memory or an I/O device

### (1) T<sub>1</sub> state :

- Address placed on A015-A00
- ALR (Address Latch Enable) is High
- M/I<sub>O</sub> is set
  - I = memory Read
  - O = I/O Read

### (2) T<sub>2</sub> state :

- Address bus now used for data (bus is selected)
- RD becomes active low - indicate read operation
- DT/R is High - Processor is receiving data
- DEN is enabled - Data bus drivers are active

### (3) T<sub>3</sub> state :

- valid data is available on data bus D15-D0
- data is ready to be processed

### (4) T<sub>4</sub> state :

- RD, DEN signal go high - ending the cycle
- Bus is idle now

### \* Minimum mode write cycle:

This cycle is used when the 8086 writes data to memory or I/O

#### (1) T<sub>1</sub> State:

Address placed on AD15-AD0

ALE is High

RAstro

1 = memory write

0 = I/O write

#### (2) T<sub>2</sub> State:

Address is latched, bus switches to data

$\overline{DT/R}$  is low  $\rightarrow$  processor is sending data

DRN is enabled  $\rightarrow$  Bus drivers ON

WR goes low  $\rightarrow$  indicate write operation

#### (3) T<sub>3</sub> State:

Data is placed on data bus D15-D0

Data is written to memory or I/O device

#### (4) T<sub>4</sub> State:

WR, DRN go high  $\rightarrow$  write complete

Bus is now idle.

(8) draw the timing diagram for read and write operation in maximum mode

Ans:



Maximum mode read cycle

• Maximum mode write cycle

(Q)

CLK

S2, J1, 10

Active

Inactive

A16/S3 -

A19/S6

BHE/1S7

AD8 - AD15

A16 - A19

BHE

83 - S7

A08 - A15

D0 - D15

AUR

DT/R

AM/WL or  
AF/OWC

MWE or  
TOWC

DRH

## \* Maximum Mode Read cycle:

Used when 8086 read data from memory or I/O in maximum mode.

### (1) T1 (Clock cycle):

Address line (A15-A0) carry address

ALE goes High

Status line S0, S1, S2 are set

Address is active

### (2) T2 :

- 8288 Bus controller use status lines to generate MRDC or TORC (PIO Read) (Memory Read)
- DT/R is High - receiving data
- DEN (Data enable) becomes active
- Address is now latched and bus is used for data

### (3) T3 :

Valid data is placed on data bus by memory or PIO devices 8086 read data.

### (4) T4 :

MRDC / TORC and DEN go inactive  
data bus is released.

### \* Maximum Mode write cycle:

Used when 8086 writes data to memory or I/O in maximum mode.

#### (1) T1 :

Address is placed on A015-A00

ALE is high

J0, J1, J2 indicates type of write

Address lines are active.

#### (2) T2 :

- 8288 Bus controller generates:

MWTC (memory write command)

IOWC (I/O write - 1-1-)

- DT/R is low - sending data
- DEN becomes active
- Data is placed on the data bus

#### (3) T3 :

Data on D15-0 is written into memory or I/O device

#### (4) T4 :

- MWTC / IOWC and DEN go high - write end
- Bus becomes idle.

Q) Explain maximum mode of 8086

Q) Maximum mode configuration of 8086

Ans:



- in maximum mode, the 8086 microprocessor is used in system with multiple processor or co-processor
- to enable this mode, the MN/MX pin set to 0

### \* Why maximum mode ?

- to share system bus with other processor
- useful when coprocessor is used
- 8086 does not generate control signals directly, instead gives status signals. M, I<sub>1</sub>, I<sub>0</sub>

### \* Main Components

#### (A) 8086 Microprocessor

- provide address / data bus and status signal
- need external bus controller to complete the operation

#### (B) 8288 Bus Controller

- receive status signals from 8086

#### (C) 8282 Latch

- store the address

#### (D) 8286 Transceiver

#### (E) 8284 Clock generator

Generate Reset and ready signals.

## \* How it works :

- Address is placed on ADO - A15 and A16 - A19 lines
- ALR enables the latch to hold the address
- 8086 manage data flow on D0 - D15
- 8086 send R, S1, S0 to 8288
- 8288 decodes them and produces control signals

in maximum mode , 8086 works with external devices like 8288 (bus controller) , 8286 (transceiver) and 8282 (latch) to manage control signals , address , data separation and communication - used in multiprocessor systems.

Q) explain minimum mode of 8086

Ans:



In minimum mode, the 8086 operates as a single processor system. To enable this mode, the M1/MX pin set to 1.

### \* Why minimum mode?

- used for simple system with only one CPU
- 8086 generates all control signals by itself
- suitable for basic microprocessor application

### \* Main components

#### (1) 8086 Microprocessor

It generates all control signals

#### (2) 8284 Clock generator

Generates Reset and Ready signals

#### (3) 8282 Latch

- store the address

#### (4) 8286 Decoder

#### (5) 74139 Decoder

- decode address signal to generate memory  
R/W control signals.

\* How it works?

- 8086 places address and ~~data~~ data on multiplexed lines
- ALE enables the latch to store the address
- Control signals RD, WR and ALE are generated directly by 8086
- 74138 decoder uses these signals to activate memory  $\oplus 10$ , read/write operations

In minimum mode, 8086 handles all control signals internally, it used in single CPU system, with external support only for fetching address and controlling data direction.

(g) explain the interrupt structure of the 8086 processor (PVT) and diff b/w hardware and software interrupt

Ans:

An interrupt is a ~~flag~~<sup>signal</sup> that temporarily stops the CPU's current execution so that it can attend to an urgent task

In 8086, we have three source of interrupt,

source of interrupt



(1) Hardware interrupt:

- In this type of interrupt, physical pins are provided in the chip. In 8086 we have two pins

(1) NMI (Non maskable interrupt)

(2) INT

(2) Software interrupt:

- Software interrupt, in 8086 we have INT instruction
- When INT instruction is executed interrupt will occur

### (3) Error condition (exception or internal interrupt)

These are automatic interrupt generate due to error during execution

(a) Type 0 → divide by zero error

Occurs when a division by zero or result overflow happens

(b) type 1 → single step

Use for debugging

(c) type 4 → overflow

When overflow flag is set.

Non-maskable interrupt request

NMI

interrupt logic

INTR

PTC

8259A

int n  
instr.

8MHz  
instr.

divide  
error

singl  
step  
TF = 1

maskable

interrupt

regular

Sr. No

## Hardware Interrupt

## Software Interrupt

- (1) To implement hardware interrupt a pin is given to processor to implement a software interrupt an instruction is given to the processor
- (2) Hardware interrupts are mostly maskable or non-maskable interrupts software interrupts are mostly non-maskable interrupts
- (3) Hardware interrupts may be vectored or non-vectored software interrupts are mostly vectored.
- (4) Hardware interrupt of 8086 are NMI and INT8 software interrupt of 8086 are INT n
- (5) Trigger when signal source from external device trigger when causes by instruction like Int n
- (6) Source is external source is internal

## Q) Explain IVT (Interrupt vector table)

Ans:

The interrupt vector table (IVT) is a reserved area of memory used to store the address of interrupt service routines (ISR).

When an interrupt occurs, the 8086 uses the IVT to locate and execute the appropriate service routine.



## \* Location of IAT

- The IAT is located at the beginning of memory from address 00000H to 003FFH
- It occupies 1kB (1024 bytes) of memory space

## \* Structure of IAT

- The IAT contains 256 interrupt vectors, one for each possible interrupt type (00H to FFH)
- each vector is 4 byte long:  
 2 bytes the offset (IP) of the ISR  
 2 bytes the segment (CS) - 1 - 1 - 1 -

## \* Purpose of IAT :

- provides a mapping b/w an interrupt type and its corresponding ISR
- When an interrupt occurs, the 8086
  - (1) → multiplies the interrupt type by 4 to get the IAT address
  - (2) reads CS and IP from that location
  - (3) jumps to the ISR using CS:IP

- (i) explain flag registers of 80386 processor  
 (ii) explain F-Flags

Ans:

The F-Flags (Extended Flag) register is a 32 bit register in the x86 architecture used to indicate the status of the processor and control operations. It contains Status flags, Control flags and System flags.

- Flag register of 8086 :

|    |   |   |   |   |    |    |    |    |    |    |   |    |   |    |   |    |
|----|---|---|---|---|----|----|----|----|----|----|---|----|---|----|---|----|
| 15 | X | X | X | X | OF | DF | IF | TF | SF | ZF | X | AF | X | PF | X | CF |
|----|---|---|---|---|----|----|----|----|----|----|---|----|---|----|---|----|

- Flag register of 80386 :

|    |  |  |  |  |             |      |   |    |    |    |    |    |    |   |    |   |    |   |    |
|----|--|--|--|--|-------------|------|---|----|----|----|----|----|----|---|----|---|----|---|----|
| 31 |  |  |  |  | NT          | Iopl | L | OF | DF | IF | TF | SF | ZF | X | AF | X | PF | X | CF |
|    |  |  |  |  | Nested flag |      |   |    |    |    |    |    |    |   |    |   |    |   |    |

I/O privilege level

Same as 8086

- Pentium

|    |    |   |    |   |    |      |   |    |    |    |    |    |    |   |    |   |    |   |    |
|----|----|---|----|---|----|------|---|----|----|----|----|----|----|---|----|---|----|---|----|
| 31 | VM | R | OF | X | NT | Iopl | L | OF | DF | IF | TF | SF | ZF | X | AF | X | PF | X | CF |
|    |    |   |    |   |    |      |   |    |    |    |    |    |    |   |    |   |    |   |    |

Virtual mode

Reference mode

Same as 80386

### \* System Flags:

- (1) VM → Virtual 8086 mode
- (2) RF → Resume Flag
- (3) NT → Nested Flag
- (4) IOPL → I/O privilege level

### \* Status Flags:

- (1) OF → overflow Flag
- (2) PF → Parity Flag
- (3) ZF → zero
- (4) SF → sign
- (5) AF → Auxiliary carry
- (6) CF → carry Flag

### \* Control Flags:

- (1) TF → Trap Flag
- (2) IF → Interrupt Flag
- (3) DF → direction Flag

## \* System Flags:

(1) VM (Virtual 8086 Mode):

enables virtual 8086 mode for running real-mode code.

(2) RF (Resume Flag):

Used with debugging to control exceptions

(3) NT (Nested Task):

Used for controlling multitasking

(4) IOPL (I/O privilege level):

privilege level for I/O operations

## \* Control Flags:

(1) TF (Trap Flag): enables single-step debugging

(2) ZF (Zero Flag): if set, enables external interrupt

(3) DF (Direction Flag): controls string operations  
(Increment / Decrement)

\* Status Flags:

- (1) OF (Overflow Flag): Set if an arithmetic overflow occurs
- (2) PF (Parity Flag): Set if the number of set bits in the result is even
- (3) ZF (Zero Flag): Set if the result of an operation zero
- (4) SF (Sign Flag): Set if the result is negative
- (5) AF (Auxiliary carry): Used in BCD operation (0xd between 4-bit to higher bits)
- (6) CF (Carry Flag): Set if there's carry or borrow in arithmetic operations.

Q) \* Ans:

compare b/w 8086, 80386, Pentium 1, 2, 3

| Attribute              | 8086    | 80386  | Pentium 1 | Pentium 2 | Pentium 3 |
|------------------------|---------|--------|-----------|-----------|-----------|
| Processor size         | 16 bit  | 32 bit | 32 bit    | 32 bit    | 32 bit    |
| Data bus size          | 16 bit  | 32 bit | 64 bit    | 64 bit    | 64 bit    |
| Address bus size       | 20 bit  | 32 bit | 32 bit    | 36 bit    | 36 bit    |
| Physical memory        | 1 MB    | 49b    | 49b       | 649b      | 649b      |
| Segmentation           | Yes     | Yes    | Yes       | Yes       | Yes       |
| Paging                 | No      | Yes    | Yes       | Yes       | Yes       |
| Protection             | No      | Yes    | Yes       | Yes       | Yes       |
| Pipeline level         | 2 Stage | 3      | 5         | 14        | 14        |
| Branch Prediction      | No      | No     | Yes       | Yes       | Yes       |
| Cache                  | No      | Yes    | Yes       | Yes       | Yes       |
| Operating Frequency    | 5 MHz   | 15 MHz | 80 MHz    | 233 MHz   | 450 MHz   |
| out of order execution | No      | No     | No        | Yes       | Yes       |
| Year of Release        | 1978    | 1985   | 1993      | 1997      | 1999      |

g) diff b/w real mode, virtual mode and protected mode

Ans:

| Sr.NO | Real Mode                                                         | Protected Mode                                                                           | Virtual mode                                                     |
|-------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| (1)   | It support 1 MB + 64 KB memory                                    | it support maximum 4gb of memory<br>Same                                                 | it support maximum 4gb of memory<br>1                            |
| (2)   | In real mode, it execute only single task at an instance.         | It support multi-tasking at a particular instance.<br>Same                               | It support multi-tasking at a particular instance.<br>1          |
| (3)   | In real mode, processor behave like a 8086 or 8080 microprocessor | In protected mode it provides memory protection, multitasking and extended memory access | In virtual mode, it is a combination of Real and protected mode. |
| (4)   | The switching between protected and real mode is not possible     | The switching between protected and virtual mode is possible                             | The switching between real and protected mode is possible.       |
| (5)   | It allow direct access to hardware and memory                     | It provides privilege level (4 to 3) to control access to system resources               | Running multiple virtual 8086 environments.                      |

(Q) Explain floating point pipelines of Pentium Processor.

Ans:

- Floating point unit is heavily pipeline, hence allowing several instruction to be executed simultaneously under certain conditions.
- Most of the floating point instruction have to be in U pipeline only and cannot be paired with integer instruction.
- The first four (4) stage of the floating point pipeline are shared with the integer pipeline unit.
- The 8 pipeline stages of the pipeline unit are as follows:
  - (1) Prefetch: instruction is fetched from memory into the pipelines
  - (2) Instruction Decode one: Basic decoding of the instruction format begins.
  - (3) Instruction Decode two: Completes decoding and identifies operations type and operands.
  - (4) Execution stage: perform the actual floating point operations.

### (5) Floating point execution 1 ( FPE 1 ) :

- In this stage, read the information from register and memory and moving into floating point register
- All also converted to FP format

### (6) Floating point Execution 2 ( FPE 2 ) :

- In this stage FP Operation is performed.

### (7) Write FP Result :

The result is rounded off and return in FP register

### (8) Error Reports :

- If error is detected, repeat it.

## Architecture

Q) Explain the cache organization of pentium processor.

**Ans**



The figure illustrates the typical memory and cache architecture in pentium-class processor, focusing on high-speed access and efficient system performances, through multiple levels and controllers.

## \* Components of cache organization

- (1) Host CPU : Central processing unit that executes instruction and processes data.
- (2) Cache SRAM (static RAM) : High speed memory used for cache.  
- stores frequently accessed data to reduce CPU wait time.
- (3) Cache controller : Manage all cache operations.  
(read/write, replacements)  
- Interface b/w CPU and cache SRAM
- (4) Dual port DRAM controller : Allows simultaneous access from both cache controller and system  
- enhanced memory access efficiently by supporting concurrent operations
- (5) System DRAM : Main memory of the system  
- Accessed when data is not found in the cache.
- (6) System Bus : Data communication path b/w CPU, memory and other components.  
- transfer data, address and control signals.

(A) expansion slots: physical interfaces for adding extra hardware.  
eg: CPU, network cards

- connected via system bus to communicate with CPU and memory

(B) embedded expansion devices:

Built-in ~~to~~ additional hardware components  
eg: WiFi, graphics

- Integrated to motherboard and communicate with system bus

(g) explain in brief Cache organization of Pentium processor also called code cache organization and explain data cache organization too.

Ans:

The Pentium processor uses a two-way set associative cache organization for both code and data cache each of size 8 kB. The code cache specifically stores the instruction data to be executed by the processor, enhancing the instruction fetch performances.

main memory  
8 kB

Cache memory  
8 kB



| Main memory address | 2abit   | 7 bits    | 5 bit                 |
|---------------------|---------|-----------|-----------------------|
|                     | set no. | Block no. | Location within block |

The pentium processor uses two separate Level 1 (L1) cache

- code cache (instruction)
- data cache

### ① Code cache organization

purpose: stores instructions to be executed by the CPU

Total size: 8 kb

Associativity: 2-way set associative

Each way size: 4 kb

Line size: 32 bytes

No. of lines per way: 128 ( $4096 \div 32$ )

### Address Breakdown (32-bit address)

Tag (Page Number): 20 bits

Set index (Line index): 7 bits

Offset (Within block): 5 bit

### Lookup process:

- The set index identifies the cache set
- the tag is compared with stored tags in both ways
- if matched, the instruction is read from cache
- if not matched, it results in a miss, and the block is fetched from main memory

|          |     |
|----------|-----|
| PAGE NO. |     |
| DATE     | / / |

## ② Data cache organization

purpose: Stores data operands used by instruction

Total size: 8 KB

Associativity: 2-way set associative (way 0 and way 1)

each way size: 4 KB

Line size: 32 bytes

No. of lines per way: 128

Directory entry for each line:

20 bit Tag

2-bit MEST States:

00: invalid

01: exclusive

10: modified

11: shared

- Parity bit: error detection for each byte.

Cache Access:

- When data is accessed, the set index and tag are used
- if data is present, it's read quickly
- if not, it's fetched from system memory and stored in cache

Q) explain memory banking? what is advantage of memory banking and justify with example.

Ans:



- The 8086 microprocessor is a 16-bit processor with 20-bit address bus (A0-A19) and 16-bit data bus (D0-D15) allowing it to access up to 1MB of memory and process 16-bit data efficiently.
- However, memory is organized as 8-bit wide, so to handle 16-bit data, 8086 uses a technique called memory banking.

## \* Memory banking structure:

- Address Bus - (A0-A19) : Used to specify memory address
- data bus (D0-D15) : 16-bit wide data bus
- memory is divided into two banks:
  - even-bank : for even address bytes (D0-D7)
  - odd-bank : for odd address bytes (D8-D15)
- memory is divided into such that consecutive location fall into two parts chip
- So one chip has even locations 0, 2, 4, 6 ... etc called even bank
- So one chip has odd locations 1, 3, 5 ... etc called odd bank.

Generally for any 16-bit operations, even bank provides the lower bytes and ~~high~~ odd bank provides the higher bytes.

Hence the even bank is also called lower bytes and the odd bank is also called higher bytes.

1 MB

512 KB

odd bank

- higher bytes
- Address range

0 0001 H

0 0003 H

0 0005 H

|

F P F F F H

512 KB

even bank

- lower bytes
- Address range

0 0002 H

0 0004 H

0 0006 H

|

F P R F E H

Select when BH &amp; 0

Select when Ao = 0

BHE

Ao

Operation

|   |   |                                      |
|---|---|--------------------------------------|
| 0 | 0 | Read or write 16-bit from even bank  |
| 0 | 1 | Read or write 8-bit from higher bank |
| 1 | 0 | Read or write 8-bit from lower bank  |
| 1 | 1 | No operation                         |

### \* Advantage:

- efficient for 16-bit data handling
- faster execution
- Better performance
- Flexibility
- Simplified memory design

eg:- Accessing a word at even bank (eg: 1000H)

$A_0 = 0, \overline{BNE} = 0 \rightarrow$  both banks accessed

entire 16-bit word fetched in ~~one~~ cycle

- Accessing a word at odd address (eg: 1001H)

Requires two memory accesses - one to 1001H

one to 1002H

takes two cycles reducing efficiency.

(Q) Explain hyper threading technology ~~and its~~ and its use in pentium 4.

Ans:

- Hyper threading (HT) Technology is intel's hardware based simultaneous multithreading (SMT) technology.
- It improves the performance of PA-32 processor by allowing better utilization of CPU resource when running multi-threaded operating system and applications.

#### \* Key Features of HT:

- (1) concurrent execution
- (2) simulated multi-processing
- (3) PA-32 support
- (4) logical processor design
- (5) APIC support (Advance Programmable Interrupt controller)
- (6) OS View:

#### \* Use in Pentium 4:

- pentium -4 was the first intel processor series to implement hyper-threading technology
- it improved performance in:
  - multitasking
  - threaded application

- Allowed ~~one~~ physical Pentium 4 processor to appear as two CPUs to the O.S.

\* Advantage :

- Better CPU utilization
- Increased throughput in multi-threaded workloads
- Improved performance without needing extra physical cores.

Q) draw and explain pentium 4: Net burst micro-architectures

Ans:



### \* Front-end Module:

- instruction fetch & decode unit: fetches and decodes instruction
- branch prediction unit: predicts the next instruction to reduce delays.
- trace cache & microcode ROM: stores decoded instructions for fast access

### \* Out-of-order execution unit:

- executes instructions out of order to improve speed
- retirement unit: reorder results to maintain correct program order.

### \* Execution unit:

- performs actual operation
- connected to Level 1 data cache for fast data access

### \* Memory Subsystem:

- Bus Interface Unit (BIU): connects to the system bus
- includes optional Level 3 cache for better memory performance.

- Q) Explain (ICW) initialization command words and (OCW) operational command words of 8259.

PJC

Ans:

The 8259 programmable interrupt controller (PIC) is used to manage hardware interrupts and send them to the CPU in a prioritized way.

To control its operations, it uses two sets of control words:

#### (1) Initialization command words (ICWs)

ICW are used to initialize the 8259A programmable interrupt controller. They are issued once during system setup to configure the operation mode of the PIC.

- There are 4 ICWs

(1) ICW 1 : Starts initialization and sets basic operation

(2) ICW 2 : Sets the basic address for interrupt routine

(3) ICW 3 : Specifies master/slave configuration

(4) ICW 4 : Specifies additional control information like operating mode.

## (2) OCWs (operational command words)

OCWs are used to control and manage 8259A PIC during normal operation.

These command can be issued at any time after ~~normalization~~ initialization.

- There are 3 OCWs

(1) OCW 1 : Used to mask or unmask interrupt request lines

(2) OCW 2 : controls how interrupt are acknowledged

(3) OCW 3 : Control interrupt polling, special mask mode and display the status

- The PCWs setup the 8259 PIC initially, while OCWs manage its behaviour during normal operation

- These control words provide flexible interrupt handling and efficient CPU interaction in system using 8259.

Q) discuss in brief protection mechanism of 80386 DX.

Ans:

The 80386 DX processor provides a powerful protection mechanism to support multi-tasking and memory protection in modern operating system.

These mechanism are based on segment-level and task-level protection and help prevent unauthorized access between programs and the O.S.



- Privilege level (PL)

The x86 architecture supports 4 privilege level ; known as privilege levels (PL) to isolate tasks.

- PL = 0 → most privilege (kernel level)
- PL = 1 → system service
- PL = 2 → OS extension
- PL = 3 → least privilege (user application)

lower PL = higher ~~privilege~~ privilege

A task at lower level can access higher level segment but not vice versa.

- page key protection mechanism in 80386 BX

### (1) privilege check:

- stops lower level tasks from using higher level code
- compare privilege levels before allowing access.

### (2) Limit check:

- each memory segments has a size limit
- Access outside the limit causes an error

### (3) A (Available) Bit:

- shows if a segment is already being used by another task
- prevent sharing of active segments.

#### (iv) Type check:

- Makes sure segments are used properly.
- Code segments → for instruction
- data - I - → for data
- System segments → only by system

#### (v) User / Supervisor Check:

- each memory page has U/S bit

$U/S = 1 \rightarrow$  User level access

$U/S = 0 \rightarrow$  Supervisor Only access

- stops user programs from accessing system memory

#### ① Task Management:

- supports hardware-based task switching with protection
- each task has a TSS (Task State Segment)
- TSS contain register state, stack pointers and I/O permissions
- during a task switch:
  - old tasks content is saved in its TSS
  - New tasks content is loaded from its TSS
  - All protection checks are performed

(g) explain the 8257 DMA controller with a neat diagram and its control register format.

(g) Interface pma controller 8257 with 8086 mp  
explain different data transfer modes of 8257 pma  
control.

Ans:



- The intel 8257 is a 4-channel direct memory Access (DMA) controller
- it allows peripheral devices to directly access system memory without involving the CPU
- this improves system performance, especially for high speed data transfer.

#### \* Key features:

- 4 independent DMA channel (CH-0 to CH-3)
- transfer upto 16KB per channel
- reduces CPU overhead
- supports multiple data transfer modes

#### \* Control Register Format:

| Bit     | Name              | Description                       |
|---------|-------------------|-----------------------------------|
| D7      | EN                | 1 = enable / disable = 0          |
| D6      | Rotating priority | 1 = Rotate; 0 = fixed             |
| D5      | extended write    | 1 = Active                        |
| D4      | TC stop           | 1 = Stop DMA after terminal count |
| D3      | Auto load         | 1 = enable auto reload            |
| D2 - D0 | Channel Enable    | 1 = enable                        |



**Fig. 10.7.1 : Interfacing of 8086 with 8257**

## 8257

### A) Interfacing<sup>1</sup> with 8086

To use 8257 with 8086 microprocessor, proper signal connection are needed.

#### (1) Address Bus:

8086 A0-A3 are connected to 8257 to access internal registers.

#### (2) Data Bus:

connect 8257 D0-D7 to the lower 8 data lines of 8086

#### (3) Control Signals:

- RD, WR, CS signals control Read / write access to 8257
- HREQ (Hold Request) from 8257 connect to Hold 8086
- HLD A (Hold acknowledged) from 8086 connects to HLD of 8257

#### (4) PMA Channels:

- Peripherals send PMA requests via DRQ0 - DRQ3
- 8257 respond with DACK0 - DACK3 to initiate data transfer.

## \* Data Transfer Modes :

### (1) Burst Modes :

- transfer a complete block of data continuously without CPU interruption
- CPU is kept in hold state during the entire transfer
- suitable for high-speed devices

### (2) Cycle Stealing Mode :

- DMA controller takes one bus cycle at a time from the CPU
- CPU and DMA work alternately.
- reduces CPU performances slightly but allows concurrent operations.

### (3) Demand Modes :

- DMA transfers data only when the peripheral request it
- transfer pauses automatically if DREQ becomes inactive
- useful when peripheral is not ready continuously.

### (4) Cascade Mode :

- used to connect multiple 8257 DMA controller together
- allows expansion beyond 4 channel
- one channel of the main 8257 is used to cascade a slave 8257
- the main controller passes control signals to the slave.

(Q) Explain MES~~II~~ protocol

Ans:

The MESI protocol is cache coherence protocol used in multiprocessor systems to ensure that all caches have a consistent view of memory.



## \* MESI stand for:

### (1) M - Modified

The Cache line has update data.

The data is different from the main memory

The only cache Abhart has <sup>this</sup> data

Must write back to memory before being replaced

### (2) E - Exclusive

The Cache line is same as main memory

It exists only in this cache

can be modified without telling others

### (3) S - shared

Data is same as main memory

may exist in multiple caches

Read-only state.

### (4) I - Invalid

The Cache line is not valid

Cannot be used.

## \* How it works?

Cache communicate with each other to update states when:

A CPU reads or writes data

A Cache line is replaced or invalidated.

## \* Why MESI is useful:

- Maintain data consistency across multiple cores
- Reduce unnecessary memory access
- Improve performance in multi-core processor

Q) Explain segment descriptor of 80386 processor?

Ans:

A segment descriptor is a 8-byte (64-bit) entry that provides detailed information about a memory segment.

It is used in protected mode to define the properties of code, data, stack segments.

|   |                       |   |   |   |                           |                        |
|---|-----------------------|---|---|---|---------------------------|------------------------|
| 7 | Base<br>(B31-B24)     | G | D | O | AV                        | Limit<br>(U19-U16)     |
| 5 | Access<br>right bytes |   |   |   | Base address<br>(B23-B16) |                        |
| 4 |                       |   |   |   |                           | Base address (B15-B16) |
| 3 |                       |   |   |   |                           | Limit (LS-LO)          |

It is 8 byte (64 bit) divided like this:

- (1) Base Address (32 bits) - starting address of segment
  - spread across bytes 3, 13, 4, and 7
- (2) Limit (20 bits) - size of segment
  - spread across bytes 0, 1, and part of 6
- (3) Access byte (1 byte) - tell if it's code/data, read/write allowed.
  - in byte 5

(4) Flags (G; D, AV):

G - Granularity

D - Default size

AV - Available for system

- in byte 6

Q) explain branch prediction mechanism of pentium processor

Ans:

The pentium processor uses a dynamic branch prediction method to improve performance by predicting outcomes of branch instruction. (like jumps or loops) before they are executed, this helps avoid delays in the instruction pipelines.

#### \* Why is it needed?

In pipeline CPU like pentium, if a branch (eg. jump) is misplaced/mispredicted, the pipeline must flush (clear instruction), which wastes time so predicting correctly improves speeds.



- + → branch was taken
- → Branch was not taken

pentium uses a 4-state branch prediction system based on a 2-bit counter.

to avoid changing prediction on a single incorrect guess.

| Hafe | Name               | Prediction      |
|------|--------------------|-----------------|
| 0    | Strongly not taken | Predict no jump |
| 1    | weakly not taken   | Predict no jump |
| 2    | weakly taken       | Predict jump    |
| 3    | Strongly taken     | Predict jump    |

- if predict is correct, stay in the same state
- if a prediction is wrong;
  - move one step toward the opposite prediction
  - this makes prediction stable and accurate