

8086

20 bits

16

$2^{20}$

$2^{10}$  - KB

$2^{20}$  - MB

$2^{30}$  - GB  
 $2^{40}$  - TB

8085

16

8

$2^{16}$

Address bus

Data bus

Main mem.

$$2^{20} = 2^6 \times 2^{10}$$

$$= 64 \text{ KB}.$$



17/01/2023

# chp.1 The Intel M.P.

## 8086 Architecture.

- 8086 Architecture
- Programmer's model.
- Functional pin diagram
- Memory segmentation.
- Memory Banks.
- Demultiplexing of address and data bus.
- Functioning of 8086 in min. and max. mode.
- Timing diagrams (imp.) (Read, Write, iowrite, ioread)
- Interrupt structure and its servicing .

### Features of 8086 processor:

- It is an enhanced version of 8088 processor by Intel in 19<sup>7</sup>
- 8086 processor supports 2 stages of pipelining - fetching and execution.
- The memory is divided into 4 segments - code, data, stack, extra.
- It has 64K I/O ports.
- There are total 14 registers of 16 bits.
- The enhanced version of instruction set ( $\times$  &  $\div$  can be done by 8086)
- It supports 2 operating modes - minimum (single m.p. will be operating) and maximum (suitable for multiple processors)
- It has instruction queue capable of storing 6 bytes of instruction from memory resulting in faster processing.

19/01/2023.

- It was the first 16 bit processor having 16 bit ALU, 16 bit registers and internal data bus resulting in faster processing.
- Available 3 versions depending on operating frequency - 5MHz, 8MHz, 10MHz.
- Single phase clock with 33% of duty cycle.
- It supports 256 vector interrupts.

o Comparison with 8086 processor of 8085.

| Parameters    | 8085                                 | 8086                              |
|---------------|--------------------------------------|-----------------------------------|
| → ALU size    | 8 bits                               | 16 bits                           |
| → Address bus | 16 bits                              | 20 bits                           |
| → Main mem.   | $2^{16}$                             | $2^{20}$                          |
| → Pipelining  | doesn't support pipelining           | supports two stages of pipelining |
| → Prefetch    | you will not find it                 | you will find 6 bytes of it       |
| → I/O         | supports 2 <sup>8</sup> i.e 256 I/Os | $2^{16}$                          |
| → Cost        | cheaper                              | costly                            |

o 8086 Architecture:

Bus Interface Unit : Functions

- segment reg. (1) Fetch Instruction
- Address generation L.U. (2) Calculate Physical Address.
- IP
- Prefetch generation queue (3) Manage 6 bytes of prefetch Queue



### Execution unit:

- general purpose reg.
- speed purpose reg.
- ALU
- status reg
- operand

### function

- (1) Execute instruction.
- (2) Perform Arithmetic/Logical operation.
- (3) Send requests to BIU to alter external devices.



o Memory segment:



- o Physical address calculation:  
Segment address  $\times$  10H + offset.

- o Segment registers:  
(1) Code segment:

- It is of 16 bit register.
- CS holds the base for code segment.
- CS holds all the instructions and programs.

$$\text{eg. } \text{CS} = 1234\text{H}$$

$$\begin{aligned}\text{Base of code segment} &= 1234\text{H} \times 10\text{H} \\ &= 12340\text{H}\end{aligned}$$



## Segments

### (2) Data segment:

- It is of 16 bits register.
- This segment is used to hold the general data.
- DS register holds 16 bits base address for this segment.
- SI register holds 16 bit offset address during the string operations.
- BX register is used to hold 16 bit offset for this segment.

### (3) Stack segment:

- This segment holds stack memory which operates in LIFO manner.
- SS register holds 16 bit of base address for stack.
- SP holds 16 bit offset address of the top of the stack.
- BP holds 16 bit offset address during random access.

### (4) Extra segment.

- This segment is used to hold general data.
- Additionally, it is used as destination during string operations
- DI holds the offset address during the string operation.
- ES holds the base address

### o Advantages of segmentation:

- It divides the memory logically to store instructions, data and stack separately.

→ It permits the programmer to access 1MB mem using 16 bit of address

- Instruction pointer (IP):

- It holds offset of the next instruction.
- IP is incremented after every current instruction is fetched.
- IP will get a new value whenever there is a branch instruction.

