

Basic Features :

- (i) 8086 is 16-bit, N-channel, NMOS microprocessor.
- (ii) Its clock frequency is 4.5 MHz. Other versions have 8 MHz & 10 MHz clock frequency.
- (iii) This is 40 PIN IC Package.
- (iv) It has 20 address lines & 16 data lines.
- (v) Its memory space size is 1 MB ( $2^{20} = 1 \text{ MB}$ )
- (vi) The 16 lower order address lines are multiplexed with 16 data lines. and 4 higher order address lines are multiplexed with status signals.
- (vii) It has two mode of operations : MINIMUM MODE MAXIMUM MODE

PIN configuration :

8086 microprocessor has 40 pins. Among them below pins are very essential :

- (i) NMI : Non-Maskable Interrupt Request.
- (ii) INTR : interrupt request.
- (iii) BHE/S7 : Bus High Enable/status7. During T1 (of execution cycle) if it is low, it is used to enable data onto MSB half of data bus, D15-D8. S7 signal is available during T3-T4.
- (iv) TEST : Wait for test control. When it is low the CPU continues execution else waits.

Operating Modes : 8086 microprocessor has two modes: minimum & maximum mode. When only one 8086 CPU is to be used in a micro-computer system, the 8086 is used in minimum mode. In multi-processor system, it is used in maximum mode. There is MN/MX pin at 33 no. exists in 8086 chip. Which is used to select any of the two modes. Pin from 24 to 31 will be used differently for minimum or maximum mode operations.

When 8086 is operating in Minimum Mode then 24-31  
Pins are acting as follows -

- Pin 24  $\rightarrow$  INTA - Interrupt Acknowledgement
- Pin 25  $\rightarrow$  ALE - High at T<sub>1</sub>, Latching purpose
- Pin 26  $\rightarrow$  DEN - Data Enable when communicating with octal bus transceiver
- Pin 27  $\rightarrow$  DT/R - Data Transmit / Receive from 8086 up to other device.
- Pin 28  $\rightarrow$  M/IO - Memory related or Input output related operations.
- Pin 29  $\rightarrow$  WR - Writing to memory
- Pin 30  $\rightarrow$  HLDA - Hold acknowledgement
- Pin 31  $\rightarrow$  HOLD - Hold (DMA operations)

When 8086 is operating in Maximum mode then 24-31  
Pins are acting as follows  $\rightarrow$

| Pin 24 $\rightarrow$ | Pin 25 $\rightarrow$ | Instruction Queue Status      |
|----------------------|----------------------|-------------------------------|
|                      | 0 0 0                | No operation                  |
|                      | 0 0 1                | 1st byte of opcode from queue |
|                      | 0 1 0                | Empty the queue               |
|                      | 0 1 1                | Subsequent bytes of queue     |

| Pin 28-27-26 $\rightarrow$                                         | S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> | Operations            |
|--------------------------------------------------------------------|----------------------------------------------|-----------------------|
| These signals are connected with bus controller (Intel 8288)       | 0 0 0                                        | Interrupt Acknowledge |
| • 8288 Controller generates Memory or I/O related control signals. | 0 0 1                                        | Read from I/O port    |
|                                                                    | 0 1 0                                        | Write into I/O port   |
|                                                                    | 0 1 1                                        | Halt                  |
|                                                                    | 1 0 0                                        | opcode fetch          |
|                                                                    | 1 0 1                                        | Memory Read           |
|                                                                    | 1 1 0                                        | Memory Write          |
|                                                                    | 1 1 1                                        | Pasitive state        |

Pin 29  $\rightarrow$  LOCK  $\rightarrow$  To lock all operation of 8086 up.

Pin 30-31  $\rightarrow$  RQ/GT<sub>1</sub> - RQ/GT<sub>0</sub>  $\rightarrow$  used for controlling local Bus

## Functional Block Diagram of 8086 CPU →



# 8086 Contains two independent functional units : Bus Interface Unit (BIU) and an Execution Unit (EU).

Parts of BIU Unit :- The segment registers (ES, CS, DS, SS), instruction pointer (IP) & 6 byte instruction Queue.

Parts of Execution Unit :- The general purpose registers, stack pointer, base pointer & index registers, ALU, flags, timing & control unit, instruction decoder are the parts of EU.

Function of BIU Unit :- It controls transfer of data between microprocessor & I/O Devices or memory. It computes &

sends out addresses, fetches instruction codes, stores fetched instruction code into queue (IQ) [FIFO], reads data from memory or I/O Devices.

EU Unit tells BIU unit from where to fetch instruction or data :-

Function of EU Unit :- EU receives opcode of instruction from instruction queue (IQ), decodes it & executes. While EU is busy with decoding/executing the instruction, the BIU fetches the opcode of instruction from memory & put it into queue.

BIU & EU operate parallelly & independently. This makes processing faster. This technique is known as PIPELINING TECHNIQUE.

## Functional Block Diagram of 8086 CPU →



# 8086 contains two independent functional units : Bus Interface Unit (BIU) and an Execution Unit (EU).

Parts of BIU Unit :- The segment registers (ES, CS, DS, SS), instruction pointer (IP) & 6 byte instruction Queue.

Parts of Execution Unit :- The general purpose registers, stack pointer, base pointer & index registers, ALU, flags, timing & control unit, instruction decoder are the parts of EU.

Function of BIU Unit :- It controls transfer of data between microprocessor & I/O Devices or memory. It computes &

sends out addresses, fetches instruction codes, stores fetched instruction code into queue (IQ) [FIFO], reads data from memory or I/O Devices.

EU unit tells BIU unit from where to fetch instruction or data.

Function of EU Unit :- EU receives opcode of instruction from instruction queue (IQ), decodes it & executes. While EU is busy with decoding/executing the instruction, the BIU fetches the opcode of instruction from memory & put it into queue.

BIU & EU operate parallelly & independently. This makes processing faster. This technique is known as PIPELINING TECHNIQUE.

## Registers of Intel 8086



Register Organization of 8086 CPU

General Purpose register: 4 16bit general purpose registers are there. ( $A_x, B_x, C_x, D_x$ ). They are further divided into two parts ( $A_x = AH$  +  $AL$ )

Now,  $A_x$  known as - Accumulator,  $B_x$  - Base register for computation of memory address.  $C_x$  - used as Counter in multiplication instruction.  $D_x$  is used to hold data while transferring from I/O port to memory.

Pointer, Index Register: As shown in figure SP, BP, SI, DI are in this group. The function of SP is same as 8085. But other registers are used to calculate memory address.

Segment Register: There are four segment registers CS, DS, SS, ES.

In 8086 based system memory is divided into following four -  
Segments. 1. Code Segment - 2. Data Segment 3. Stack Segment 4. Extra Segment -  
The code segment holds instruction code of program. The data, variables, constants given in the program are stored in Data segment. The stack segment is used for stack handling purpose. The extra segment holds the destination address of some data or certain string. Now segment registers hold the starting add. of each instruction, New concept.

Instruction Pointer: It is acting as Program Counter. The functioning of this register is similar to PC of 8085. The content of GS are used to calculate memory address of instruction to be fetched.

New concept! ← same as 8085 rep. →

Status Register:

|   |   |   |   |    |    |    |    |    |    |   |    |   |    |   |    |
|---|---|---|---|----|----|----|----|----|----|---|----|---|----|---|----|
| x | x | x | x | OF | DF | IF | TF | SF | ZF | x | AF | x | PF | x | CF |
|---|---|---|---|----|----|----|----|----|----|---|----|---|----|---|----|

overflow → Direction → Trap Flag → Interrupt Enable → Sign → Zero → Auxiliary → Parity → Carry

Total 9 status registers. Among them 6 - Status register

3 - Control register

Control Registers → DF, IF, TF

Enable used in string operation. INTR mode

# 8086 Microprocessor

- It is a 16 bit μp.
- 8086 has a 20 bit address bus can access upto  $2^{20}$  memory locations ( 1 MB) .
- It can support upto 64K I/O ports.
- It provides 14, 16-bit registers.
- It has multiplexed address and data bus AD0-AD15 and A16 – A19.

# 8086 Microprocessor (cont..)

- 8086 is designed to operate in two modes, Minimum and Maximum.
- It can pre-fetches up to 6 instruction bytes from memory and queues them in order to speed up instruction execution.
- It requires +5V power supply.
- A 40 pin dual in line package.

# 8086 Microprocessor (cont..)

## Minimum and Maximum Modes:

- The minimum mode is selected by applying logic 1 to the MN / MX# input pin. This is a single microprocessor configuration.
- The maximum mode is selected by applying logic 0 to the MN / MX# input pin. This is a multi-microprocessors configuration.

# 8086 Microprocessor (cont..)



# Pin Diagram of 8086





# Internal Architecture of 8086

- 8086 has two blocks BIU and EU.
- The BIU performs all bus operations such as instruction fetching, reading and writing operands for memory and calculating the addresses of the memory operands.
- The instruction bytes are transferred to the instruction queue.
- EU executes instructions from the instruction system byte queue.

# Internal Architecture of 8086 (cont..)

- Both units operate asynchronously to give the 8086 an overlapping instruction fetch and execution mechanism which is called as Pipelining. This results in efficient use of the system bus and system performance.
- BIU contains Instruction queue, Segment registers, Instruction pointer, Address adder.
- EU contains Control circuitry, Instruction decoder, ALU, Pointer and Index register, Flag register.

# Internal Architecture of 8086 (cont..)

- Bus Interfacr Unit:
- It provides a full 16 bit bidirectional data bus and 20 bit address bus.
- The bus interface unit is responsible for performing all external bus operations.

*Specifically it has the following functions:*

- Instruction fetch, Instruction queuing, Operand fetch and storage, Address relocation and Bus control.
- The BIU uses a mechanism known as an instruction stream queue to implement a *pipeline architecture*.

# Internal Architecture of 8086 (cont..)

- This queue permits prefetch of up to six bytes of instruction code. Whenever the queue of the BIU is not full, it has room for at least two more bytes and at the same time the EU is not requesting it to read or write operands from memory, the BIU is free to look ahead in the program by prefetching the next sequential instruction.
- These prefetching instructions are held in its FIFO queue. With its 16 bit data bus, the BIU fetches two instruction bytes in a single memory cycle.
- After a byte is loaded at the input end of the queue, it automatically shifts up through the FIFO to the empty location nearest the output.

# Internal Architecture of 8086 (cont..)

- The EU accesses the queue from the output end. It reads one instruction byte after the other from the output of the queue.
- If the queue is full and the EU is not requesting access to operand in memory, These intervals of no bus activity, which may occur between bus cycles are known as *Idle state*.
- If the BIU is already in the process of fetching an instruction when the EU request it to read or write operands from memory or I/O, the BIU first completes the instruction fetch bus cycle before initiating the operand read / write cycle.

# Internal Architecture of 8086 (cont..)