- Address Generation logic Unit (AGLU):

- This generates the physical address.
- Physical address = Segment address  $\times 10H$  + offset
- Left address shifted by one. address.  
and offset is added.

$$\text{eq. CS} = 1234H$$

$$IP = 0005H$$

calculate physical address.

- 6 Bytes prefetch Queue:

- 6 Byte FIFO RAM.
- This fetches the next instruction while executing the current one.
- This <sup>unit</sup> holds 6 instruction byte.
- This prefetch queue is refilled when at least 2 bytes are empty.
- This pipelining increases the efficiency of IP.
-



24/01/2023

- Execution Unit:
  - Decodes and execute instructions.
  - Perform arithmetic logic and internal data transfer operation.
  - Send request signal to BIU to access the external module.
  - It operates w.r.t. 'T states' (clock cycle).

Main components :

- General purpose register
- Special purpose registers.
- ALU
- Operand
- Flag register.

### (1) General Purpose Register:



- 8086 has 16 bit G.P.R.s - AX, BX, CX, DX.
- These are available to user.
- Access is req. for storing the values during program execution.
- All these GPRs can be divided into two separate 8 bit registers eg. AX - AL & AH.

→ Apart from holding the data, GPRs have specific functions.

31/01/2023

(2) Special Purpose Registers (16 bits).

(a) SP : It holds offset address of top of stack (out of memory locations operating in LIFO manner). SP is used with stack segment register to calculate physical address for stack segment. It is used during instructions like push, pop, CALL, RET instruction, etc.

(b) BP (Base Pointer (16 bits)) : It can hold offset address of any location in the stack segment. It is used to access random locations of the stack.

(c) Source Index (SI) : It is normally used to hold the offset address of the data segment. But it can be also used for other segments using segment overriding. It holds offset address of the source data in the data segment during string operation.

(d) Destination Index (DI) : It is normally used to hold offset address for extra segment but also can be used for other segments using segment overriding. It holds offset address of the destination of in extra segment during string operations.

Any 2 flags would be asked to define for 2 marks.



### (3) ALU:

- 8086 supports 16 bit ALU
- It performs 8 bit and 16 bit Arithmetic & Logical operations (enhancement - multiplication (MUL) & division (DIV) instructions).
- Control system: It is responsible to decode the I, which is already prefetched in prefetch Q. Generate appropriate internal control signals for execution purpose.

### (4) Operand:

- It is 16 bit register used by control register to hold the operands temporarily. (Exchange I.)
- Not visible to the user.

### \* (5) Flag register: control flags/control flag. 02/02/2023

Imp.

Q3      x x x x OF DF IF TF SF ZF x AF x PF x CF

OF: Overflow Flag

1 = overflow occurred

0 = NO overflow occurred.

TF: Trap flag

1 = Perform single

stepping

0 = Do not perform

single stepping

DF: Direction flag

1 = Auto Decrement

0 = Auto Increment

SF: Sign flag

1 = MSB of result is 1 (-ve)

Interrupt flag: IF

1 = Enable Interrupt

0 = MSB of result is 0 (+ve)

used for signed nos.)

ZF: Zero Flag

1 = Result = 0

0 = Result ≠ 0

PF: Parity Flag

1 = Even Parity

0 = Odd Parity

CF: Carry Flag

1 = Carry out of MSB

0 = No such carry

AF: Auxiliary Carry Flag

1 = Carry from lower

Nibble to higher nibble

0 = NO such carry  
(used in 8-bit operation)

Total 9 flags

status flags (6)

→ OF (f) → AF (l)

→ SF (e) → PF (b)

→ ZF (d) → CF (a)

control flags (3)

→ IF (g)

→ DF (h)

→ TF (i)

(a) Carry Flag (CF): Whenever there is a carry (or borrow), the carry flag is set to 1 out of the MSB of the result.

(b) Parity Flag (PF): It is set if the result has even parity.

(c) Auxiliary Flag (AF): It is set if the carry is generated out of the lower nibble. It is used only in 8 bits operations like DAA.



(a) Zero Flag (ZF): This flag will be set if the result is 0.

(b) Sign Flag (SF): It is set if MSB of result is 1. For signed operations, such a no. is treated as -ve.