- The BIU also contains a dedicated adder which is used to generate the 20 bit physical address that is output on the address bus. This address is formed by adding an appended 16 bit segment address and a 16 bit offset address.
- For example, the physical address of the next instruction to be fetched is formed by combining the current contents of the code segment CS register and the current contents of the instruction pointer IP register.
- The BIU is also responsible for generating bus control signals such as those for memory read or write and I/O read or write.

# Internal Architecture of 8086 (cont..)

- **EXECUTION UNIT** : The Execution unit is responsible for decoding and executing all instructions.
- The EU extracts instructions from the top of the queue in the BIU, decodes them, generates operands if necessary, passes them to the BIU and requests it to perform the read or write cycles to memory or I/O and perform the operation specified by the instruction on the operands.
- During the execution of the instruction, the EU tests the status and control flags and updates them based on the results of executing the instruction.

# Internal Architecture of 8086 (cont..)

- If the queue is empty, the EU waits for the next instruction byte to be fetched and shifted to top of the queue.
- When the EU executes a branch or jump instruction, it transfers control to a location corresponding to another set of sequential instructions.
- Whenever this happens, the BIU automatically resets the queue and then begins to fetch instructions from this new location to refill the queue.

# Internal Architecture of 8086 (cont..)

| COMMON SIGNALS                 |                                               |                                   |
|--------------------------------|-----------------------------------------------|-----------------------------------|
| Name                           | Function                                      | Type                              |
| <b>AD 15– AD 0</b>             | <b>Address/ Data Bus</b>                      | <b>Bidirectional<br/>3- state</b> |
| <b>A19 / S6– A16/S3</b>        | <b>Address / Status</b>                       | <b>Output 3- State</b>            |
| <b><u>BHE</u> / <u>S 7</u></b> | <b>Bus High Enable /<br/>Status</b>           | <b>Output<br/>3- State</b>        |
| <b>MN/MX</b>                   | <b>Minimum /<br/>Maximum Mode<br/>Control</b> | <b>Input</b>                      |
| <b><u>RD</u></b>               | <b>Read Control</b>                           | <b>Output 3- State</b>            |
| <b>TEST</b>                    | <b>Wait On Test Control</b>                   | <b>Input</b>                      |
| <b>READY</b>                   | <b>Wait State Controls</b>                    | <b>Input</b>                      |
| <b>RESET</b>                   | <b>System Reset</b>                           | <b>Input</b>                      |
| <b>NMI</b>                     | <b>Non - Maskable<br/>Interrupt Request</b>   | <b>Input</b>                      |
| <b>INTR</b>                    | <b>Interrupt Request</b>                      | <b>Input</b>                      |
| <b>CLK</b>                     | <b>System Clock</b>                           | <b>Input</b>                      |
| <b>Vcc</b>                     | <b>+ 5 V</b>                                  |                                   |
| <b>GND</b>                     | <b>Ground</b>                                 | <b>Input</b>                      |

# Internal Architecture of 8086 (cont..)

| Minimum Mode Signals<br>( $MN / \overline{MX} = Vcc$ ) |                                                           |                            |
|--------------------------------------------------------|-----------------------------------------------------------|----------------------------|
| Name                                                   | Function                                                  | Type                       |
| <b>HOLD</b>                                            | <b>Hold Request</b>                                       | <b>Input</b>               |
| <b>HLDA</b>                                            | <b>Hold Acknowledge</b>                                   | <b>Output</b>              |
| <b><math>\overline{WR}</math></b>                      | <b>Write Control</b>                                      | <b>Output,<br/>3-state</b> |
| <b><math>\overline{M/IO}</math></b>                    | <b>Memory or IO Control</b>                               | <b>Output,<br/>3-State</b> |
| <b><math>\overline{DT/R}</math></b>                    | <b>Data Transmit<br/>Receiver /</b><br><b>Date Enable</b> | <b>Output,<br/>3-State</b> |
| <b>DEN</b>                                             |                                                           | <b>Output,<br/>3-State</b> |
| <b>ALE</b>                                             | <b>Address Latch Enable</b>                               | <b>Output</b>              |
| <b><math>\overline{INTA}</math></b>                    | <b>Interrupt Acknowledge</b>                              | <b>Output</b>              |

# Internal Architecture of 8086 (cont..)

| Maximum mode signals ( MN / MX = GND ) |                                           |                             |
|----------------------------------------|-------------------------------------------|-----------------------------|
| Name                                   | Function                                  | Type                        |
| <b>RQ / GT1, 0</b>                     | <b>Request / Grant Bus Access Control</b> | <b>Bidirectional</b>        |
| <b>LOCK</b>                            | <b>Bus Priority Lock Control</b>          | <b>Output,<br/>3- State</b> |
| <b>S2– S0</b>                          | <b>Bus Cycle Status</b>                   | <b>Output,<br/>3- State</b> |
| <b>QS1, QS0</b>                        | <b>Instruction Queue Status</b>           | <b>Output</b>               |

# Minimum Mode Interface

- When the Minimum mode operation is selected, the 8086 provides all control signals needed to implement the memory and I/O interface.
- The minimum mode signal can be divided into the following basic groups : address/data bus, status, control, interrupt and DMA.
- **Address/Data Bus** : these lines serve two functions. As an address bus is 20 bits long and consists of signal lines A<sub>0</sub> through A<sub>19</sub>. A<sub>19</sub> represents the MSB and A<sub>0</sub> LSB. A 20bit address gives the 8086 a 1Mbyte memory address space.

## Minimum Mode Interface ( cont..)

- The 16 data bus lines D<sub>0</sub> through D<sub>15</sub> are actually multiplexed with address lines A<sub>0</sub> through A<sub>15</sub> respectively. By multiplexed we mean that the bus work as an address bus during first machine cycle and as a data bus during next machine cycles. D<sub>15</sub> is the MSB and D<sub>0</sub> LSB.
- When acting as a data bus, they carry read/write data for memory, input/output data for I/O devices, and interrupt type codes from an interrupt controller.

# Minimum Mode Interface ( cont..)



Block Diagram of the Minimum Mode 8086 MPU

# Minimum Mode Interface ( cont..)

- **Status signal** : The four most significant address lines A19 through A16 are also multiplexed but in this case with status signals S<sub>6</sub> through S<sub>3</sub>. These status bits are output on the bus at the same time that data are transferred over the other bus lines.
- Bit S<sub>4</sub> and S<sub>3</sub> together from a 2 bit binary code that identifies which of the 8086 internal segment registers are used to generate the physical address that was output on the address bus during the current bus cycle.
- Code S<sub>4</sub>S<sub>3</sub> = 00 identifies a register known as *extra segment register* as the source of the segment address.

# Minimum Mode Interface ( cont..)

| S <sub>4</sub> | S <sub>3</sub> | Segment Register |
|----------------|----------------|------------------|
| 0              | 0              | <b>Extra</b>     |
| 0              | 1              | <b>Stack</b>     |
| 1              | 0              | <b>Code</b>      |
| 1              | 1              | <b>Data</b>      |

Memory segment status codes.

# Minimum Mode Interface ( cont..)

- Status line S<sub>5</sub> reflects the status of another internal characteristic of the 8086. It is the logic level of the internal enable flag. The last status bit S<sub>6</sub> is always at the logic 0 level.
- **Control Signals** : The control signals are provided to support the 8086 memory, I/O interfaces. They control functions such as when the bus is to carry a valid address in which direction data are to be transferred over the bus, when valid write data are on the bus and when to put read data on the system bus.

## Minimum Mode Interface ( cont..)

- ALE is a pulse to logic 1 that signals external circuitry when a valid address word is on the bus. This address must be latched in external circuitry.
- Another control signal that is produced during the bus cycle is BHE bus high enable. These lines also serves a second function, which is as the S7 status line.
- Using the M/IO and DT/R lines, the 8086 signals which type of bus cycle is in progress and in which direction data are to be transferred over the bus.

## Minimum Mode Interface ( cont..)

- The logic level of  $\overline{M/IO}$  tells external circuitry whether a memory or I/O transfer is taking place over the bus. Logic 0 at this output signals a memory operation and logic 1 an I/O operation.
- The direction of data transfer over the bus is signaled by the logic level output at DT/R. When this line is logic 1 during the data transfer part of a bus cycle, the bus is in the transmit mode. Therefore, data are either written into memory or output to an I/O device.
- On the other hand, logic 0 at DT/R signals that the bus is in the receive mode. This corresponds to reading data from memory or input of data from an input port.

## Minimum Mode Interface ( cont..)

- The signal read  $\overline{RD}$  and write  $WR$  indicates that a read bus cycle or a write bus cycle is in progress. The 8086 switches  $WR$  to logic 0 to signal external device that valid write or output data are on the bus.
- On the other hand,  $\overline{RD}$  indicates that the 8086 is performing a read of data of the bus. During read operations, one other control signal is also supplied. This is  $DEN$  ( data enable) and it signals external devices when they should put data on the bus.
- There is one other control signal that is involved with the memory and I/O interface. This is the  $READY$  signal.

## Minimum Mode Interface ( cont..)

- READY signal is used to insert wait states into the bus cycle such that it is extended by a number of clock periods. This signal is provided by an external clock generator device and can be supplied by the memory or I/O sub-system to signal the 8086 when they are ready to permit the data transfer to be completed.
- **Interrupt signals** : The key interrupt interface signals are interrupt request (INTR) and interrupt acknowledge (INTA).
- INTR is an input to the 8086 that can be used by an external device to signal that it need to be serviced.

# Minimum Mode Interface ( cont..)

- Logic 1 at INTR represents an active interrupt request.  
When an interrupt request has been recognized by the 8086, it indicates this fact to external circuit with pulse to logic 0 at the INTA output.
-

---

## Minimum Mode Interface ( cont..)

- There are two more inputs in the interrupt interface: the nonmaskable interrupt NMI and the reset interrupt RESET.
  - On the 0-to-1 transition of NMI control is passed to a nonmaskable interrupt service routine. The RESET input is used to provide a hardware reset for the 8086. Switching RESET to logic 0 initializes the internal register of the 8086 and initiates a reset service routine.
-

# Minimum Mode Interface.

- **DMA Interface signals** :The direct memory access DMA interface of the 8086 minimum mode consist of the HOLD and HLDA signals.
- When an external device wants to take control of the system bus, it signals to the 8086 by switching HOLD to the logic 1 level. The 8086 signals external device that it is in this state by switching its HLDA output to logic 1 level.

# Maximum Mode Interface

- When the 8086 is set for the maximum-mode configuration, it provides signals for implementing a multiprocessor / coprocessor system environment.
- Usually in this type of system environment, there are some system resources that are common to all processors.
- They are called as *global resources*.

# Maximum Mode Interface (cont..)

- Coprocessor means that there is a second processor in the system. In this two processor does not access the bus at the same time.
- One passes the control of the system bus to the other and then may suspend its operation.
- In the maximum-mode 8086 system, facilities are provided for implementing allocation of global resources and passing bus control to other microprocessor or coprocessor.



# Maximum Mode Interface (cont..)

- **8288 Bus Controller – Bus Command and Control Signals:** 8086 does not directly provide all the signals that are required to control the memory, I/O and interrupt interfaces.
- Specially the WR, M/IO, DT/R, DEN, ALE and INTA, signals are no longer produced by the 8086. Instead it outputs three status signals S<sub>0</sub>,  $\bar{S}_1$ , S<sub>2</sub> prior to the initiation of each bus cycle. This 3- bit bus status code identifies which type of bus cycle is to follow.
- S<sub>2</sub>S<sub>1</sub>S<sub>0</sub> are input to the external bus controller device, the bus controller generates the appropriately timed command and control signals.

# Maximum Mode Interface (cont..)

| Status Inputs    |                  |                  | CPU Cycles            | 8288                       |
|------------------|------------------|------------------|-----------------------|----------------------------|
| $\overline{S_2}$ | $\overline{S_1}$ | $\overline{S_0}$ |                       | Command                    |
| 0                | 0                | 0                | Interrupt Acknowledge | <u>INTA</u>                |
| 0                | 0                | 1                | Read I/O Port         | <u>IORC</u>                |
| 0                | 1                | 0                | Write I/O Port        | <u>IOWC</u> , <u>AIOWC</u> |
| 0                | 1                | 1                | Halt                  | <u>None</u>                |
| 1                | 0                | 0                | Instruction Fetch     | <u>MRDC</u>                |
| 1                | 0                | 1                | Read Memory           | <u>MRDC</u>                |
| 1                | 1                | 0                | Write Memory          | <u>MWTC</u> , <u>AMWC</u>  |
| 1                | 1                | 1                | Passive               | <u>None</u>                |

## Bus Status Codes

# Maximum Mode Interface (cont..)

- The 8288 produces one or two of these eight command signals for each bus cycles. For instance, when the 8086 outputs the code  $S_2S_1S_0$  equals 001, it indicates that an *I/O read cycle* is to be performed.
- In the code 111 is output by the 8086, it is signaling that no bus activity is to take place.
- The control outputs produced by the 8288 are DEN, DT/ $\bar{R}$  and ALE. These 3 signals provide the same functions as those described for the minimum system mode. This set of bus commands and control signals is compatible with the Multibus and industry standard for interfacing microprocessor systems.

# Maximum Mode Interface (cont..)

- **8289 Bus Arbiter – Bus Arbitration and Lock Signals :**  
This device permits processors to reside on the system bus. It does this by implementing the Multibus arbitration protocol in an 8086-based system.
- Addition of the 8288 bus controller and 8289 bus arbiter frees a number of the 8086 pins for use to produce control signals that are needed to support multiple processors.
- Bus priority lock ( LOCK) is one of these signals. It is input to the bus arbiter together with status signals  $\bar{S}_0$  through  $\bar{S}_2$ .

# Maximum Mode Interface (cont..)

- *The output of 8289 are bus arbitration signals: bus busy (BUSY), common bus request (CBRQ), bus priority out (BPRO), bus priority in (BPRN), bus request (BREQ) and bus clock (BCLK).*
- They correspond to the bus exchange signals of the Multibus and are used to lock other processor off the system bus during the execution of an instruction by the 8086.
- In this way the processor can be assured of uninterrupted access to common system resources such as *global memory*.

# Maximum Mode Interface (cont..)

- **Queue Status Signals** : Two new signals that are produced by the 8086 in the maximum-mode system are queue status outputs  $QS_0$  and  $QS_1$ . Together they form a 2-bit queue status code,  $QS_1QS_0$ .
- Following table shows the four different queue status.

# Maximum Mode Interface (cont..)

| QS <sub>1</sub> | QS <sub>0</sub> | Queue Status                                                                                          |
|-----------------|-----------------|-------------------------------------------------------------------------------------------------------|
| 0 (low)         | 0               | No Operation. During the last clock cycle, nothing was taken from the queue.                          |
| 0               | 1               | First Byte. The byte taken from the queue was the first byte of the instruction.                      |
| 1 (high)        | 0               | Queue Empty. The queue has been reinitialized as a result of the execution of a transfer instruction. |
| 1               | 1               | Subsequent Byte. The byte taken from the queue was a subsequent byte of the instruction.              |

Queue status codes

# Maximum Mode Interface (cont..)

- **Local Bus Control Signal – Request / Grant Signals:** In a maximum mode configuration, the minimum mode HOLD, HLDA interface is also changed. These two are replaced by request/grant lines RQ/ GT<sub>0</sub> and RQ/ GT<sub>1</sub>, respectively. They provide a prioritized bus access mechanism for accessing the local bus.

# Minimum Mode 8086 System

- In a minimum mode 8086 system, the microprocessor 8086 is operated in minimum mode by strapping its MN/MX pin to logic 1.
- In this mode, all the control signals are given out by the microprocessor chip itself. There is a single microprocessor in the minimum mode system.
- The remaining components in the system are latches, transreceivers, clock generator, memory and I/O devices.

# Minimum Mode 8086 System (cont..)

- Latches are generally buffered output D-type flip-flops like 74LS373 or 8282. They are used for separating the valid address from the multiplexed address/data signals and are controlled by the ALE signal generated by 8086.

---

## Minimum Mode 8086 System (cont..)

- . The DEN signal indicates the direction of data, i.e. from or to the processor.

## Minimum Mode 8086 System (cont..)

- The clock generator generates the clock from the crystal oscillator and then shapes it and divides to make it more precise so that it can be used as an accurate timing reference for the system.
- The clock generator also synchronizes some external signal with the system clock. The general system organisation is as shown in below fig.
- It has 20 address lines and 16 data lines, the 8086 CPU requires three octal address latches and two octal data buffers for the complete address and data separation.

# Minimum Mode 8086 System (cont..)

- The working of the minimum mode configuration system can be better described in terms of the timing diagrams rather than qualitatively describing the operations.
- The opcode fetch and read cycles are similar. Hence the timing diagram can be categorized in two parts, the first is the timing diagram for read cycle and the second is the timing diagram for write cycle.
- The read cycle begins in T<sub>1</sub> with the assertion of address latch enable (ALE) signal and also M / IO signal. During the negative going edge of this signal, the valid address is latched on the local bus.

## Minimum Mode 8086 System (cont..)

- The BHE and A<sub>0</sub> signals address low, high or both bytes. From T<sub>1</sub> to T<sub>4</sub>, the M/IO signal indicates a memory or I/O operation.
- At T<sub>2</sub>, the address is removed from the local bus and is sent to the output. The bus is then tristated. The read (RD) control signal is also activated in T<sub>2</sub>.
- The read (RD) signal causes the address device to enable its data bus drivers. After RD goes low, the valid data is available on the data bus.
- The addressed device will drive the READY line high. When the processor returns the read signal to high level, the addressed device will again tristate its bus drivers.

# Minimum Mode 8086 System (cont..)

- A write cycle also begins with the assertion of ALE and the emission of the address. The M/IO signal is again asserted to indicate a memory or I/O operation. In T<sub>2</sub>, after sending the address in T<sub>1</sub>, the processor sends the data to be written to the addressed location.
- The data remains on the bus until middle of T<sub>4</sub> state. The WR becomes active at the beginning of T<sub>2</sub> (unlike RD is somewhat delayed in T<sub>2</sub> to provide time for floating).
- The BHE and A<sub>0</sub> signals are used to select the proper byte or bytes of memory or I/O word to be read or write.
- The M/IO, RD and WR signals indicate the type of data transfer as specified in table below.

# Minimum Mode 8086 System (cont..)

| M / $\overline{IO}$ | $\overline{RD}$ | $\overline{WR}$ | Transfer Type |
|---------------------|-----------------|-----------------|---------------|
| 0                   | 0               | 1               | I / O read    |
| 0                   | 1               | 0               | I/O write     |
| 1                   | 0               | 1               | Memory read   |
| 1                   | 1               | 0               | Memory write  |

Data Transfer table

# Minimum Mode 8086 System (cont..)



Read Cycle Timing Diagram for Minimum Mode

# Minimum Mode 8086 System (cont..)



Write Cycle Timing Diagram for Minimum Mode

# Maximum Mode 8086 System ( cont..)



Memory Read Timing in Maximum Mode

# Maximum Mode 8086 System ( cont..)



Memory Write Timing in Maximum mode.

# Internal Registers of 8086 (cont..)

- The 8086 has four groups of the user accessible internal registers. They are the instruction pointer, four data registers, four pointer and index register, four segment registers.
- The 8086 has a total of fourteen 16-bit registers including a 16 bit register called the *status register*, with 9 of bits implemented for status and control flags.

- Most of the registers contain data/instruction offsets within 64 KB memory segment. There are four different 64 KB segments for instructions, stack, data and extra data. To specify where in 1 MB of processor memory these 4 segments are located the processor uses four segment registers:
- **Code segment (CS)** is a 16-bit register containing address of 64 KB segment with processor instructions. The processor uses CS segment for all accesses to instructions referenced by instruction pointer (IP) register. CS register cannot be changed directly. The CS register is automatically updated during far jump, far call and far return instructions.

- **Stack segment (SS)** is a 16-bit register containing address of 64KB segment with program stack. By default, the processor assumes that all data referenced by the stack pointer (SP) and base pointer (BP) registers is located in the stack segment. **SS register can be changed directly using POP instruction.**
- **Data segment (DS)** is a 16-bit register containing address of 64KB segment with program data. By default, the processor assumes that all data referenced by general registers (AX, BX, CX, DX) and index register (SI, DI) is located in the data segment. **DS register can be changed directly using POP and LDS instructions.**

- **Extra segment (ES)** is a 16-bit register containing address of 64KB segment, usually with program data. By default, the processor assumes that the DI register references the ES segment in string manipulation instructions. ES register can be changed directly using POP and LES instructions.
- It is possible to change default segments used by general and index registers by prefixing instructions with a CS, SS, DS or ES prefix.
- All general registers of the 8086 microprocessor can be used for arithmetic and logic operations. The general registers are:

- **Accumulator** register consists of two 8-bit registers AL and AH, which can be combined together and used as a 16-bit register AX. AL in this case contains the low-order byte of the word, and AH contains the high-order byte. Accumulator can be used for I/O operations and string manipulation.
- **Base** register consists of two 8-bit registers BL and BH, which can be combined together and used as a 16-bit register BX. BL in this case contains the low-order byte of the word, and BH contains the high-order byte. **BX register** usually contains a data pointer used for based, based indexed or register indirect addressing.