(c) Overflow Flag (OF): It will be set if the result of the signed operation is too large to fit in the no. of bits available to represent it. It can be checked using instruction 'INTO' - Interrupt on Overflow.

e.g.    31H                  42H                  range : -80H to 7FH  
      23H                  44H  
      54H ✓                  86H X

(d) Interrupt Flag (IF): It is used to mask or disable 'INTR'-interrupts

(e) Direction Flag (DF): Associated with string operations. If this flag is set, SI and DI are in auto-decrement mode in string operations.

(f) Trap Flag (TF): This is generally used for debugging of programs. It is used to set trace mode i.e. start single stepping mode. Here, the MP is interrupted after every instruction so that program can be debugged.

- Programmer's Model / Software model:

All registers visible to the programmer

- All GPRs
- All segment registers

- All offset registers (SP, BP, purpose)

- Flag registers





07/02/2022



### (1) CLK - clock signal.

- This clock signal provides the basic timing for operation of processor by 8284 CLK generator
- It is symmetric sq. wave with 50% duty cycle.
- The range of frequency of different versions is 5MHz, 8MHz and 10MHz.

### (2) RESET :

- It is a system reset .
- It is an active high signal.
- When high, MP enters into reset state and terminates the current activity .
- It must be active for atleast 4 clock cycles to reset the MP.

#### Reset Set :

- Code set - FFFFH
- after address calc (Reset vector add.)  $\rightarrow$  FFFFOH
- BIOS( Booting ) program is stored here .

### (3) READY: (synchronisation purpose)

- This is an acknowledgement signal from slower I/O devices or memory .
- It is an active high signal
- When high, it indicates that the device is ready to transfer data .
- When low, the MP is in wait state .

(4) NMI - (NON-Maskable Interrupt)

- It is an active high
- It is an edge triggered interrupt

(5) INTR:

- It is interrupt request signal.
- It is active high
- It is level triggered.

(6) TEST

- It is used to test the status of math co-processor
- The BUSY pin of 8087 connected to this pin of 8086.

(7) MN / MX

- 8086 works in two modes
  - Min. mode
  - Max. mode
- If MN / MX is high, it works in minimum mode.
- If MN / MX is low, it works in maximum mode.

(8) V<sub>cc</sub> & V<sub>ss</sub>

- V<sub>cc</sub> is power supply.
- +5V DC is supplied to this pin.
- V<sub>ss</sub> is ground signal

- (9)  $AD_0$  to  $AD_{15}$  (Address & Data bus Multiplexed)
- These lines are multiplexed bi-directional add. / databus.
  - During  $T_1$ , they carry lower order 16-bit address.
  - In remaining clock cycles, they carry 16-bit data.
  - $AD_0$  -  $AD_7$  carry lower order byte of data.
  - $AD_8$  -  $AD_{15}$  carry higher order byte of data.

- (10)  $A_{19}/S_6$ ,  $A_{18}/S_5$ ,  $A_{17}/S_4$ ,  $A_{16}/S_3$
- These lines are multiplexed unidirectional address and status bus.
  - During  $T_1$ , they carry higher order 4-bit address.
  - In the remaining clock cycles, they carry status signals.

- (11) BHE / S<sub>7</sub>
- Bus High Enable
  - used to indicate the transfer of data over higher order databus ( $D_8$  -  $D_{15}$ )
  - 8-bit to 16 devices use this signal.
  - It is multiplexed with status pin  $S_7$ .

memory segmentation, advantages,  
need



14/02/23.

## o Memory Banking:



|   |   |                                      |
|---|---|--------------------------------------|
| 0 | 0 | Read or write 16 bit from both banks |
| 0 | 1 | " 8 bits from higher bank            |
| 1 | 0 | " lower bank                         |
| 1 | 1 | NO operation (processor is idle)     |

e.g. MOV BL, [2000H]

MOV BX, [2000H] (aligned operation)

MOV BH, [2001H]

MOV BX, [2001H] (misaligned operation)

MOV BL [2000H]

→ 8 bit operation

value stored at

→ BL will get content of offset address (2000H)

→ only one bank is selected (here lower/even)

→ BHE → 1, A<sub>0</sub> → 0.

MOV BX, [2000H] (aligned)

→ 16 bits

→ BX will get values stored at both 2000H & 2001H.