- **Count** register consists of two 8-bit registers CL and CH, which can be combined together and used as a 16-bit register CX. When combined, CL register contains the low-order byte of the word, and CH contains the high-order byte. Count register can be used in Loop, shift/rotate instructions and as a counter in string manipulation,.
- **Data** register consists of two 8-bit registers DL and DH, which can be combined together and used as a 16-bit register DX. When combined, DL register contains the low-order byte of the word, and DH contains the high-order byte. Data register can be used as a port number in I/O operations. In integer 32-bit multiply and divide instruction the DX register contains high-order word of the initial or resulting number.

- The following registers are both general and index registers:
- **Stack Pointer (SP)** is a 16-bit register pointing to program stack.
- **Base Pointer (BP)** is a 16-bit register pointing to data in stack segment. BP register is usually used for based, based indexed or register indirect addressing.
- **Source Index (SI)** is a 16-bit register. SI is used for indexed, based indexed and register indirect addressing, as well as a source data address in string manipulation instructions.

- **Destination Index (DI)** is a 16-bit register. DI is used for indexed, based indexed and register indirect addressing, as well as a destination data address in string manipulation instructions.

Other registers:

- **Instruction Pointer (IP)** is a 16-bit register.
- **Flags** is a 16-bit register containing 9 one bit flags.
- **Overflow Flag (OF)** - set if the result is too large positive number, or is too small negative number to fit into destination operand.

- **Direction Flag (DF)** - if set then string manipulation instructions will auto-decrement index registers. If cleared then the index registers will be auto-incremented.
- **Interrupt-enable Flag (IF)** - setting this bit enables maskable interrupts.
- **Single-step Flag (TF)** - if set then single-step interrupt will occur after the next instruction.
- **Sign Flag (SF)** - set if the most significant bit of the result is set.
- **Zero Flag (ZF)** - set if the result is zero.

# **8086 Microprocessor**

| Register | Name of the Register      | Special Function                                                                                         |
|----------|---------------------------|----------------------------------------------------------------------------------------------------------|
| AX       | <b>16-bit Accumulator</b> | <b>Stores the 16-bit results of arithmetic and logic operations</b>                                      |
| AL       | <b>8-bit Accumulator</b>  | <b>Stores the 8-bit results of arithmetic and logic operations</b>                                       |
| BX       | <b>Base register</b>      | <b>Used to hold base value in base addressing mode to access memory data</b>                             |
| CX       | <b>Count Register</b>     | <b>Used to hold the count value in SHIFT, ROTATE and LOOP instructions</b>                               |
| DX       | <b>Data Register</b>      | <b>Used to hold data for multiplication and division operations</b>                                      |
| SP       | <b>Stack Pointer</b>      | <b>Used to hold the offset address of top stack memory</b>                                               |
| BP       | <b>Base Pointer</b>       | <b>Used to hold the base value in base addressing using SS register to access data from stack memory</b> |
| SI       | <b>Source Index</b>       | <b>Used to hold index value of source operand (data) for string instructions</b>                         |
| DI       | <b>Data Index</b>         | <b>Used to hold the index value of destination operand (data) for string operations</b>                  |

# **ADDRESSING MODES**

**&**

# **Instruction set**

# Introduction

```
; PROGRAM TO ADD TWO 16-BIT DATA (METHOD-1)

DATA SEGMENT ;Assembler directive
    ORG 1104H ;Assembler directive
    SUM DW 0 ;Assembler directive
    CARRY DB 0 ;Assembler directive
DATA ENDS ;Assembler directive
CODE SEGMENT ;Assembler directive
    ASSUME CS:CODE ;Assembler directive
    ASSUME DS:DATA ;Assembler directive
    ORG 1000H ;Assembler directive
    MOV AX,205AH ;Load the first data in AX register
    MOV BX,40EDH ;Load the second data in BX register
    MOV CL,00H ;Clear the CL register for carry
    ADD AX,BX ;Add the two data, sum will be in AX
    MOV SUM,AX ;Store the sum in memory location (1104H)
    JNC AHEAD ;Check the status of carry flag
    INC CL ;If carry flag is set, increment CL by one
    AHEAD: MOV CARRY,CL ;Store the carry in memory location (1106H)
    HLT
CODE ENDS ;Assembler directive
END ;Assembler directive
```

**Program**  
**A set of instructions written to solve a problem.**

**Instruction**  
**Directions which a microprocessor follows to execute a task or part of a task.**



## ■ Binary bits

- English Alphabets
- 'Mnemonics'
- Assembler
- Mnemonics → Machine Language

# **ADDRESSING MODES**

# Addressing Modes

- Every instruction of a program has to operate on a data.
- The different ways in which a source operand is denoted in an instruction are known as addressing modes.

1. Register Addressing

**Group I : Addressing modes for register and immediate data**

2. Immediate Addressing

3. Direct Addressing

4. Register Indirect Addressing

5. Based Addressing

6. Indexed Addressing

**Group II : Addressing modes for memory data**

7. Based Index Addressing

8. String Addressing

9. Direct I/O port Addressing

**Group III : Addressing modes for I/O ports**

10. Indirect I/O port Addressing

11. Relative Addressing

**Group IV : Relative Addressing mode**

12. Implied Addressing

**Group V : Implied Addressing mode**

**1. Register Addressing****2. Immediate Addressing****3. Direct Addressing****4. Register Indirect Addressing****5. Based Addressing****6. Indexed Addressing****7. Based Index Addressing****8. String Addressing****9. Direct I/O port Addressing****10. Indirect I/O port Addressing****11. Relative Addressing****12. Implied Addressing**

The instruction will specify the name of the register which holds the data to be operated by the instruction.

**Example:**

**MOV CL, DH**

The content of 8-bit register DH is moved to another 8-bit register CL

$(CL) \leftarrow (DH)$

|    |    |    |   |
|----|----|----|---|
| 15 | 8  | 7  | 0 |
| AX | AH | AL |   |
| BX | BH | BL |   |
| CX | CH | CL |   |
| DX | DH | DL |   |

|               |   |
|---------------|---|
| 15            | 0 |
| SP            |   |
| BP            |   |
| DI            |   |
| SI            |   |
| Flag Register |   |

EU

|    |   |
|----|---|
| 15 | 0 |
| IP |   |

|    |   |
|----|---|
| 15 | 0 |
| CS |   |
| DS |   |
| SS |   |
| ES |   |

BIU

**1. Register Addressing****2. Immediate Addressing****3. Direct Addressing****4. Register Indirect Addressing****5. Based Addressing****6. Indexed Addressing****7. Based Index Addressing****8. String Addressing****9. Direct I/O port Addressing****10. Indirect I/O port Addressing****11. Relative Addressing****12. Implied Addressing**

**In immediate addressing mode, an 8-bit or 16-bit data is specified as part of the instruction**

**Example:**

**MOV DL, 08H**

The 8-bit data ( $08_H$ ) given in the instruction is moved to DL

$(DL) \leftarrow 08_H$

**MOV AX, 0A9FH**

The 16-bit data ( $0A9F_H$ ) given in the instruction is moved to AX register

$(AX) \leftarrow 0A9F_H$



# Addressing Modes : Memory Access

- 20 Address lines  $\Rightarrow$  8086 can address up to  $2^{20} = 1\text{M}$  bytes of memory
- However, the largest register is only 16 bits
- Physical Address will have to be calculated  
**Physical Address** : Actual address of a byte in memory. i.e. the value which goes out onto the address bus.
- Memory Address represented in the form –  
**Seg : Offset** (Eg - 89AB:F012)
- Each time the processor wants to access memory, it takes the contents of a segment register, shifts it one hexadecimal place to the left (same as multiplying by  $16_{10}$ ), then add the required offset to form the 20-bit address



16 bytes of contiguous memory

89AB : F012  $\rightarrow$  89AB  $\rightarrow$  89AB0 (Paragraph to byte  $\rightarrow 89AB \times 10 = 89AB0$ )  
 F012  $\rightarrow$  0F012 (Offset is already in byte unit)  
 + -----  
 98AC2 (The absolute address)

**1. Register Addressing****2. Immediate Addressing****3. Direct Addressing****4. Register Indirect Addressing****5. Based Addressing****6. Indexed Addressing****7. Based Index Addressing****8. String Addressing****9. Direct I/O port Addressing****10. Indirect I/O port Addressing****11. Relative Addressing****12. Implied Addressing**

Here, the effective address of the memory location at which the data operand is stored is given in the instruction.

The effective address is just a 16-bit number written directly in the instruction.

**Example:**

```
MOV BX, [1354H]
MOV BL, [0400H]
```

The square brackets around the  $1354H$  denotes the contents of the memory location. When executed, this instruction will copy the contents of the memory location into BX register.

This addressing mode is called direct because the displacement of the operand from the segment base is specified directly in the instruction.

1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing



In Register indirect addressing, name of the register which holds the effective address (EA) will be specified in the instruction.

Registers used to hold EA are any of the following registers:

**BX, BP, DI and SI.**

Content of the DS register is used for base address calculation.

**Example:**

**MOV CX, [BX]**

**Operations:**

$$EA = (BX)$$

$$BA = (DS) \times 16_{10}$$

$$MA = BA + EA$$

Note : Register/ memory enclosed in brackets refer to content of register/ memory

$$(CX) \leftarrow (MA) \text{ or,}$$

$$(CL) \leftarrow (MA)$$

$$(CH) \leftarrow (MA + 1)$$

# Addressing Modes

Group II : Addressing modes  
for memory data

1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing



In Based Addressing, **BX or BP** is used to hold the base value for effective address and a signed 8-bit or unsigned 16-bit displacement will be specified in the instruction.

In case of 8-bit displacement, it is sign extended to 16-bit before adding to the base value.

When **BX** holds the base value of EA, 20-bit physical address is calculated from **BX and DS**.

When **BP** holds the base value of EA, **BP and SS** is used.

**Example:**

**MOV AX, [BX + 08H]**

**Operations:**

$$\begin{aligned}
 &0008_H \leftarrow 08_H \text{ (Sign extended)} \\
 &\text{EA} = (\text{BX}) + 0008_H \\
 &\text{BA} = (\text{DS}) \times 16_{10} \\
 &\text{MA} = \text{BA} + \text{EA}
 \end{aligned}$$

$$\begin{aligned}
 &(\text{AX}) \leftarrow (\text{MA}) \quad \text{or}, \\
 &(\text{AL}) \leftarrow (\text{MA}) \\
 &(\text{AH}) \leftarrow (\text{MA} + 1)
 \end{aligned}$$

1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing



**SI or DI register** is used to hold an index value for memory data and a signed 8-bit or unsigned 16-bit displacement will be specified in the instruction.

Displacement is added to the index value in SI or DI register to obtain the EA.

In case of 8-bit displacement, it is sign extended to 16-bit before adding to the base value.

### Example:

**MOV CX, [SI + 0A2H]**

### Operations:

$\text{FFA2}_H \leftarrow \text{A2}_H$  (Sign extended)