→ BHE → 0, A<sub>0</sub> → 0

→ Both banks will be selected.

## Pin Configuration for Mid Mode.

### (1) HOLD

- When DMA controller needs to use address bus, it sends zero, to CPU through the bus.
- active high signal.
- When UP receives HOLD signal, it issues HOLD signal to the DMA controller.

### (2) HLD#

- It is a hold acknowledgement signal
- Issued after receiving HOLD.
- It is an active high signal.

### (3) WE

- Write signal
- Used to write data in memory or output data depending upon the status of WE signal.
- Active low signal.

### (4) M1#

- This signal is issued by the UP to distinguish memory access from I/O access.
- When it is high memory is accessed.
- When low, I/O devices are accessed.

### (5) ET/R

- DMA Transmitter/receive signal (to precursor)
- It decides the direction of data flow through the transceiver.

- High → data is transmitted out
- Low → data is received

(6) DEN

- Data Enable signal.

(7) INTA

- Interrupt Acknowledge signal
- When CPU receives the INTA signal, it acknowledges the interrupt by generating this signal.
- Active low signal.

(8) ALE

- Address Latch Enable
- Indicates that valid address bus to -AD<sub>15</sub>-
- Connected to enable pin of latch 8222.

## Pin configuration for Min Mode.

### (1) HOLD

- When DMA controller needs to use address /data bus, it sends a req. to CPU through this pin.
- active high signal.
- When MP receives HOLD signal, it issues HLDA signal to the DMA controller.

### (2) HLDA

- It is a hold acknowledgement signal
- Issued after receiving HOLD.
- It is an active high signal.

### (3) WR

- Write signal
- Used to write data in memory or output data from device depending upon the status of M/I/O signal.
- Active low signal.

### (4) M/I $\bar{O}$

- The signal is issued by the MP to distinguish memory access from I/O access.
- When it is high memory is accessed
- When low, I/O devices are accessed.

### (5) DTLR

- Data Transmit / Receive signal (to processor)
- It decides the direction of data flow through the transceiver.



- High → data is transmitted out
- Low → data is received

(6) DEN

- Data Enable signal.

(7) INTA

- Interrupt Acknowledge signal
- When CPU receives INTA signal, it acknowledges the interrupt by generating this signal.
- Active LOW signal.

(8) ALE

- Address Latch Enable
- Indicates that valid address on bus  $AD_0 - AD_{15}$
- Connected to enable pin of latch 8282.

16/10/21 28

## • Minimum Mode Configuration





- Timing diagrams: (Terms):
  - $T_{state} = 1 / \text{clock frequency}$
  - Machine or Bus cycle = Time to execute one read or write cycle
  - Instruction cycle = Total time req. to fetch and Execute one Instruction (combination of Bus cycle).

### Significance of clock

- 8086 operates at 5MHz, 8MHz & 10MHz
- Read/write cycle in 8086 is of 4 clock cycles
- At 5MHz, one T state =  $\frac{1}{5} \text{MHz} = 200 \text{nsec}$   
80 Read/Write cycle =  $4 \times 200 = 800 \text{nsec}$
- At 8MHz, Read/Write cycle =  $4 \times 125 = 500 \text{nsec}$
- At 10 MHz, Read/Write cycle =  $4 \times 100 = 400 \text{nsec}$

### Read machine cycle





$\overline{RD}$

$\overline{WR}$

$\overline{DEN}$



## 8086 Interrupt

- special case / condition that arises during the working of the micro processor.
- HP service it by executing a subroutine call interrupt service routine.

|                            |           |                |                                |
|----------------------------|-----------|----------------|--------------------------------|
| 1KB (2 <sup>10</sup> ) * 4 | 00000 H   | IP lower byte  | INT 0 - Divide error           |
|                            | 00001 H   | IP higher byte |                                |
|                            | 00002 H   | CS lower byte  |                                |
|                            | 00003 H   | CS higher byte |                                |
|                            | 00004 H   |                | INT 1 - Single stepping        |
|                            | :         |                |                                |
|                            | 00007 H   |                |                                |
|                            | 00008 H   |                | INT 2 - NM                     |
|                            | :         |                |                                |
|                            | 0000B H   |                |                                |
|                            | 0000C H   |                | INT 3 - Breakpt.               |
|                            | :         |                |                                |
|                            | 0000F H   |                |                                |
|                            | 00010 H   |                | INT 4 - Interrupt on overflow. |
|                            | :         |                |                                |
|                            | 00013 H   |                |                                |
|                            | 00014 H   |                | INT 5 } Reserved               |
|                            | :         |                |                                |
|                            | 00017 F H |                | INT-31 } User defined          |
|                            | 00018 0 H |                | INT-32 }                       |
|                            | :         |                |                                |
|                            | 0003FF H  |                | INT-255 }                      |