$\text{EA} = (\text{SI}) + \text{FFA2}_H$

$\text{BA} = (\text{DS}) \times 16_{10}$

$\text{MA} = \text{BA} + \text{EA}$

$(\text{CX}) \leftarrow (\text{MA})$  or,

$(\text{CL}) \leftarrow (\text{MA})$

$(\text{CH}) \leftarrow (\text{MA} + 1)$

1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing



In Based Index Addressing, the effective address is computed from the sum of a base register (BX or BP), an index register (SI or DI) and a displacement.

**Example:**

**MOV DX, [BX + SI + 0AH]**

**Operations:**

$000A_H \leftarrow 0A_H$  (Sign extended)

$$EA = (BX) + (SI) + 000A_H$$

$$BA = (DS) \times 16_{10}$$

$$MA = BA + EA$$

$(DX) \leftarrow (MA)$  or,

$(DL) \leftarrow (MA)$

$(DH) \leftarrow (MA + 1)$

1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing

Note : Effective address of  
the Extra segment register

**Employed in string operations to operate on string data.**

The effective address (EA) of source data is stored in **SI register** and the EA of destination is stored in **DI register**.

**Segment register** for calculating base address of source data is **DS** and that of the destination data is **ES**

**Example: MOVS BYTE**

**Operations:**

**Calculation of source memory location:**

$$\text{EA} = (\text{SI}) \quad \text{BA} = (\text{DS}) \times 16_{10} \quad \text{MA} = \text{BA} + \text{EA}$$

**Calculation of destination memory location:**

$$\text{EA}_E = (\text{DI}) \quad \text{BA}_E = (\text{ES}) \times 16_{10} \quad \text{MA}_E = \text{BA}_E + \text{EA}_E$$

$$(\text{MAE}) \leftarrow (\text{MA})$$

If **DF = 1**, then **(SI)  $\leftarrow$  (SI) - 1** and **(DI) = (DI) - 1**

If **DF = 0**, then **(SI)  $\leftarrow$  (SI) + 1** and **(DI) = (DI) + 1**

1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing

These addressing modes are used to access data from standard I/O mapped devices or ports.

In **direct port addressing mode**, an 8-bit port address is directly specified in the instruction.

**Example:** IN AL, [09H]

**Operations:**  $\text{PORT}_{\text{addr}} = 09_{\text{H}}$   
 $(\text{AL}) \leftarrow (\text{PORT})$

Content of port with address  $09_{\text{H}}$  is moved to AL register



1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing



In this addressing mode, the effective address of a program instruction is specified relative to Instruction Pointer (IP) by an 8-bit signed displacement.

**Example: JZ 0AH**

**Operations:**

$000A_H \leftarrow 0A_H$  (sign extend)

If ZF = 1, then

$$EA = (IP) + 000A_H$$

$$BA = (CS) \times 16_{10}$$

$$MA = BA + EA$$

If ZF = 1, then the program control jumps to new address calculated above.

If ZF = 0, then next instruction of the program is executed.

1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing

**Instructions using this mode have no operands.  
The instruction itself will specify the data to be  
operated by the instruction.**

**Example: CLC**

This clears the carry flag to zero.



# **INSTRUCTION SET**

**8086 supports 6 types of instructions.**

- 1. Data Transfer Instructions**
- 2. Arithmetic Instructions**
- 3. Logical Instructions**
- 4. String manipulation Instructions**
- 5. Process Control Instructions**
- 6. Control Transfer Instructions**

## 1. Data Transfer Instructions

**Instructions that are used to transfer data/ address in to registers, memory locations and I/O ports.**

**Generally involve two operands: Source operand and Destination operand of the same size.**

**Source:** Register or a memory location or an immediate data  
**Destination :** Register or a memory location.

**The size should be either a byte or a word.**

**A 8-bit data can only be moved to 8-bit register/ memory and a 16-bit data can be moved to 16-bit register/ memory.**

## 1. Data Transfer Instructions

Mnemonics: **MOV, XCHG, PUSH, POP, IN, OUT ...**

### MOV reg2/ mem, reg1/ mem

MOV reg2, reg1  
MOV mem, reg1  
MOV reg2, mem

(reg2)  $\leftarrow$  (reg1)  
(mem)  $\leftarrow$  (reg1)  
(reg2)  $\leftarrow$  (mem)

### MOV reg/ mem, data

MOV reg, data  
MOV mem, data

(reg)  $\leftarrow$  data  
(mem)  $\leftarrow$  data

### XCHG reg2/ mem, reg1

XCHG reg2, reg1  
XCHG mem, reg1

(reg2)  $\leftrightarrow$  (reg1)  
(mem)  $\leftrightarrow$  (reg1)

## 1. Data Transfer Instructions

Mnemonics: **MOV, XCHG, PUSH, POP, IN, OUT ...**

|                        |                                                                                                           |
|------------------------|-----------------------------------------------------------------------------------------------------------|
| <b>PUSH reg16/ mem</b> |                                                                                                           |
| <b>PUSH reg16</b>      | $(SP) \leftarrow (SP) - 2$<br>$MA_s = (SS) \times 16_{10} + SP$<br>$(MA_s ; MA_s + 1) \leftarrow (reg16)$ |
| <b>PUSH mem</b>        | $(SP) \leftarrow (SP) - 2$<br>$MA_s = (SS) \times 16_{10} + SP$<br>$(MA_s ; MA_s + 1) \leftarrow (mem)$   |
| <b>POP reg16/ mem</b>  |                                                                                                           |
| <b>POP reg16</b>       | $MA_s = (SS) \times 16_{10} + SP$<br>$(reg16) \leftarrow (MA_s ; MA_s + 1)$<br>$(SP) \leftarrow (SP) + 2$ |
| <b>POP mem</b>         | $MA_s = (SS) \times 16_{10} + SP$<br>$(mem) \leftarrow (MA_s ; MA_s + 1)$<br>$(SP) \leftarrow (SP) + 2$   |

## 1. Data Transfer Instructions

Mnemonics: **MOV, XCHG, PUSH, POP, IN, OUT ...**

|                     |                                                                                     |                      |                                                                                     |
|---------------------|-------------------------------------------------------------------------------------|----------------------|-------------------------------------------------------------------------------------|
| <b>IN A, [DX]</b>   |                                                                                     | <b>OUT [DX], A</b>   |                                                                                     |
| <b>IN AL, [DX]</b>  | $\text{PORT}_{\text{addr}} = (\text{DX})$<br>$(\text{AL}) \leftarrow (\text{PORT})$ | <b>OUT [DX], AL</b>  | $\text{PORT}_{\text{addr}} = (\text{DX})$<br>$(\text{PORT}) \leftarrow (\text{AL})$ |
| <b>IN AX, [DX]</b>  | $\text{PORT}_{\text{addr}} = (\text{DX})$<br>$(\text{AX}) \leftarrow (\text{PORT})$ | <b>OUT [DX], AX</b>  | $\text{PORT}_{\text{addr}} = (\text{DX})$<br>$(\text{PORT}) \leftarrow (\text{AX})$ |
| <b>IN A, addr8</b>  |                                                                                     | <b>OUT addr8, A</b>  |                                                                                     |
| <b>IN AL, addr8</b> | $(\text{AL}) \leftarrow (\text{addr8})$                                             | <b>OUT addr8, AL</b> | $(\text{addr8}) \leftarrow (\text{AL})$                                             |
| <b>IN AX, addr8</b> | $(\text{AX}) \leftarrow (\text{addr8})$                                             | <b>OUT addr8, AX</b> | $(\text{addr8}) \leftarrow (\text{AX})$                                             |

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

|                                                                       |                                                                                                                                                                               |
|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ADD reg2/ mem, reg1/mem</b>                                        |                                                                                                                                                                               |
| <b>ADC reg2, reg1</b><br><b>ADC reg2, mem</b><br><b>ADC mem, reg1</b> | $(\text{reg2}) \leftarrow (\text{reg1}) + (\text{reg2})$<br>$(\text{reg2}) \leftarrow (\text{reg2}) + (\text{mem})$<br>$(\text{mem}) \leftarrow (\text{mem}) + (\text{reg1})$ |
| <b>ADD reg/mem, data</b>                                              |                                                                                                                                                                               |
| <b>ADD reg, data</b><br><b>ADD mem, data</b>                          | $(\text{reg}) \leftarrow (\text{reg}) + \text{data}$<br>$(\text{mem}) \leftarrow (\text{mem}) + \text{data}$                                                                  |
| <b>ADD A, data</b>                                                    |                                                                                                                                                                               |
| <b>ADD AL, data8</b><br><b>ADD AX, data16</b>                         | $(\text{AL}) \leftarrow (\text{AL}) + \text{data8}$<br>$(\text{AX}) \leftarrow (\text{AX}) + \text{data16}$                                                                   |

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

|                                |                                                                      |
|--------------------------------|----------------------------------------------------------------------|
| <b>ADC reg2/ mem, reg1/mem</b> |                                                                      |
| <b>ADC reg2, reg1</b>          | $(\text{reg2}) \leftarrow (\text{reg1}) + (\text{reg2}) + \text{CF}$ |
| <b>ADC reg2, mem</b>           | $(\text{reg2}) \leftarrow (\text{reg2}) + (\text{mem}) + \text{CF}$  |
| <b>ADC mem, reg1</b>           | $(\text{mem}) \leftarrow (\text{mem}) + (\text{reg1}) + \text{CF}$   |
| <b>ADC reg/mem, data</b>       |                                                                      |
| <b>ADC reg, data</b>           | $(\text{reg}) \leftarrow (\text{reg}) + \text{data} + \text{CF}$     |
| <b>ADC mem, data</b>           | $(\text{mem}) \leftarrow (\text{mem}) + \text{data} + \text{CF}$     |
| <b>ADDC A, data</b>            |                                                                      |
| <b>ADD AL, data8</b>           | $(\text{AL}) \leftarrow (\text{AL}) + \text{data8} + \text{CF}$      |
| <b>ADD AX, data16</b>          | $(\text{AX}) \leftarrow (\text{AX}) + \text{data16} + \text{CF}$     |

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

|                                                                       |                                                                                                                                                                               |
|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SUB reg2/ mem, reg1/mem</b>                                        |                                                                                                                                                                               |
| <b>SUB reg2, reg1</b><br><b>SUB reg2, mem</b><br><b>SUB mem, reg1</b> | $(\text{reg2}) \leftarrow (\text{reg1}) - (\text{reg2})$<br>$(\text{reg2}) \leftarrow (\text{reg2}) - (\text{mem})$<br>$(\text{mem}) \leftarrow (\text{mem}) - (\text{reg1})$ |
| <b>SUB reg/mem, data</b>                                              |                                                                                                                                                                               |
| <b>SUB reg, data</b><br><b>SUB mem, data</b>                          | $(\text{reg}) \leftarrow (\text{reg}) - \text{data}$<br>$(\text{mem}) \leftarrow (\text{mem}) - \text{data}$                                                                  |
| <b>SUB A, data</b>                                                    |                                                                                                                                                                               |
| <b>SUB AL, data8</b><br><b>SUB AX, data16</b>                         | $(\text{AL}) \leftarrow (\text{AL}) - \text{data8}$<br>$(\text{AX}) \leftarrow (\text{AX}) - \text{data16}$                                                                   |

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