# chp.2 Instruction set and Programming

## o Addressing modes: (Memory)

### (1) Immediate A.M.:

- Operand is specified in the instruction itself.
- eg. MOV CL, 0AH — Move 0AH into the lower byte of CL.

### (2) Register A.M.:

- Operands are registers i.e. they are specified through registers
- eg. MOV CL, DL.

### (3) Direct A.M.:

- Address of the operand is directly given in the instruction.

→ eg. MOV CL, [2000H] — Moves data from 2000H (16 bits → 20 bits) in the data segment CL.  
physical address = DS \* 10H + 2000H (offset address)  
 $PA = 5000H \times 10H + 2000H = 52000$

- eg. MOV CX, [2000H]

CX - 16 bits, PA will be calculated twice, once for lower byte and 2nd for upper byte.

(A) Indirect A.M.:

→ 1. Register I.A.M.:

Address of the operand is given using a register.

The address should be in register as operand.  
B10 calculates the P.A.

2. Register Relative addressing mode:

Address of the operand by is given by sum of register and displacement

eg.  $MOV CL, [BX+4]$  (constant) or  $MOV, 04H [BX]$ .  
 $\downarrow$   
Relative'

3. Base Indexed A.M.:

$BX^{(SI/DI)}$  Data seg., BP - stack seg..

only BX GPR's used for atleast address along with offset address registers.

segment to be operated by segment reg. and not by index register.  $BX + SI$   
 $BX + DI$

eg.  $MOV CL, [BX+SI]$

$BP + SI$

$MOV CL, [BP+SI]$

$PBP + DI$ .

- (4) Base Relative plus Indexed Addressing mode  
 eg.  $MOV CL, [BX + DI + 20]$   
 $MOV [BP + SI + 1000], CL$ .

### (5) Implied A.M.

→ operands are implied, not specified in instructions.  
 eg. STC - set the carry flag  
 CLD - clears the direction flag.

### o I/O Addressing Modes:

#### Direct

- 8 bits
- 00H to FFH
- 256 I/O port

#### Address

eg. IN AL, ATH



#### Indirect

- 16 bits
- 0000H to FFFFH
- 65536 I/O port Address

eg. ~~MOV DX, 2000H~~

~~IN AL, DX~~

IN AL, DX  
 move DX data to AL  
 AL gets data from I/O  
 port add. 2000H  
 given by DX.

### o Assembler Directive.

- It is a statement/reserved keyword to give direction to the assembler to perform task of the assembly process.
- Indicate how an operand or section of program is to be processed by the assembler

→ controls the organization of the program.  
→ provides necessary info. to the assembler to understand assembly lang. programs to generate necessary machine codes.  
→ An assembler supports directives to define data, to organize segments to control procedures.

(1) • MODEL: defines mem. model.

i - SMALL

ii - MEDIUM

iii - LARGE

(2) • DATA.

(3) • CODE - start code segment.

(4) • STACK - start stack segment.

(5) • DB - define byte

(6) • DW - define word

(7) SEGMENT, ENDS - end of the segment.

L beginning of code/data/stack/extr segment.

(8) ASSUME - informs name of program or data segment that should be used for a specific segment.

e.g. ASSUME CS CODE, DS DATA.

(9) ORG: (origin) used to assign the starting address for program / data in segment.

(10) END

(11) EVEN - even address start

(12) PROC - indicates beginning of a procedure

(13) ENDP - End of procedure

(14) FAR - Intersegment call

(15) NEAR - Intrasegment call



(16) AT: instruct the assembler to start the segment at  
5000H

- 8086 Instruction set:
  - ✓ Data Transfer
  - ✓ Arithmetic
  - ✓ Logical
  - ✓ String
  - ✓ Control transfer / Shift Rotate
  - ✓ Processor control