|                                                                       |                                                                                                                                                                                                                   |
|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SBB reg2/ mem, reg1/mem</b>                                        |                                                                                                                                                                                                                   |
| <b>SBB reg2, reg1</b><br><b>SBB reg2, mem</b><br><b>SBB mem, reg1</b> | $(\text{reg2}) \leftarrow (\text{reg1}) - (\text{reg2}) - \text{CF}$<br>$(\text{reg2}) \leftarrow (\text{reg2}) - (\text{mem}) - \text{CF}$<br>$(\text{mem}) \leftarrow (\text{mem}) - (\text{reg1}) - \text{CF}$ |
| <b>SBB reg/mem, data</b>                                              |                                                                                                                                                                                                                   |
| <b>SBB reg, data</b><br><b>SBB mem, data</b>                          | $(\text{reg}) \leftarrow (\text{reg}) - \text{data} - \text{CF}$<br>$(\text{mem}) \leftarrow (\text{mem}) - \text{data} - \text{CF}$                                                                              |
| <b>SBB A, data</b>                                                    |                                                                                                                                                                                                                   |
| <b>SBB AL, data8</b><br><b>SBB AX, data16</b>                         | $(\text{AL}) \leftarrow (\text{AL}) - \text{data8} - \text{CF}$<br>$(\text{AX}) \leftarrow (\text{AX}) - \text{data16} - \text{CF}$                                                                               |

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

|                     |                                                |
|---------------------|------------------------------------------------|
| <b>INC reg/ mem</b> |                                                |
| <b>INC reg8</b>     | $(\text{reg8}) \leftarrow (\text{reg8}) + 1$   |
| <b>INC reg16</b>    | $(\text{reg16}) \leftarrow (\text{reg16}) + 1$ |
| <b>INC mem</b>      | $(\text{mem}) \leftarrow (\text{mem}) + 1$     |
| <b>DEC reg/ mem</b> |                                                |
| <b>DEC reg8</b>     | $(\text{reg8}) \leftarrow (\text{reg8}) - 1$   |
| <b>DEC reg16</b>    | $(\text{reg16}) \leftarrow (\text{reg16}) - 1$ |
| <b>DEC mem</b>      | $(\text{mem}) \leftarrow (\text{mem}) - 1$     |

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

|                      |                                                                                                                                     |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <b>MUL reg/ mem</b>  |                                                                                                                                     |
| <b>MUL reg</b>       | <u>For byte</u> : $(AX) \leftarrow (AL) \times (\text{reg8})$<br><u>For word</u> : $(DX)(AX) \leftarrow (AX) \times (\text{reg16})$ |
| <b>MUL mem</b>       | <u>For byte</u> : $(AX) \leftarrow (AL) \times (\text{mem8})$<br><u>For word</u> : $(DX)(AX) \leftarrow (AX) \times (\text{mem16})$ |
| <b>IMUL reg/ mem</b> |                                                                                                                                     |
| <b>IMUL reg</b>      | <u>For byte</u> : $(AX) \leftarrow (AL) \times (\text{reg8})$<br><u>For word</u> : $(DX)(AX) \leftarrow (AX) \times (\text{reg16})$ |
| <b>IMUL mem</b>      | <u>For byte</u> : $(AX) \leftarrow (AX) \times (\text{mem8})$<br><u>For word</u> : $(DX)(AX) \leftarrow (AX) \times (\text{mem16})$ |

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

DIV reg/ mem

DIV reg

For 16-bit :- 8-bit :

(AL)  $\leftarrow$  (AX)  $\div$  (reg8) Quotient  
(AH)  $\leftarrow$  (AX) MOD(reg8) Remainder

For 32-bit :- 16-bit :

(AX)  $\leftarrow$  (DX)(AX)  $\div$  (reg16) Quotient  
(DX)  $\leftarrow$  (DX)(AX) MOD(reg16) Remainder

DIV mem

For 16-bit :- 8-bit :

(AL)  $\leftarrow$  (AX)  $\div$  (mem8) Quotient  
(AH)  $\leftarrow$  (AX) MOD(mem8) Remainder

For 32-bit :- 16-bit :

(AX)  $\leftarrow$  (DX)(AX)  $\div$  (mem16) Quotient  
(DX)  $\leftarrow$  (DX)(AX) MOD(mem16) Remainder

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

**IDIV reg / mem**

**IDIV reg**

**For 16-bit :- 8-bit :**

$(AL) \leftarrow (AX) \text{ :- } (\text{reg8})$  Quotient

$(AH) \leftarrow (AX) \text{ MOD } (\text{reg8})$  Remainder

**For 32-bit :- 16-bit :**

$(AX) \leftarrow (DX)(AX) \text{ :- } (\text{reg16})$  Quotient

$(DX) \leftarrow (DX)(AX) \text{ MOD } (\text{reg16})$  Remainder

**IDIV mem**

**For 16-bit :- 8-bit :**

$(AL) \leftarrow (AX) \text{ :- } (\text{mem8})$  Quotient

$(AH) \leftarrow (AX) \text{ MOD } (\text{mem8})$  Remainder

**For 32-bit :- 16-bit :**

$(AX) \leftarrow (DX)(AX) \text{ :- } (\text{mem16})$  Quotient

$(DX) \leftarrow (DX)(AX) \text{ MOD } (\text{mem16})$  Remainder

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

**CMP reg2/mem, reg1/ mem**

**CMP reg2, reg1**

**CMP reg2, mem**

**CMP mem, reg1**

**Modify flags  $\leftarrow (\text{reg2}) - (\text{reg1})$**

**If ( $\text{reg2} > \text{reg1}$ ) then CF=0, ZF=0, SF=0**

**If ( $\text{reg2} < \text{reg1}$ ) then CF=1, ZF=0, SF=1**

**If ( $\text{reg2} = \text{reg1}$ ) then CF=0, ZF=1, SF=0**

**Modify flags  $\leftarrow (\text{reg2}) - (\text{mem})$**

**If ( $\text{reg2} > \text{mem}$ ) then CF=0, ZF=0, SF=0**

**If ( $\text{reg2} < \text{mem}$ ) then CF=1, ZF=0, SF=1**

**If ( $\text{reg2} = \text{mem}$ ) then CF=0, ZF=1, SF=0**

**Modify flags  $\leftarrow (\text{mem}) - (\text{reg1})$**

**If ( $\text{mem} > \text{reg1}$ ) then CF=0, ZF=0, SF=0**

**If ( $\text{mem} < \text{reg1}$ ) then CF=1, ZF=0, SF=1**

**If ( $\text{mem} = \text{reg1}$ ) then CF=0, ZF=1, SF=0**

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

**CMP reg/mem, data**

**CMP reg, data**

**Modify flags  $\leftarrow (\text{reg}) - (\text{data})$**

**If (reg) > data then CF=0, ZF=0, SF=0**

**If (reg) < data then CF=1, ZF=0, SF=1**

**If (reg) = data then CF=0, ZF=1, SF=0**

**CMP mem, data**

**Modify flags  $\leftarrow (\text{mem}) - (\text{mem})$**

**If (mem) > data then CF=0, ZF=0, SF=0**

**If (mem) < data then CF=1, ZF=0, SF=1**

**If (mem) = data then CF=0, ZF=1, SF=0**

## 2. Arithmetic Instructions

Mnemonics: **ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV, CMP...**

**CMP A, data**

**CMP AL, data8**

**Modify flags  $\leftarrow (AL) - \text{data8}$**

**If  $(AL) > \text{data8}$  then CF=0, ZF=0, SF=0**

**If  $(AL) < \text{data8}$  then CF=1, ZF=0, SF=1**

**If  $(AL) = \text{data8}$  then CF=0, ZF=1, SF=0**

**CMP AX, data16**

**Modify flags  $\leftarrow (AX) - \text{data16}$**

**If  $(AX) > \text{data16}$  then CF=0, ZF=0, SF=0**

**If  $(mem) < \text{data16}$  then CF=1, ZF=0, SF=1**

**If  $(mem) = \text{data16}$  then CF=0, ZF=1, SF=0**

### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

|                |                                         |
|----------------|-----------------------------------------|
| AND A, data    |                                         |
| AND AL, data8  | $(AL) \leftarrow (AL) \& \text{data8}$  |
| AND AX, data16 | $(AX) \leftarrow (AX) \& \text{data16}$ |

|                   |                                                       |
|-------------------|-------------------------------------------------------|
| AND reg/mem, data |                                                       |
| AND reg, data     | $(\text{reg}) \leftarrow (\text{reg}) \& \text{data}$ |
| AND mem, data     | $(\text{mem}) \leftarrow (\text{mem}) \& \text{data}$ |

### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

|                       |                                                          |
|-----------------------|----------------------------------------------------------|
| OR reg2/mem, reg1/mem |                                                          |
| OR reg2, reg1         | $(\text{reg2}) \leftarrow (\text{reg2})   (\text{reg1})$ |
| OR reg2, mem          | $(\text{reg2}) \leftarrow (\text{reg2})   (\text{mem})$  |
| OR mem, reg1          | $(\text{mem}) \leftarrow (\text{mem})   (\text{reg1})$   |

|                  |                                                      |
|------------------|------------------------------------------------------|
| OR reg/mem, data |                                                      |
| OR reg, data     | $(\text{reg}) \leftarrow (\text{reg})   \text{data}$ |
| OR mem, data     | $(\text{mem}) \leftarrow (\text{mem})   \text{data}$ |

|               |                                                      |
|---------------|------------------------------------------------------|
| OR A, data    |                                                      |
| OR AL, data8  | $(\text{AL}) \leftarrow (\text{AL})   \text{data8}$  |
| OR AX, data16 | $(\text{AX}) \leftarrow (\text{AX})   \text{data16}$ |

### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

|                        |                                                               |
|------------------------|---------------------------------------------------------------|
| XOR reg2/mem, reg1/mem |                                                               |
| XOR reg2, reg1         | $(\text{reg2}) \leftarrow (\text{reg2}) \wedge (\text{reg1})$ |
| XOR reg2, mem          | $(\text{reg2}) \leftarrow (\text{reg2}) \wedge (\text{mem})$  |
| XOR mem, reg1          | $(\text{mem}) \leftarrow (\text{mem}) \wedge (\text{reg1})$   |

|                   |                                                           |
|-------------------|-----------------------------------------------------------|
| XOR reg/mem, data |                                                           |
| XOR reg, data     | $(\text{reg}) \leftarrow (\text{reg}) \wedge \text{data}$ |
| XOR mem, data     | $(\text{mem}) \leftarrow (\text{mem}) \wedge \text{data}$ |

|                |                                                           |
|----------------|-----------------------------------------------------------|
| XOR A, data    |                                                           |
| XOR AL, data8  | $(\text{AL}) \leftarrow (\text{AL}) \wedge \text{data8}$  |
| XOR AX, data16 | $(\text{AX}) \leftarrow (\text{AX}) \wedge \text{data16}$ |

### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

|                         |                                           |
|-------------------------|-------------------------------------------|
| TEST reg2/mem, reg1/mem |                                           |
| TEST reg2, reg1         | Modify flags $\leftarrow$ (reg2) & (reg1) |
| TEST reg2, mem          | Modify flags $\leftarrow$ (reg2) & (mem)  |
| TEST mem, reg1          | Modify flags $\leftarrow$ (mem) & (reg1)  |
| TEST reg/mem, data      |                                           |
| TEST reg, data          | Modify flags $\leftarrow$ (reg) & data    |
| TEST mem, data          | Modify flags $\leftarrow$ (mem) & data    |
| TEST A, data            |                                           |
| TEST AL, data8          | Modify flags $\leftarrow$ (AL) & data8    |
| TEST AX, data16         | Modify flags $\leftarrow$ (AX) & data16   |

### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

SHR reg/mem

SHR reg

i) SHR reg, 1

ii) SHR reg, CL

SHR mem

i) SHR mem, 1

ii) SHR mem, CL

$CF \leftarrow B_{LSD}; B_n \leftarrow B_{n+1}; B_{MSD} \leftarrow 0$



### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

SHL reg/mem or SAL reg/mem

SHL reg or SAL reg

- i) SHL reg, 1 or SAL reg, 1
- ii) SHL reg, CL or SAL reg, CL

SHL mem or SAL mem

- i) SHL mem, 1 or SAL mem, 1
- ii) SHL mem, CL or SAL mem, CL

$$CF \leftarrow B_{MSD}; B_{n+1} \leftarrow B_n; B_{LSD} \leftarrow 0$$



### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

RCR reg/mem

RCR reg

- i) RCR reg, 1
- ii) RCR reg, CL

RCR mem

- i) RCR mem, 1
- ii) RCR mem, CL

$$B_n \leftarrow B_{n-1} ; B_{MSD} \leftarrow CF ; CF \leftarrow B_{LSD}$$



### 3. Logical Instructions

Mnemonics: **AND, OR, XOR, TEST, SHR, SHL, RCR, RCL ...**

ROL reg/mem

ROL reg

- i) ROL reg, 1
- ii) ROL reg, CL

ROL mem

- i) ROL mem, 1
- ii) ROL mem, CL

$$B_{n+1} \leftarrow B_n ; CF \leftarrow B_{MSD} ; B_{LSD} \leftarrow B_{MSD}$$



## 4. String Manipulation Instructions

- **String : Sequence of bytes or words**
- **8086 instruction set includes instruction for string movement, comparison, scan, load and store.**
- **REP instruction prefix : used to repeat execution of string instructions**
- **String instructions end with S or SB or SW.**  
**S represents string, SB string byte and SW string word.**
- **Offset or effective address of the source operand is stored in SI register and that of the destination operand is stored in DI register.**
- **Depending on the status of DF, SI and DI registers are automatically updated.**
- **$DF = 0 \Rightarrow SI$  and  $DI$  are incremented by 1 for byte and 2 for word.**
- **$DF = 1 \Rightarrow SI$  and  $DI$  are decremented by 1 for byte and 2 for word.**

## 4. String Manipulation Instructions

Mnemonics: **REP, MOVS, CMPS, SCAS, LODS, STOS**

**REP**

**REPZ/ REPE**

**(Repeat CMPS or SCAS until  
ZF = 0)**

**REPNZ/ REPNE**

**(Repeat CMPS or SCAS until  
ZF = 1)**

**While CX ≠ 0 and ZF = 1, repeat execution of  
string instruction and  
 $(CX) \leftarrow (CX) - 1$**

**While CX ≠ 0 and ZF = 0, repeat execution of  
string instruction and  
 $(CX) \leftarrow (CX) - 1$**

## 4. String Manipulation Instructions

Mnemonics: **REP, MOVS, CMPS, SCAS, LODS, STOS**

### MOVS

#### MOVSB

$$\begin{aligned} \text{MA} &= (\text{DS}) \times 16_{10} + (\text{SI}) \\ \text{MA}_E &= (\text{ES}) \times 16_{10} + (\text{DI}) \end{aligned}$$

$$(\text{MA}_E) \leftarrow (\text{MA})$$

If DF = 0, then  $(\text{DI}) \leftarrow (\text{DI}) + 1$ ;  $(\text{SI}) \leftarrow (\text{SI}) + 1$   
If DF = 1, then  $(\text{DI}) \leftarrow (\text{DI}) - 1$ ;  $(\text{SI}) \leftarrow (\text{SI}) - 1$

#### MOVSW

$$\begin{aligned} \text{MA} &= (\text{DS}) \times 16_{10} + (\text{SI}) \\ \text{MA}_E &= (\text{ES}) \times 16_{10} + (\text{DI}) \end{aligned}$$

$$(\text{MA}_E ; \text{MA}_E + 1) \leftarrow (\text{MA}; \text{MA} + 1)$$

If DF = 0, then  $(\text{DI}) \leftarrow (\text{DI}) + 2$ ;  $(\text{SI}) \leftarrow (\text{SI}) + 2$   
If DF = 1, then  $(\text{DI}) \leftarrow (\text{DI}) - 2$ ;  $(\text{SI}) \leftarrow (\text{SI}) - 2$

## 4. String Manipulation Instructions

Mnemonics: **REP, MOVS, CMPS, SCAS, LODS, STOS**

Compare two string byte or string word

**CMPS**

**CMPSB**

**CMPSW**

$$\begin{aligned} \text{MA} &= (\text{DS}) \times 16_{10} + (\text{SI}) \\ \text{MA}_E &= (\text{ES}) \times 16_{10} + (\text{DI}) \end{aligned}$$

**Modify flags**  $\leftarrow (\text{MA}) - (\text{MA}_E)$

If  $(\text{MA}) > (\text{MA}_E)$ , then  $\text{CF} = 0; \text{ZF} = 0; \text{SF} = 0$

If  $(\text{MA}) < (\text{MA}_E)$ , then  $\text{CF} = 1; \text{ZF} = 0; \text{SF} = 1$

If  $(\text{MA}) = (\text{MA}_E)$ , then  $\text{CF} = 0; \text{ZF} = 1; \text{SF} = 0$

**For byte operation**

If  $\text{DF} = 0$ , then  $(\text{DI}) \leftarrow (\text{DI}) + 1; (\text{SI}) \leftarrow (\text{SI}) + 1$

If  $\text{DF} = 1$ , then  $(\text{DI}) \leftarrow (\text{DI}) - 1; (\text{SI}) \leftarrow (\text{SI}) - 1$

**For word operation**

If  $\text{DF} = 0$ , then  $(\text{DI}) \leftarrow (\text{DI}) + 2; (\text{SI}) \leftarrow (\text{SI}) + 2$

If  $\text{DF} = 1$ , then  $(\text{DI}) \leftarrow (\text{DI}) - 2; (\text{SI}) \leftarrow (\text{SI}) - 2$

## 4. String Manipulation Instructions

Mnemonics: **REP, MOVS, CMPS, SCAS, LODS, STOS**

**Scan (compare) a string byte or word with accumulator**

### SCAS

#### SCASB

$MA_E = (ES) \times 16_{10} + (DI)$   
**Modify flags**  $\leftarrow (AL) - (MA_E)$

If  $(AL) > (MA_E)$ , then  $CF = 0; ZF = 0; SF = 0$   
If  $(AL) < (MA_E)$ , then  $CF = 1; ZF = 0; SF = 1$   
If  $(AL) = (MA_E)$ , then  $CF = 0; ZF = 1; SF = 0$

If  $DF = 0$ , then  $(DI) \leftarrow (DI) + 1$   
If  $DF = 1$ , then  $(DI) \leftarrow (DI) - 1$

#### SCASW

$MA_E = (ES) \times 16_{10} + (DI)$   
**Modify flags**  $\leftarrow (AX) - (MA_E)$

If  $(AX) > (MA_E ; MA_E + 1)$ , then  $CF = 0; ZF = 0; SF = 0$   
If  $(AX) < (MA_E ; MA_E + 1)$ , then  $CF = 1; ZF = 0; SF = 1$   
If  $(AX) = (MA_E ; MA_E + 1)$ , then  $CF = 0; ZF = 1; SF = 0$

If  $DF = 0$ , then  $(DI) \leftarrow (DI) + 2$   
If  $DF = 1$ , then  $(DI) \leftarrow (DI) - 2$

## 4. String Manipulation Instructions

Mnemonics: **REP, MOVS, CMPS, SCAS, LODS, STOS**

Load string byte in to AL or string word in to AX

**LODS**

**LODSB**

$MA = (DS) \times 16_{10} + (SI)$   
 $(AL) \leftarrow (MA)$

If DF = 0, then  $(SI) \leftarrow (SI) + 1$   
If DF = 1, then  $(SI) \leftarrow (SI) - 1$

**LODSW**

$MA = (DS) \times 16_{10} + (SI)$   
 $(AX) \leftarrow (MA ; MA + 1)$

If DF = 0, then  $(SI) \leftarrow (SI) + 2$   
If DF = 1, then  $(SI) \leftarrow (SI) - 2$

## 4. String Manipulation Instructions

Mnemonics: **REP, MOVS, CMPS, SCAS, LODS, STOS**

Store byte from AL or word from AX in to string

**STOS**

**STOSB**

$MA_E = (ES) \times 16_{10} + (DI)$   
 $(MA_E) \leftarrow (AL)$

If DF = 0, then  $(DI) \leftarrow (DI) + 1$   
If DF = 1, then  $(DI) \leftarrow (DI) - 1$

**STOSW**

$MA_E = (ES) \times 16_{10} + (DI)$   
 $(MA_E ; MA_E + 1) \leftarrow (AX)$

If DF = 0, then  $(DI) \leftarrow (DI) + 2$   
If DF = 1, then  $(DI) \leftarrow (DI) - 2$

## 5. Processor Control Instructions

| Mnemonics                  | Explanation                                                                                          |
|----------------------------|------------------------------------------------------------------------------------------------------|
| STC                        | <b>Set CF ← 1</b>                                                                                    |
| CLC                        | <b>Clear CF ← 0</b>                                                                                  |
| CMC                        | <b>Complement carry CF ← CF/</b>                                                                     |
| STD                        | <b>Set direction flag DF ← 1</b>                                                                     |
| CLD                        | <b>Clear direction flag DF ← 0</b>                                                                   |
| STI                        | <b>Set interrupt enable flag IF ← 1</b>                                                              |
| CLI                        | <b>Clear interrupt enable flag IF ← 0</b>                                                            |
| NOP                        | <b>No operation</b>                                                                                  |
| HLT                        | <b>Halt after interrupt is set</b>                                                                   |
| WAIT                       | <b>Wait for TEST pin active</b>                                                                      |
| <b>ESC opcode mem/ reg</b> | <b>Used to pass instruction to a coprocessor which shares the address and data bus with the 8086</b> |
| <b>LOCK</b>                | <b>Lock bus during next instruction</b>                                                              |

## 6. Control Transfer Instructions

- Transfer the control to a specific destination or target instruction
- Do not affect flags

### □ 8086 Unconditional transfers

| Mnemonics                   | Explanation            |
|-----------------------------|------------------------|
| CALL reg/ mem/ disp16       | Call subroutine        |
| RET                         | Return from subroutine |
| JMP reg/ mem/ disp8/ disp16 | Unconditional jump     |

## 6. Control Transfer Instructions

- **8086 signed conditional branch instructions**
  - Checks flags
  - If conditions are true, the program control is transferred to the new memory location in the same segment by modifying the content of IP
- **8086 unsigned conditional branch instructions**

## 6. Control Transfer Instructions

**8086 signed conditional branch instructions**

| Name                                                     | Alternate name                                                |
|----------------------------------------------------------|---------------------------------------------------------------|
| <b>JE disp8</b><br><b>Jump if equal</b>                  | <b>JZ disp8</b><br><b>Jump if result is 0</b>                 |
| <b>JNE disp8</b><br><b>Jump if not equal</b>             | <b>JNZ disp8</b><br><b>Jump if not zero</b>                   |
| <b>JG disp8</b><br><b>Jump if greater</b>                | <b>JNLE disp8</b><br><b>Jump if not less or equal</b>         |
| <b>JGE disp8</b><br><b>Jump if greater than or equal</b> | <b>JNL disp8</b><br><b>Jump if not less</b>                   |
| <b>JL disp8</b><br><b>Jump if less than</b>              | <b>JNGE disp8</b><br><b>Jump if not greater than or equal</b> |
| <b>JLE disp8</b><br><b>Jump if less than or equal</b>    | <b>JNG disp8</b><br><b>Jump if not greater</b>                |

**8086 unsigned conditional branch instructions**

| Name                                              | Alternate name                                         |
|---------------------------------------------------|--------------------------------------------------------|
| <b>JE disp8</b><br><b>Jump if equal</b>           | <b>JZ disp8</b><br><b>Jump if result is 0</b>          |
| <b>JNE disp8</b><br><b>Jump if not equal</b>      | <b>JNZ disp8</b><br><b>Jump if not zero</b>            |
| <b>JA disp8</b><br><b>Jump if above</b>           | <b>JNBE disp8</b><br><b>Jump if not below or equal</b> |
| <b>JAE disp8</b><br><b>Jump if above or equal</b> | <b>JNB disp8</b><br><b>Jump if not below</b>           |
| <b>JB disp8</b><br><b>Jump if below</b>           | <b>JNAE disp8</b><br><b>Jump if not above or equal</b> |
| <b>JBE disp8</b><br><b>Jump if below or equal</b> | <b>JNA disp8</b><br><b>Jump if not above</b>           |

## 6. Control Transfer Instructions

- 8086 conditional branch instructions affecting individual flags

| Mnemonics        | Explanation                                   |
|------------------|-----------------------------------------------|
| <b>JC disp8</b>  | <b>Jump if CF = 1</b>                         |
| <b>JNC disp8</b> | <b>Jump if CF = 0</b>                         |
| <b>JP disp8</b>  | <b>Jump if PF = 1</b>                         |
| <b>JNP disp8</b> | <b>Jump if PF = 0</b>                         |
| <b>JO disp8</b>  | <b>Jump if OF = 1</b>                         |
| <b>JNO disp8</b> | <b>Jump if OF = 0</b>                         |
| <b>JS disp8</b>  | <b>Jump if SF = 1</b>                         |
| <b>JNS disp8</b> | <b>Jump if SF = 0</b>                         |
| <b>JZ disp8</b>  | <b>Jump if result is zero, i.e, Z = 1</b>     |
| <b>JNZ disp8</b> | <b>Jump if result is not zero, i.e, Z = 1</b> |

# **Assembler directives**

## Assemble Directives

- Instructions to the Assembler regarding the program being executed.
- Control the generation of machine codes and organization of the program; but no machine codes are generated for assembler directives.
- Also called 'pseudo instructions'
- Used to :
  - specify the start and end of a program
  - attach value to variables
  - allocate storage locations to input/ output data
  - define start and end of segments, procedures, macros etc..

# Assemble Directives

DB

DW

SEGMENT  
ENDS

ASSUME

ORG  
END  
EVEN  
EQUPROC  
FAR  
NEAR  
ENDP

SHORT

MACRO  
ENDM

- Define Byte
- Define a byte type (8-bit) variable
- Reserves specific amount of memory locations to each variable
- Range :  $00_H$  –  $FF_H$  for unsigned value;  
 $00_H$  –  $7F_H$  for positive value and  
 $80_H$  –  $FF_H$  for negative value
- General form : variable DB value/ values

Example:

**LIST DB 7FH, 42H, 35H**

Three consecutive memory locations are reserved for the variable LIST and each data specified in the instruction are stored as initial value in the reserved memory location

# Assemble Directives

DB

DW

SEGMENT  
ENDS

ASSUME

ORG  
END  
EVEN  
EQU

PROC  
FAR  
NEAR  
ENDP

SHORT

MACRO  
ENDM

■ Define Word

■ Define a word type (16-bit) variable

■ Reserves two consecutive memory locations to each variable

■ Range :  $0000_H$  –  $FFFF_H$  for unsigned value;  
 $0000_H$  –  $7FFF_H$  for positive value and  
 $8000_H$  –  $FFFF_H$  for negative value

■ General form : variable DW value/ values

Example:

ALIST DW 6512H, 0F251H, 0CDE2H

Six consecutive memory locations are reserved for the variable ALIST and each 16-bit data specified in the instruction is stored in two consecutive memory location.

# Assemble Directives

DB

DW

SEGMENT  
ENDS

ASSUME

ORG  
END  
EVEN  
EQU

PROC  
FAR  
NEAR  
ENDP

SHORT

MACRO  
ENDM

- **SEGMENT** : Used to indicate the beginning of a code/ data/ stack segment
- **ENDS** : Used to indicate the end of a code/ data/ stack segment
- **General form:**

Segnam SEGMENT

...

Program code  
or  
Data Defining Statements

Segnam ENDS

User defined name of  
the segment

# Assemble Directives

DB

DW

SEGMENT  
ENDS

ASSUME

ORG  
END  
EVEN  
EQU

PROC  
FAR  
NEAR  
ENDP

SHORT

MACRO  
ENDM

- Informs the assembler the name of the program/ data segment that should be used for a specific segment.

- General form:

**ASSUME segreg : segnam, .. , segreg : segnam**

Segment Register

User defined name of the segment

**Example:**

ASSUME CS:ACODE, DS:ADATA

Tells the compiler that the instructions of the program are stored in the segment ACODE and data are stored in the segment ADATA

# Assemble Directives

DB

DW

**SEGMENT**  
**ENDS**

**ASSUME**

**ORG**  
**END**  
**EVEN**  
**EQU**

**PROC**  
**FAR**  
**NEAR**  
**ENDP**

**SHORT**

**MACRO**  
**ENDM**

- **ORG** (Origin) is used to assign the starting address (Effective address) for a program/ data segment
- **END** is used to terminate a program; statements after END will be ignored
- **EVEN** : Informs the assembler to store program/ data segment starting from an even address
- **EQU** (Equate) is used to attach a value to a variable

## Examples:

|                                                                                          |                                                                                                                                                                                      |
|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ORG 1000H</b>                                                                         | Informs the assembler that the statements following ORG 1000H should be stored in memory starting with effective address <b>1000<sub>H</sub></b>                                     |
| <b>LOOP EQU 10FEH</b>                                                                    | <b>Value of variable LOOP is 10FE<sub>H</sub></b>                                                                                                                                    |
| <pre>_SDATA SEGMENT     ORG 1200H     A DB 4CH     EVEN     B DW 1052H _SDATA ENDS</pre> | In this data segment, effective address of memory location assigned to A will be <b>1200<sub>H</sub></b> and that of B will be <b>1202<sub>H</sub></b> and <b>1203<sub>H</sub></b> . |

# Assemble Directives

DB

DW

**SEGMENT**  
**ENDS**

**ASSUME**

**ORG**  
**END**  
**EVEN**  
**EQU**

**PROC**  
**ENDP**  
**FAR**  
**NEAR**

**SHORT**

**MACRO**  
**ENDM**

- **PROC** Indicates the beginning of a procedure
- **ENDP** End of procedure
- **FAR** Intersegment call
- **NEAR** Intrasegment call
- General form

procname PROC[NEAR/ FAR]

...

...

...

RET



Program statements of the procedure

Last statement of the procedure

procname ENDP

User defined name of the procedure

DB

DW

SEGMENT  
ENDS

ASSUME

ORG  
END  
EVEN  
EQUPROC  
ENDP  
FAR  
NEAR

SHORT

MACRO  
ENDM**Examples:****ADD64 PROC NEAR**...  
...  
...**RET**  
**ADD64 ENDP**

The subroutine/ procedure named **ADD64** is declared as **NEAR** and so the assembler will code the **CALL** and **RET** instructions involved in this procedure as near call and return

**CONVERT PROC FAR**...  
...  
...**RET**  
**CONVERT ENDP**

The subroutine/ procedure named **CONVERT** is declared as **FAR** and so the assembler will code the **CALL** and **RET** instructions involved in this procedure as far call and return

# Assemble Directives

DB

DW

SEGMENT  
ENDS

ASSUME

ORG  
END  
EVEN  
EQU

PROC  
ENDP  
FAR  
NEAR

SHORT

MACRO  
ENDM

- Reserves one memory location for 8-bit signed displacement in jump instructions

Example:

JMP SHORT  
AHEAD

The directive will reserve one memory location for 8-bit displacement named AHEAD

# Assemble Directives

DB

DW

SEGMENT  
ENDS

ASSUME

ORG  
END  
EVEN  
EQU

PROC  
ENDP  
FAR  
NEAR

SHORT

MACRO  
ENDM

- **MACRO** Indicate the beginning of a macro
- **ENDM** End of a macro
- General form:

macroname MACRO[Arg1, Arg2 ...]

...



macroname ENDM

User defined name of  
the macro

Program  
statements in  
the macro