

## **16-bit Microprocessor and Programming (13hrs)**

## Intel 8086 Microprocessor:

### Features:

- Released in 1978 by Intel Corporation.
  - It has **16-bit data bus** i.e. it can access 16-bit data in one operation. Its ALU and internal data registers are also 16-bit; hence 8086 is a **16-bit pp.**
  - 8086 has a **20 bit address bus** and can access up to  $2^{20}$  memory locations[00000H - FFFFH] (1 MB)[16 times more than 8085].
  - 8086 supports **Pipelining**
    - Fetching the next instruction while executing the current instruction is called Pipelining. 8086 prefetches up to 6 instruction bytes from memory and queues them in order to speed up instruction execution. Pipelining highly improves the performance of the system.
  - 8086 supports **Memory Segmentation**:
    - Segmentation means dividing the memory into logical components. Here, the memory is divided into 4 segments: **Code, Data, Stack and Extra Segments.**
  - 40-pin IC with +5V DC power supply.
  - Available in 3 versions- 8086(Clock rate 5MHz), 8086-2(8 MHz) & 8086-1(10 MHz).
  - 8086 is designed to operate in two modes, Minimum and Maximum.
  - Have 117 different instructions.

सुगम स्टेसनरी सप्लायर्स एण्ड फोटोकपी सर्भिस  
बालकुमारी, ललितपुर ९८४९५९५९२  
NCIT College

### Internal Architecture of 8086 Microprocessor:

c) The Instruction Pointer (IP),  
d) The Address Summing block (2)



FIGURE 8086 internal block diagram. (Intel Corp.)

### Explanation:

- 8086 is a 2-stage microprocessor and its architecture has two blocks:
  1. Bus Interface Unit (BIU) and
  2. Execution Unit (EU).
- 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.



Contains

- a) 6-byte Instruction Queue (Q)
- b) The Segment Registers (CS, DS, ES, SS).

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCTI

- THE QUEUE (Q)**
- The BIU uses a mechanism known as an **instruction stream queue** to implement pipeline **architecture**.
  - This queue permits pre-fetch of up to 6 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 pre-fetching the next sequential instruction.
  - These pre-fetching 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.
  - The EU accesses the queue from the output end. It reads one instruction byte after the other from the output of the queue.
  - The intervals of no bus activity, which may occur between bus cycles, are known as **idle state**.

### Segmented Memory:

- The memory in an 8086/88 based system is organized as segmented memory.
- The CPU 8086 is able to address 1 Mbyte of memory.
- The Complete physically available memory may be divided into a number of logical segments with each segment of 64kbyte.

- A segment is an area that begins at any location which is divisible by 16



- The 16 bit contents of the segment registers in the BIU actually point to the starting location of a particular segment.

**Note:** Segments may be overlapped or non-overlapped (for small programs which do not need all 64 KB in each segment can overlap)

#### Segment Registers:

##### CS (Code Segment):

- This segment is used to hold the program to be executed.
- Instruction fetch operation is performed in the CS memory.
- Holds upper 16 bit of starting address i.e. base address for the code.
- BIU always inserts zeros for the lowest 4 bits of 20 bit starting address.
- Instruction Pointer (IP) holds offset for CS.

##### SS (Stack Segment):

- Upper 16 bit of starting address for stack memory is kept in this register.
- Stack Pointer (SP) in EU holds the 16 bit offset address of the Top of the Stack.
- Base Pointer (BP) holds the 16-bit offset address during random access.
- So physical address given by SS and SP.

##### DS (Data Segment):

- Where data and operands are stored.
- This segment also holds the source operands during string instructions.
- DS register points current data segment.
- Operands for most instructions are fetched from this segment.
- The 16 bit content of SI (Source Index) or DI (Destination Index) is used as offset for computing 20 bit physical address.

Fig Physical Memory

- Each of these segments can be used for a specific function.
- Code segment is used for storing the instructions.
- The stack segment is used as a stack and it is used to store the return addresses.
- The data and extra segments are used for storing data byte.

The following example shows the CS, IP scheme of address formation:



- ES (Extra Segment):**
- Data in access of 64KB during some string instructions use ES to hold the destination.
  - ES and DI are used to determine 20bit physical address.
- Summary:**
- CS : IP,
  - SS : SP or BP,
  - DS : DI or SI,
  - ES : DI, for string instructions

#### Advantages of Segmentation:

- It permits the programmer to access 1MB using only 16-bit address.
- It divides the memory logically to store the Data, Instructions and Stack separately.
- Segmentation is very useful for multi-user environment.

#### Disadvantages of Segmentation:

- Although the total memory,  $16 * 64 \text{ KB}$ , at a time only  $4 * 64 \text{ KB}$  memory can be accessed.
- Any memory locations need to be expressed using 2 registers (Base and Offset).

The main components of EU are as follows:

- a) **General Purpose Registers :**
- The instruction pointer register contains a 16-bit offset address of instruction that is to be executed next.
  - The IP always references the Code segment register (CS).
  - The value contained in the instruction pointer is called as an offset because this value must be added to the base address of the code segment, which is available in the CS register to find the 20-bit physical address.

- The value of the instruction pointer is incremented after executing every instruction.
- To form a 20bit address of the next instruction, the 16 bit address of the IP is added (by the address summing block) to the address contained in the CS, which has been shifted four bits to the left.

### Microprocessors- Chapter 4

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Apart from their general use, these registers also have some specific functions as follows:

| Register               | Purpose                                                                                                                                                                                                                                       |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AX(16 bit accumulator) | Used for I/O instructions, multiplication & division instructions<br>also use AX or AL.                                                                                                                                                       |
| BX(Base Register)      | Stores address information BH & BL are similar to H & L in BX(Base Register) Relative Addressing Mode.                                                                                                                                        |
| CX(Counter Register)   | Some instructions like- shift, rotate, loop and string instructions use contents of CX as counter. Decrement CX automatically by 1 without affecting flags.                                                                                   |
| DX(Data Register)      | Used to hold high 16 bit result of (data) in 16 X 16 bit multiplication, or 16 bit dividend (data) before 32 / 16 bit division or 16 bit remainder after division. Also used to hold the address of I/O port in Indirect I/O Addressing Mode. |

### Microprocessors- Chapter-4

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

It can be used with SS Register to access the stack randomly.

#### Source Index (SI) [16-bits]:

- Normally used to hold the offset address for the data segment but can be used for the Stack Segment.
- Is required for some string operations.
- When string operations are performed, the SI register points to memory locations in the data segment which is addressed by the DS register. Thus, SI is associated with the DS in string operations.

#### Destination Index (DI) [16-bits]:

- It is also used to hold the offset address for the data segment or the stack segment.
- Is also required for some string operations.
- When string operations are performed, the DI register points to memory locations in the data segment which is addressed by the ES register. Thus, DI is associated with the ES in string operations.

#### Note: SI and DI registers may also be used to access data stored in arrays.

#### c) Arithmetic and Logic Unit (ALU) [16-bits]:

- It has a 16-bit ALU. It performs 8/16 bit binary arithmetic and logic operations.

#### d) Operand Register:

- It is a 16-bit register used by control register to hold the operands temporarily.
- It is not available to the Programmer.

#### e) Instruction Register and Instruction Decoder:

- The EU fetches an opcode from the queue into the Instruction Register.
- The Instruction Decoder decodes it and sends the information to the control circuit for execution.

#### f) Flag Register (16-bits):

- A flag is a flip flop which indicates some conditions produced by the execution of an instruction or controls certain operations of the EU.

In 8086 The EU contains

- a 16 bit flag register
- 9 of the 16 are active flags and remaining 7 are undefined.
- 6 flags indicate some conditions- status flags
- 3 flags - control flags

#### Base Pointer (BP) [16-bits]:

- It is used to hold the offset address of the stack in Random Access Mode.

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



| Flag        | Purpose                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Carry (CF)  | Status Flag<br>Set whenever there is a carry (or borrow) out of MSB of a result (D7 bit for an 8-bit operation and D15 bit for a 16-bit Operation ) |
| Parity (PF) | Status Flag<br>PF=0; odd parity, PF=1; even parity.                                                                                                 |

|                      |                                                                                                                                                                                                                      |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Overflow (OF)        | Status Flag<br>Overflow occurs when signed numbers are added or subtracted. An overflow indicates the result has exceeded the capacity of the destination location. Checked by INTO (Interrupt Overflow instruction) |
| Direction (DF)       | Control Flag.<br>Used by string manipulation instructions. Setting DF causes string instruction increment.                                                                                                           |
| Interrupt (IF)       | Control Flag.<br>Setting IF causes 8086 to recognize external maskable interrupt (e.g. INT0), clearing IF disables this interrupt.                                                                                   |
| Trap (TF)            | Control Flag.<br>Setting TF puts 8086 in single step mode, where 8086 generates internal interrupt after execution of each instruction. (1=Trap on; 0=trap off)                                                      |
| Sign (SF)            | Status Flag<br>Holds the sign of the result after an arithmetic/logic operation.<br>$Z=1$ ; result is zero. $Z=0$ ; The result is not 0                                                                              |
| Zero (ZF)            | Status Flag<br>Shows the result of the arithmetic or logic operation.                                                                                                                                                |
| Auxiliary Carry (AC) | Status Flag<br>Holds the carry (half- carry) after addition or borrow after subtraction between bit positions 3 and 4 of the result<br>(For example, in BCD addition or subtraction)                                 |

OF = 1  
PF = 1  
SF = 1  
ZF = 0  
DF = 0  
IF = 0  
TF = 0  
CF = 0

### Addressing Modes of 8086:

Way of defining operands.

Way in which processor can access data.

#### Types:

- Immediate Addressing Mode
- Direct Addressing Mode
- Register Addressing Mode
- Register Indirect Addressing Mode
- Register Relative Addressing Mode
- Base + Index Addressing Mode, &
- Base + Relative + Index Addressing Mode.

#### (i) Immediate Addressing Mode:

-operand is specified in the instruction itself.

$MOV AL, 33H$

$ADD AX, 162H$

$MOV AL, 33H$



As shown in above pin configuration of 8086 microprocessor, the pins from 24-31 has a dual function, one for minimum mode and other for maximum mode. Their function depend on pin 33, i.e.  $MN / \overline{MX}$ , if  $MN / \overline{MX} = 0$ , 8086 operates in maximum mode, if  $MN / \overline{MX} = 1$ , 8086 operates in minimum mode.

So, all the pins of 8086 microprocessor can be categorized into 3 sections as follows:

Section 1: The functions of pin remain same in both modes

Section 2: The functions of pin only in minimum mode

Section 3: The functions of pin only in maximum mode

#### Section 1(pins that remain same for both modes):

##### #AD7-AD0 [ADDRESS/DATA]

- The address/data bus line compose the multiplexed address data bus of the 8086 and contain the rightmost eight bits of the memory address or I/O port number whenever ALE is logic 1.
- It contains data whenever ALE is logic 0.
- These pins are at high impedance state during a hold acknowledgement.

##### #AD15-AD8 [ADDRESS/DATA]

- The 8086 address/data bus lines compose the upper multiplexed address/data bus on the 8086.
- These lines contain address bits A15-A8 whenever ALE is logic 1 and contains data when ALE is logic 0.
- These pins enter a high-impedance state whenever a hold acknowledgement occurs.

##### #READY [READY]

- This input is controlled to insert wait states into the timing of the Microprocessor.
- If the READY pin is placed at logic 0 level, the MPU enters into wait states and remains idle. If the READY pin is placed at logic 1 level, it has no effect on the operation of the MPU.

##### #INTR [INTERRUPT REQUEST]

- Interrupt request is used to request a hardware interrupt.
- This is maskable, level-triggered, low-priority interrupt.
- On receiving an interrupt on INTR line, microprocessor executes two INTA pulses.
- First INTA pulse- the interrupting device prepares (calculates) the vector number.
- Second INTA – the interrupting device sends the vector number “N” to the microprocessor.
- Control shifts to the location pointed by  $(N \times 4)$  in the IVT and CS and IP are loaded.
- If INTR is held high when  $IF=1$ , the 8086 enters an interrupt acknowledge cycle.

##### #TEST [TEST]

- Bit S5 indicates the condition of IF flag bit.
- Bit S5 indicates the condition of TF flag bit.
- S4 and S3 show which segment is accessed during the current bus cycle.
- The TEST pin is an input that is tested by the WAIT instruction.
- If TEST is a logic 0, the WAIT instruction functions as NOP.
- If TEST is a logic 1, the WAIT instruction waits for TEST to become a logic 0.

TABLE: FUNCTION OF STATUS BITS S3 AND S4

| S4 | S3 | FUNCTION      |
|----|----|---------------|
| 0  | 0  | EXTRA SEGMENT |
| 0  | 1  | STACK SEGMENT |
| 1  | 0  | CODE SEGMENT  |
| 1  | 1  | DATA SEGMENT  |

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

- This pin is most often connected to the 8087 Numeric Coprocessor.
- In Maximum mode, whenever the co-processor is busy, it makes this pin HIGH.
- In Minimum mode, it is connected to ground.

#### #NMI [NON MASKABLE INTERRUPT]

- The NMI interrupt input is similar to INTR except that the Non-Maskable interrupt does not check to see whether the IF flag bit is logic 1.
- If NMI is activated, the microprocessor executes INT 2 and takes control to location 2 \* 4 =00008H in the Interrupt Vector Table (IVT) to get the value of CS and IP.

#### #RESET [RESET]

- The RESET input causes the MPU to reset itself if this pin is held high for a minimum of four clocking periods.
- The 8284 Clock generator provides this signal.
- The 8086 is reset, it begins executing instructions at memory location FFFFOH and whenever the 8086 is reset, it begins executing instructions at memory location FFFFOH and disables future interrupts by clearing the IF flag bit.

#### #CLK [CLOCK]

- The CLOCK pin provides the basic timing signals to the MPU.
- The clock signals must have a duty cycle of 33 percent (high for 1/3 clocking period and low for 2/3) to provide proper internal timing for the 8086.
- An external clock generator like 8284 provides the clock signal.

#### #VCC [POWER SUPPLY]

- The power supply input provides a +5.0V,  $\pm 10\%$  signal to the MPU.

#### #GND [GROUND]

- The GROUND connection is the return for the power supply.
- The GROUND connection is the return for the power supply.
- Note that the 8086 MPU have two pins labeled GND- both must be connected to ground for proper operation.

#### #MN/ MX [MINIMUM/MAXIMUM]

- The MINIMUM/MAXIMUM mode pin selects either minimum mode or maximum mode operation for the MPU.
- If minimum mode is selected the MN/ MX pin must be connected directly to +5.0 V.

#### #B/E/S7 [BUS HIGH ENABLE/STATUS]

- The Bus High Enable pin is used in 8086 to enable the most significant data bus bits (D15-D8) during a read or write operation.
- The state of S7 is always at logic 1.

#### Section 2(MINIMUM MODE PINS)

- Minimum mode operation of 8086 is obtained by connecting the MN/MX pin directly to +5V through a pull up resistor.
- Minimum mode operation of 8086 is obtained by connecting the MN/MX pin directly to +5V through a pull up resistor.

#### #M/ $\overline{O}$

- The M/  $\overline{O}$  (8086) pin select Memory or I/O.
- This pin indicates that the MPU address bus contains either a memory address of an I/O port address.
- This pin is at high impedance state during a hold acknowledge.

#### #WR [WRITE]

- The WR line is a strobe that indicates that the 8086 is outputting data to memory or I/O device.
- During the time that the WR is logic 0, the data bus contains valid data for memory or I/O.
- This pin floats to a high-impedance during a hold acknowledge.

#### #ALE [ADDRESS LATCH ENABLE]

- It shows that the 8086 address/data bus contains address information.
- This address can be a memory address or an I/O port number.
- The ALE signal does not float during a hold acknowledge.

#### #DT/R [DATA TRANSMIT / RECEIVE]

- It shows that the MPU data bus is transmitting or receiving.
- Data Transmitting if Logic 1.
- Data Receiving if Logic 0.

- This signal is used to enable external data bus buffers.

#### #DEN [DATA BUS ENABLE]

- Activates external data bus buffers (bi-directional buffers- 8286)
- It activates the data transceivers (8288 gives the DEN signal).
- It is used to enable the data controller IC - 8288 gives the DEN signal.
- In Maximum mode, Bus Controller IC - 8288 gives the DEN signal.

#### $\#S2$ , $\overline{S1}$ AND $\overline{S0}$

The Status bits in 8086 indicate the function of the current bus cycle.

- These signals are normally decoded by the 8288 Bus Controller.
- In order to achieve maximum mode for use with external coprocessors, connect MN/MX pin to ground.

#### Section 3 (MAXIMUM MODE PINS)

- The HOLD input requests a DMA.
- If the HOLD signal is logic 1, the MPU stops executing SW and places its address, data and control bus at the high-impedance state.
- If HOLD is set to 0, the MPU executes SW normally.

#### #HOLD | HOLD ACKNOWLEDGE

- Hold Acknowledge indicates that that 8086 has entered hold state.
- Hold Acknowledge is combined with IOM and DT/R to decode the function of current bus cycle.

| #SS0  |      | DESCRIPTION |               |
|-------|------|-------------|---------------|
| I/O/M | DT/R | SS0         |               |
| 0     | 0    | 0           | INTERRUPT ACK |
| 0     | 0    | 1           | I/O READ      |
| 0     | 1    | 0           | I/O WRITE     |
| 0     | 1    | 1           | HALT          |
| 1     | 0    | 0           | OPCODE FETCH  |
| 1     | 0    | 1           | MEMORY READ   |
| 1     | 1    | 0           | MEMORY WRITE  |
| 1     | 1    | 1           | PASSIVE       |

#### $\#Q/GT1$ AND $\overline{RQ}/\overline{GT0}$ [REQUEST/GRANT]

- The Request grant pins request DMA during maximum mode operation.
- These lines are bi-directional and are used to both request and grant a DMA operation.

#### $\#I/CK$

- The Lock output is used to lock peripherals of the system.

#### #QS1 AND QS0 [QUEUE STATUS BITS]

The queue status bits show the status of the internal queue.

| FUNCTION                  | QS1 | QS0 |
|---------------------------|-----|-----|
| Queue is idle             | 0   | 0   |
| First byte of opcode      | 1   | 0   |
| Queue is empty            | 0   | 1   |
| Subsequent byte of opcode | 1   | 1   |

#### MINIMUM MODE VS MAXIMUM MODE

- There are two available modes of operation for the 8086: Minimum and Maximum Mode.
- Minimum mode operation is obtained by connecting the mode selection MN/MX to +5V.
- Maximum mode is selected by grounding MN/MX pin.

| INSTRUCTIONS                                              | COMMENTS                                                                                |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------|
| MOV                                                       | Copy byte or word from specified source to specified destination.                       |
| MOV Destination, Source                                   | Source: Register, Memory Location, Immediate<br>Destination: Register, Memory Location. |
| MOV CX,0037H ; CX ← 0037H                                 |                                                                                         |
| MOV BL,[4000H] ; BL ← DS:[4000H]                          |                                                                                         |
| MOV AX,BX ; AX ← BX                                       |                                                                                         |
| MOV DL,[BX] ; DL ← DS : [BX]                              |                                                                                         |
| MOV DS,BX ; DS ← BX                                       | Both, source and destinations cannot be memory locations                                |
| PUSH                                                      | Copy specified source (word) to top of stack and decrement the stack pointer by two.    |
| PUSH Source                                               | - The source must be a word (16 bits).<br>Source : Register, Memory Locations           |
| PUSH BX ; SS:[SP-1] ← BH,<br>SS:[SP-2] ← BL,<br>SP ← SP-2 |                                                                                         |
| POP                                                       | Copy word from top to stack to specified location and increment the stack pointer by 2. |
| POP Destination                                           | Destination: Register (except CS), Memory Location                                      |
| POP CX ; CL ← SS:[SP],<br>CH ← SS:[SP+1]                  |                                                                                         |
| POP DS                                                    |                                                                                         |

#### #MINIMUM MODE OPERATION

- The mode of operation provided by minimum mode is similar to that of 8085A , the most popular Intel 8 bit MPU.
- It is the least expensive way to operate the 8086
- It costs less because all the control signals for Memory and I/O are generated by MPU.
- These control signals are similar to those of Intel 8085A
- 8288 Bus Controller is not required.

#### #MAXIMUM MODE OPERATION

- The Maximum mode is unique and designed to be used whenever a coprocessor exists in a system.(8087 Arithmetic Coprocessor)
- It requires additional external bus controller : 8288
- This 8288 Bus Controller is required because there are not enough pins on the 8086 for bus control during Maximum mode.

|                               |  |                                                                                                       |
|-------------------------------|--|-------------------------------------------------------------------------------------------------------|
|                               |  | <b>IN AX, 16-bit Port_ Addr (direct)</b><br>or DX register (Indirect), or                             |
|                               |  | <b>IN AH, 8-bit Port_ Addr, or</b>                                                                    |
|                               |  | <b>IN AL, 8-bit Port_ Addr</b>                                                                        |
|                               |  | Note: MOV, PUSH & POP are only<br>Instructions that use segment<br>Registers (except CS) as Operands. |
| XCHG                          |  | Exchange word or byte between the source and<br>destination specified in the instruction.             |
| XCHG Destination, Source      |  | Source: Register, Memory Location<br>Destination: Register, Memory Location.                          |
| XCHG AX,BX ; AX ↔ CX          |  | Both source and destinations cannot be memory<br>locations                                            |
| XCHG BL,CH ; BL ↔ CH          |  |                                                                                                       |
| XLAT                          |  | Translate a byte in AL using a table in<br>memory.                                                    |
| E.g. XLAT ; AL ← DS : [BX+AL] |  | It first adds AL + BX to form memory<br>address.<br>It then copies the content into AL                |
| OUT                           |  | <b>Copy a byte or word from accumulator to<br/>specified port.</b>                                    |
| OUT Port_Addr, AX             |  | OUT 2CH,AX ;<br>OUT DX,AX ; [DX] ← [AX] as<br>I/O port pointed by DX is 16-bit port                   |

### 1.2 SIMPLE INPUT AND OUTPUT PORT TRANSFER INSTRUCTIONS

| INSTRUCTIONS | COMMENTS                                                   |
|--------------|------------------------------------------------------------|
| IN           | Copy a byte or word from specified port to<br>accumulator. |

### 1.3 SPECIAL ADDRESS TRANSFER INSTRUCTIONS

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCTT

Microprocessors- Chapter-4  
Copy word at top of stack to flag register and  
increment the stack pointer by 2.

## 2. ARITHMETIC INSTRUCTIONS

### 2.1 ADDITION INSTRUCTIONS

| Microprocessors- Chapter-4                      |                                                                             |
|-------------------------------------------------|-----------------------------------------------------------------------------|
| Prepared By: Er. Ramu Pandey, Asst. Prof., NCTT | Load effective address (offset address) of operand into specified register. |

| Microprocessors- Chapter-4                                                                           |                                                                                                               |
|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| Prepared By: Er. Ramu Pandey, Asst. Prof., NCTT                                                      | Copy word at top of stack to flag register and increment the stack pointer by 2.                              |
| <b>LEA</b>                                                                                           | Load effective address (offset address) of operand into specified register.                                   |
| <b>LEA Register, Source</b>                                                                          | Effective address of PRICE in Data Segment                                                                    |
| E.g:-<br><code>LEA BX,PRICE ; BX ← Effective address of PRICE in Data Segment</code>                 | Load DS register and other specified register from memory.                                                    |
| <b>LDS</b>                                                                                           | Load DS register, Source                                                                                      |
| <b>LDS Register, Source</b>                                                                          | Effective address of DS:BX                                                                                    |
| E.g:-<br><code>LDS BX,[4326H] ; BX ← {DS:[4326], DS:[4326+1]}, DS←{DS:[4326 +2], DS:[4326+3]}</code> | Load DS register and other specified register from memory.                                                    |
| <b>ADC</b>                                                                                           | Add byte + byte + carry flag                                                                                  |
| <b>ADC Destination, Source</b>                                                                       | Both source & destination must be of same size.                                                               |
| ADD AL,74H ; AL ← AL +74H                                                                            | Add specified byte or word in source to the byte or word in destination and stores the result in destination. |
| ADD BX,CX                                                                                            | Add word+word + carry flag                                                                                    |
| <b>ADC CL,BL</b>                                                                                     | Add word+byte + carry flag                                                                                    |
| <b>INC</b>                                                                                           | Increment specified byte or word by 1.                                                                        |
| <b>INC Register</b>                                                                                  | Carry Flag is not affected.                                                                                   |
| LAHF                                                                                                 | Copy to AH with the low byte of the flag register.                                                            |
| SAHF                                                                                                 | Stores AH register to low byte of flag register.                                                              |
| PUSHF                                                                                                | Copy flag register to top of stack and decrement the stack pointer by 2.                                      |

| SBB Destination, Source                   |              | Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT |
|-------------------------------------------|--------------|-------------------------------------------------|
| SBB CH,AL                                 | DEC          | Decrement specified byte or word by 1.          |
| E.g. (3) <sub>10</sub> = (33)ASCII - [AL] | DEC CX       |                                                 |
| (5) <sub>10</sub> = (35)ASCII - [CL]      | NEG          | Form 2's complement.                            |
| ADD AL,CL ; Result = [AL] = 68            | NEG Register |                                                 |
| AAA ; After AAA instruction               | NEG AL       |                                                 |
| Result = [AH]=00 ; [AL] = 08              | CMP          | Compare two specified bytes or words.           |

| CMP Destination, Source                   |           | Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT                                                                                                                                   |
|-------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMP CX,BX                                 | CMP CX,BX |                                                                                                                                                                                   |
| CF ZF SF                                  |           |                                                                                                                                                                                   |
| CX = BX 0 1 0                             |           |                                                                                                                                                                                   |
| CX > BX 0 0 0                             |           |                                                                                                                                                                                   |
| CX < BX 1 0 1                             |           |                                                                                                                                                                                   |
| AAS                                       |           | - ASCII adjust after subtraction.<br>Used to get result in Unpacked BCD form after subtraction of 2 unpacked decimal numbers in ASCII form.<br>This instruction works only in AL. |
| E.g. (9) <sub>10</sub> = (39)ASCII - [AL] |           |                                                                                                                                                                                   |
| (5) <sub>10</sub> = (35)ASCII - [CL]      |           |                                                                                                                                                                                   |
| SUB CX,BX                                 |           |                                                                                                                                                                                   |
| SBB                                       |           |                                                                                                                                                                                   |
| SUB AL,CL ; Result = [AL] = 04            |           |                                                                                                                                                                                   |

### 2.3 MULTIPLICATION INSTRUCTIONS

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

#### MUL

| INSTRUCTIONS | COMMENTS                                                                                                                                                                                                    |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MUL          | Multiply unsigned byte by byte or unsigned word by word.<br>If the source is 8-bit, it is multiplied with <b>AX</b> and the result is stored in <b>DX</b> ( <b>D</b> X-higher byte, <b>A</b> X-lower byte). |

MUL Source (unsigned 8/16 bit register)

MUL BL ; AX  $\leftarrow$  AL  $\times$  BL

MUL BX ; DX AX  $\leftarrow$  AX  $\times$  BX

MUL affects AF, SF, PF, ZF

SUB AL,CL ; Result - C<sub>y</sub> = 0,  
[AL]=2F

DAS ; After DAS instruction C<sub>y</sub> = 0;  
[AL] = 29

So result = +(29)<sub>10</sub>

ANSI  
AAS  
AAM

| INSTRUCTIONS | COMMENTS                                             |
|--------------|------------------------------------------------------|
| MUL          | Multiply signed byte by byte or signed word by word. |

MUL Source

MUL CX

E.g. [A] = (05) unpacked BCD X [CL= (09) unpacked BCD = (0405) unpacked BCD

- It is not really ASCII adjust after multiplication but it is BCD adjust after multiplication
- It is used to get result in unpacked BCD form after performing multiplication of 2 unpacked numbers.
- This instruction works only on AX.

MUL CL ; RESULT - [AH] = 00,  
[AL] = 2D  
AAM ; After AAM instruction  
[AH] = 04; [AL] = 05

So, result = (0405)hex  
(45)dec

MUL BL ; AX ÷ BL, AL ← quotient;  
AH ← remainder  
[AL] = 2D

DIV BX ; {DX:AX} ÷ BX,  
AX ← quotient,  
DX ← remainder

All flags are undefined after DIV instruction.

Note: If the divisor is 0, or the result is too large to fit in AL or AX in 16 bit divisor then Error does a Type 0 interrupt. (Zero Divide Error)

#### AAD

ASCII adjust before division  
BCD to binary convert before division.

#### CBW

Fill upper byte of word with copies of sign bit of lower byte.

#### CWD

Fill upper word of double word with sign bit of lower word.

### 3. BIT MANIPULATION INSTRUCTIONS

#### 3.1 LOGICAL INSTRUCTIONS

If the divisor is 8-bit then the dividend is in AX register.

- After division, the quotient is in AL and remainder in AH

| INSTRUCTIONS | COMMENTS                    |
|--------------|-----------------------------|
| DIV          | Used for Unsigned division. |

| INSTRUCTIONS | COMMENTS                                                       |
|--------------|----------------------------------------------------------------|
| MUL          | Divides a WORD by a BYTE or DOUBLE WORD by a WORD.             |
| DIV          | Divides a WORD by a BYTE or DOUBLE WORD by a WORD.             |
| CBW          | Fill upper byte of word with copies of sign bit of lower byte. |
| CWD          | Fill upper word of double word with sign bit of lower word.    |

| INSTRUCTIONS | COMMENTS                                                                        |
|--------------|---------------------------------------------------------------------------------|
| NOT          | Invert each bit of a byte or word.                                              |
| NOT BX       | NOT Destination                                                                 |
| AND          | AND each bit in a byte/word with the corresponding bit in another byte or word. |

If the divisor is 16-bit then the dividend is in DX-AX register.

- After division, the quotient is in AX and remainder in DX.

DIV Source (unsigned 8/16-bit register - Divisor)

|                         |                                                                                    |
|-------------------------|------------------------------------------------------------------------------------|
| AND Destination,Source  |                                                                                    |
| AND BH,CL               |                                                                                    |
| OR                      | OR each bit in a byte or word with the corresponding bit in another byte or word.  |
| OR Destination,Source   |                                                                                    |
| OR AH,CL                |                                                                                    |
| XOR                     | XOR each bit in a byte or word with the corresponding bit in another byte or word. |
| XOR Destination,Source  |                                                                                    |
| XOR CL,BH               |                                                                                    |
| TEST                    | AND operands to update flags, but don't change the operands.                       |
| TEST Destination,Source |                                                                                    |
| TEST AL,BH              |                                                                                    |

### 3.2 SHIFT INSTRUCTIONS

| INSTRUCTIONS                                                                     | COMMENTS                                             |
|----------------------------------------------------------------------------------|------------------------------------------------------|
| SHL/SAL                                                                          | Shift Bits of Word or Byte Left, Put Zero(s) in LSB. |
| SAL Destination,Count                                                            |                                                      |
| SHL Destination,Count                                                            |                                                      |
| e.g. SAL AL,01; Rotates content of AL, each bit 1 times left as:<br>CF←MSB←LSB←0 |                                                      |

|                       |                                                                                             |
|-----------------------|---------------------------------------------------------------------------------------------|
| SHR                   |                                                                                             |
| SHR Destination,Count | Shift Bits of Word or Byte Right, Put Zero(s) in MSB.                                       |
| 0→MSB→LSB→CF          |                                                                                             |
| SAR                   |                                                                                             |
| SAR Destination,Count | - Shift Bits of Word or Byte Right, Old MSB into New MSB.<br>- Here, sign bit is preserved. |
| MSB→MSB→LSB→CF        |                                                                                             |

### 3.3 ROTATE INSTRUCTIONS

| INSTRUCTIONS | COMMENTS                                                    |
|--------------|-------------------------------------------------------------|
| ROL          | Rotate Bits of Byte or Word Left, MSB to LS and to CF.      |
| ROR          | Rotate Bits of Byte or Word Right, LSB to MSB               |
| RCL          | Rotate Bits of Byte or Word Left, MSB to CF and CF to LSB.  |
| RCR          | Rotate Bits of Byte or Word Right, LSB TO CF and CF TO MSB. |

#### 4. PROGRAM EXECUTION TRANSFER INSTRUCTIONS

##### 4.1 UNCONDITIONAL TRANSFER INSTRUCTION

| INSTRUCTIONS | COMMENTS                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------|
| CALL         | Call a Subprogram/Procedure.                                                                     |
| RET          | Return From Procedure to Calling Program.                                                        |
| JMP          | Goto Specified Address to Get Next Instruction<br>(Unconditional Jump to Specified Destination). |

##### 4.2 CONDITIONAL TRANSFER INSTRUCTION

| INSTRUCTIONS | COMMENTS                                        |
|--------------|-------------------------------------------------|
| JA/JNBE      | Jump if Above/Jump if Not Below or Equal.       |
| JAE/JNB      | Jump if Above or Equal/Jump if Not Below.       |
| JB/JNAE      | Jump if Below/Jump if Not Above or Equal.       |
| JBE/JNA      | Jump if Below or Equal/Jump if Not Above.       |
| JC           | Jump if Carry Flag CF=1.                        |
| JE/JZ        | Jump if Equal/Jump if Zero Flag (ZF=1).         |
| JG/JNLE      | Jump if Greater/Jump if Not Less than or Equal. |

Jump if Greater than or Equal/Jump if Not Less than.

JGE/JNL

Jump if Less than/Jump if Not Greater than or Equal.

JL/JNGE

Jump if Less than or Equal/Jump if Not Greater than.

JLE/JNG

Jump if No Carry i.e. CF=0

JNC

Jump if Not Equal/Jump if Not Zero(ZF=0)

JNE/JNZ

Jump if No Overflow.

JNO

Jump if Not Parity/Jump if Parity Odd.

JNP/JPO

Jump if Not Sign(SF=0)

JNS

Jump if Parity/Jump if Parity Even (PF=1)

JP/JPE

Jump if Sign (SF=1)

JS

##### 4.3 ITERATION CONTROL INSTRUCTIONS

| INSTRUCTIONS | COMMENTS                                            |
|--------------|-----------------------------------------------------|
| LOOP         | Loop Through a Sequence of Instructions Until CX=0. |

Microprocessors- Chapter-4

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

|               |                                                               |
|---------------|---------------------------------------------------------------|
| LOOP/LOOPZ    | Loop Through a Sequence of Instructions While ZF=1 and CX!=0. |
| LOOPNE/LOOPNZ | Loop Through a Sequence of Instruction While ZF=0 & CX!=0.    |
| JCXZ          | Jump to Specified Address if CX=0.                            |

4.4 INTERRUPT INSTRUCTIONS

| INSTRUCTIONS | COMMENTS                                                 |
|--------------|----------------------------------------------------------|
| INT          |                                                          |
| INTO         | Interrupt Program Execution if OF=1                      |
| IRET         | Return From Interrupt Service Procedure to Main Program. |

5 PROCESSOR CONTROL INSTRUCTIONS

5.1 FLAG SET/CLEAR INSTRUCTION

| INSTRUCTIONS | COMMENTS                    |
|--------------|-----------------------------|
| STC          | Set Carry Flag CF to 1.     |
| CLC          | Clear Carry Flag to 0.      |
| CMC          | Complement the State of CF. |

Microprocessors- Chapter-4

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

|     |                                                  |
|-----|--------------------------------------------------|
| STD | Set Direction Flag to 1.                         |
| CLD | Clear Direction Flag to 0.                       |
| STI | Set Interrupt Flag to 1.<br>(Enable INTR Input). |
| CLI | Clear Interrupt Enable to 0                      |

5.2 NO OPERATION INSTRUCTION

| INSTRUCTIONS | COMMENTS                           |
|--------------|------------------------------------|
| NOP          | No Action Except Fetch and Decode. |

5.3 EXTERNAL HARDWARE SYNCHRONIZATION INST.

| INSTRUCTIONS | COMMENTS                                             |
|--------------|------------------------------------------------------|
| HLT          | Halt (Do Nothing) Until Interrupt or Reset.          |
| WAIT         | Wait Until Signal On the TEST Pin is Low.            |
| ESC          | Escape to External Coprocessor Such as 8087 or 8089. |
| LOCK         | Prevents Another Processor From Taking the Bus       |

Microprocessors- Chapter-4

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT  
While the Adjacent Instruction Executes.

6 STRING INSTRUCTIONS

| INSTRUCTIONS        | COMMENTS                                                                                                                                                                                                                                                                       |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REP                 | Repeat Instruction Until CX=0.                                                                                                                                                                                                                                                 |
| REPE/REPZ           | Repeat if Equal/Repeat if Zero                                                                                                                                                                                                                                                 |
| REPNE/REPNZ         | Repeat if Not Equal/Repeat if Not Zero.                                                                                                                                                                                                                                        |
| MOVSB/MOVSW         | Move Byte or Word From One String to Another.<br><br>E.g. MOVSB<br>; Moves content of memory<br>location pointed by DS:[SI] to<br>ES:[DI]<br><br>After executing string instruction<br>if direction flag is reset then<br>content of DI is incremented by 1<br>and vice versa. |
| COMPS/COMPSB/COMPSW | Compare Two String Bytes or Two String Words.                                                                                                                                                                                                                                  |

Microprocessors- Chapter-4

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT  
SCAS/SCASB/SCASW

- Compares a Byte in AL or Word in AX With a Byte or Word Pointed By DI in ES.
- Subtract content of memory locations ES:[DI] from AL.
- Data will not change , only flags are affected.

### Assembler:

- Assembler:**

  - Program that converts assembly language into machine language is called Assembler.
  - E.g.s. TASM (Turbo Assembler), MASM (Microsoft Assembler), AS86

**Programming:**

Advantages of Assembly Language Programming:

- A Program written in Assembly Language requires considerably less Memory and execution time than that of High Level Language.
  - Assembly Language gives a programmer the ability to perform highly technical tasks.
  - Resident Programs (that resides in memory while other programs execute) and Interrupt Service Routine (that handles I/P and O/P) are almost always developed in Assembly Language.
  - Provides more control over handling particular Hardware requirements.
  - Generates smaller and compact executable modules.
  - Results in faster execution.

- Results in faster execution.

| LABEL | OPCODE FIELD | OPERAND FIELD | COMMENTS                |
|-------|--------------|---------------|-------------------------|
| NEXT: | ADD          | AL,07H        | ; Add correction factor |

- Assembly language statements are usually written in a standard form that has 4 fields.
  - A label is a symbol used to represent an address. They are followed by colon
  - Labels are only inserted when they are needed so it is an optional field.
  - The opcode field of the instruction contains the mnemonics for the instruction to be performed
  - The instruction mnemonics are sometimes called as operation codes.
  - The operand field of the statement contains the data, the memory address, the port address or the name of the register on which the instruction is to be performed.
  - The final field in an assembly language statement is the comment field which starts with semicolon. It forms a well documented program.

ASSEMBLY LANGUAGE PROGRAM DEVELOPMENT TOOLS  
Prepared By: Er. Ramu Panigrahi

EDITOR

- An Editor is a Program which allows you to create a file containing the Assembly Language statements for your Program.

ASSEMBLER

- An Assembler Program is used to translate the assembly language mnemonics for instruction to the corresponding binary codes.

JUNKER

- A Linker is a Program used to join several files into one large .obj file. It produces .exe file so that the program becomes executable.

## LOCATOR

- A Locator is a program used to assign the specific address of where the segment of object code is to be loaded into memory.

- It usually
- A Locator progr

5. DEBUGGER

  - A Debugger is a program which allows you to load your .obj code program into system memory, execute program and troubleshoot.
  - It allows you to look at the content of registers and memory locations after your program runs.
  - It allows setting the breakpoint.

## 6 EMULATOR

- An Emulator is a mixture of hardware and software.
  - It is used to test and debug the hardware and software of an external system such as the prototype of a Microprocessor based system.

#### **Types of Assembler:**

1. One-pass Assembler,
  2. Two-pass Assembler

(1) One-pass Assembler:

- This assembler goes through the Assembly Language Program (ALP) once and then translates it into machine code.
- Supports backward reference and problem with forward reference.

E.g.

|                  |                   |
|------------------|-------------------|
| Label: MOV AX,CX | JMP Label1        |
| .....            | .....             |
| JMP Label        | Label1: MOV AX,CX |

Remark: Does not Support

(2) Two-pass Assembler:

- This assembler scans the assembly language program twice.
- In the first pass, it generates the table of symbols which consists of label with the address assigned to them.
- Forward/Backward reference is supported.
- On the second pass, the assembler translates ALP into machine code.
- E.g. MASM

Macro Assembler:

- Translates the program written in macro language into machine language.
- A macro is a group of instructions that performs the task as a procedure.
- Disadvantage of using procedure are need of stack over head time required to call plus return to calling program.
- Macro sequences execute faster than procedure.
  - No call and return instructions
- Each time encountering macro name, macro assembler replaces it with appropriate instruction sequence (i.e. copy paste)

E.g.  
MOVE MACRO A,B ; MOVE is a macro name and A & B are parameters or arguments  
PUSH AX  
MOV AX,B  
MOV A,AX  
POP AX  
ENDM; End of macro

Program:

MOVE VAR1, VAR2 ; MOVE is a macro

Note: Macro with/without argument is both possible.

E.g. terminate macro

Mov ah, 4Ch

Int 21h

Program

At last.

Terminate



ASSEMBLY LANGUAGE PROGRAM FEATURES

#PROGRAM COMMENTS

- The use of Comments throughout a program can improve its clarity, especially in Assembly Language.
- A Comment begins with Semicolon.

EXAMPLE  
MOV AX, BX ; Adds the Content of BX with AX and stores the result in AX.

#### #RESERVED WORDS

- Instructions : MOV, ADD
- Directives : END,SEGMENT
- Operators : FAR,OFFSET
- Predefined Symbols : @DATA

#### #IDENTIFIERS

- An Identifier (or symbol) is a name that you apply to an item in your program that you expect to reference. The two types of identifiers are NAME and LABEL.
- NAME : Refers to the Address of a data item  
COUNTER DB 0
- LABEL: Refer to the Address of an instruction, procedure, or segment.  
MAIN PROC

#### #STATEMENTS

- An Assembly Program consists of a set of statements. The two types of statements are:
  1. INSTRUCTION
    - Instructions such as MOV, ADD, etc which the Assembler translates to Object Code.
  2. DIRECTIVES
    - Directives tell the Assembler to perform a specific action, such as define a data item etc.

### ASSEMBLY LANGUAGE PROGRAMMING USING MASM GENERAL PATTERN FOR WRITING ALP IN MASM

[PAGE DIRECTIVE]

[TITLE DIRECTIVE]  
[MEMORY MODEL DEFINITION]  
[SEGMENT DIRECTIVES]  
[PROC DIRECTIVES]  
.....  
.....  
.....  
.....  
[END DIRECTIVES]

BASIC FORMAT OF ALP BASED UPON THE GENERAL PATTERN  
PAGE 60,80  
TITLE "ALP TO PRINT FACTORIAL NO"

MODEL [MODEL NAME]  
STACK  
DATA ..... ; INITIALIZE DATA VARIABLES  
.CODE

MAIN PROC

.....  
.....  
..... ; INSTRUCTION SETS  
.....  
.....  
.....

```
MAIN ENDP  
END MAIN
```

#### DIRECTIVES

- Assembly Language supports a number of statements that enable to control the way in which a source program assembles and lists. These Statements are called Directives.
- They act only during the assembly of a program and generate no machine executable code.
- Their main task is to inform the assembler about the start/end of the segment, procedure or program, to reserve the appropriate space for data storage, etc
- They are called pseudo-instructions because they are seem like instructions in program but are not instructions in real and are not converted into object code during assembling.
- The most common Directives are PAGE, TITLE, PROC, END, etc.

- The important assembler directives are explained below:

#### # PAGE DIRECTIVE

- The PAGE Directive helps to control the format of a listing of an assembled program.
- It is optional Directive.
- At the start of program, the PAGE Directive designates the maximum number of lines to list on a page and the maximum number of characters on a line.
- Its format is  
PAGE [LENGTH], [WIDTH]
- Omission of a PAGE Directive causes the assembler to set the default value to PAGE 50,80

#### # TITLE DIRECTIVE

- The TITLE Directive is used to define the title of a program to print on line 2 of each page of the program listing.
- It is also optional Directive.
- Its format is  
TITLE [TEXT]

#### #DOSSEG

- The DOSSEG directive tells the MASM to place the segments( code, data and stack ) in the standard order.

#### #SEGMENT DIRECTIVE

- The SEGMENT Directive defines the start of a segment.
- A Stack Segment defines stack storage, a data segment defines data items and a code segment provides executable code.
- MASM provides simplified Segment Directive.
- The format (including the leading dot) for the directives that defines the stack, data and code segment are

.STACK [SIZE]

.DATA

..... Initialize Data Variables

.CODE

The Default Stack size is 1024 bytes.

To use them as above, Memory Model initialization should be carried out.

#### #MEMORY MODEL DEFINTION

- The different models tell the assembler how to use segments to provide space and ensure optimum execution speed.
- The format of Memory Model Definition is  
MODEL [MODEL NAME]
- The Memory Model may be TINY, SMALL, MEDIUM, COMPACT, LARGE AND HUGE.

| MODEL TYPE | DESCRIPTION                                               |
|------------|-----------------------------------------------------------|
| TINY       | All DATA, CODE & STACK Segment must fit in one Segment of |

| Microprocessors- Chapter-4                      |                                                                     |
|-------------------------------------------------|---------------------------------------------------------------------|
| Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT |                                                                     |
| SMALL                                           | Size <=64K.                                                         |
| MEDIUM                                          | One Code Segment of Size <=64K.<br>One Data Segment of Size <=64 K. |
| COMPACT                                         | One Data Segment of Size <=64K.<br>Any Number of Code Segments.     |
| LARGE                                           | One Code Segment of Size <=64K.<br>Any Number of Data Segments.     |
| HUGE                                            | Any Number of Code and Data Segments.                               |

#### #THE PROC DIRECTIVE

- The Code Segment contains the executable code for a program, which consists of one or more procedures, defined initially with the PROC Directive and ended with the ENDP Directive.
- Its Format is given as:

PROCEDURE NAME PROC

.....  
.....  
.....

PROCEDURE NAME ENDP

#### #END DIRECTIVE

- As already mentioned, the ENDP Directive indicates the end of a procedure.
- An END Directive ends the entire Program and appears as the last statement.
- Its Format is

PT PROC  
ENDP  
SE DATA DE  
JN MN(0)

END [PROCEDURE NAME]

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

#### #PROCESSOR DIRECTIVE

- Most Assemblers assume that the source program is to run on a basic 8086 level.
- As a result, when you use instructions or features introduced by later processors, you have to notify the assemblers by means of a processor directive as .286,.386,.486 or .586
- This directive may appear before the Code Segment.

#### #THE EQU DIRECTIVE

- It is used for redefining symbolic names

#### EXAMPLE

DATAX DB 25

DATA EQU DATAX

#### #THE .STARTUP AND .EXIT DIRECTIVE

- MASM 6.0 introduced the .STARTUP and .EXIT Directive to simplify program initialization and Termination.
- .STARTUP generates the instruction to initialize the Segment Registers.
- .EXIT generates the INT 21H function 4ch instruction for exiting the Program.

#### #DATA DEFINITION DIRECTIVES

- In assembly language, we define storage for variables using data definition directives.
- Data definition directive create storage during assembling time.
- The Format of Data Definition is given as

[NAME] DN [EXPRESSION]

#### EXAMPLES

STRING DB 'HELLO WORLD'

NUM1 DB 10

NUM2 DB 90

| DEFINITION            | DIRECTIVE |
|-----------------------|-----------|
| BYTE                  | DB        |
| WORD(2 bytes)         | DW        |
| DOUBLE WORD (4 bytes) | DD        |
| FAR WORD              | DF        |
| QUAD WORD (8 bytes)   | DQ        |
| TEN BYTES             | DT        |

- DB**
  - The DB directive creates storage for a byte or group of bytes, and optionally assigns starting values.
  - e.g. num DB 20h,43h,10h,02h      - multiple bytes
  - num DB 12h                      - 1 byte
  - data db ?                      - undefined byte.

- DW**
  - The DW directive creates a storage for a word or list of words
  - e.g. data DW 1234h,4567h
  - data2 DW abcdh

- #DUP Operator**
  - The DUP operator allocates multiple occurrence of a value.
  - Duplication of Constants in a Statement is also possible and is given by

[NAME] DN [REPEAT-COUNT DUP (EXPRESSION)]

#### EXAMPLES:

- |                          |                                     |
|--------------------------|-------------------------------------|
| DATAX DB 5 DUP(12)       | ; 5 Bytes containing hex 0c0c0c0c0c |
| DATA DB 10 DUP(?)        | ; 10 Words Uninitialized            |
| DATAZ DB 3 DUP(5 DUP(4)) | ; 44444 44444 44444                 |

#### 1. CHARACTER STRINGS

- Character Strings are used for descriptive data.
- Consequently DB is the conventional format for defining character data of any length
- An Example is
- DB "Computer City"
- DB "Hello World"
- DB "NCIT College"

#### 2. NUMERIC CONSTANTS

- |              |                     |
|--------------|---------------------|
| #BINARY      | : VAL1 DB 10101010B |
| #DECIMAL     | : VAL1 DB 230       |
| #HEXADECIMAL | : VAL1 DB 23H       |

#### PROCEDURES AND MACROS

##### Procedures:

- Procedure or a subroutine or a function is a key concept of modular programming, the essential way to conquer complexity.
- A procedure is a reusable set of instructions that has a name.
- Only one copy of procedure is stored in memory; and it can be called as many times as needed.
- "CALL" transfers control to the procedure like a jump; but unlike a jump, procedure has a "RETURN" instruction which returns control to the instruction following the CALL instruction. During the call and return process, the information is stored temporarily in stack.
- Further, nested procedures are also possible. In other words, Procedure A can call Procedure B which in turn calls Procedure C. After completing Procedure C, control returns to Procedure B and after completing Procedure B control returns to Procedure A.
- It is also possible for a procedure to call itself (a recursive procedure).

- A procedure can be in the same code segment as that of the main program (Intra-segment). In such a case, we specify only IP as relative distance or indirectly as actual value. This is known as NEAR CALL.
- Moreover, the procedure may also be in different code segment (Inter segment). In such a case, we need to specify both IP and CS (directly or indirectly). This is known as a FAR CALL.
- In a program, procedure starts with PROC directive and ends with ENDP directive.

Near CALL Instruction:

- Similar to Near Jump except that current IP is saved on the stack before transferring control to the new IP with CS remaining the same.
- This instruction is 3-byte long.

Example:

Main Program:

1

..

CALL MULT ; Calling a procedure, transfer a control to procedure named as MULT.

..

; Procedure definition

MULT PROC NEAR USES BX

MOV AX, 1

ADD AX, BX

RET

MULT ENDP

.... ..

CALL SRI

*Macro is a group of instructions  
written in assembly language  
which is expanded by the preprocessor*

FAR CALL instruction:

- FAR CALL is like a FAR JMP in the sense that it can call a procedure available anywhere in the code space.

In this case, the target address is directly specified as a new CS:IP. Both current IP and CS are saved on the stack and then control is transferred to the new CS:IP.

This instruction is 5-byte long.

Example:

SUM1 PROC FAR

.....

SUM1 ENDP

Now, a call to SUM1 is assembled as FAR CALL.

Return from Procedure:

We use a RET instruction to "return" from the called procedure. The control returns to the instruction following the CALL instruction in the calling program. Corresponding to the two varieties of CALL instructions (near & far), two forms of RET instructions (near & far) exist.

Macro:

- Macro is a group of instructions with a name, which provides several mechanisms useful for the development of generic programs.
- When a macro is invoked, the associated set of instructions is inserted in place into the source, replacing the macro name. This "macro expansion" is done by a Macro Preprocessor and it happens before assembly. Thus, the actual Assembler sees the "expanded" source.
- The body of the macro is defined between a pair of directives, MACRO and ENDM.

Examples of Macro Definitions:

; Definition of Macro named SAVE :

|         |       |
|---------|-------|
| SAVE    | MACRO |
| PUSH AX |       |
| PUSH BX |       |
| PUSH CX |       |

ENDM

; Another Macro named RETRIEVE is defined here  
 RETRIEVE MACRO

POP CX

POP BX

POP AX

ENDM

Now the macro is called in the main program i.e. macro invocations is as shown below:

```
SAVE
MOV CX, DA1
MOV BX, DA2
ADD AX, BX
RETRIEVE ; Invoke macro
```

**Macro Vs Procedure:****(1) Procedure:**

- Only one copy exists in memory. Thus memory consumed is less.
- “Called” when required.
- Return address (IP or CS:IP) is saved on stack before transferring control to the subroutine through CALL instruction. It should be popped again when control comes back to calling program with RET instruction.
- Execution time overhead is present because of the call and return instructions.
- If more lines of code, better to write a procedure.

**(2) Macro:**

- When a macro is “invoked”, the corresponding code is “inserted” into the source. Thus multiple copies of the same code exist in the memory leading to greater space requirements.
- However, there is no execution overhead because there are no additional call and return instructions. The code is in-place.
- Good if few instructions are in the Macro body.
- No use of stack for operation

**8086 System Timing Diagram****BASIC BUS OPERATION:**

- The Three buses of 8086 are Address, Data and Control.
- If Data are written to the memory, the MPU outputs the memory address on the address bus, outputs the data to be written into memory on the data bus, and issues a write( ) to memory.
- If Data are to be read from the memory, the MPU outputs the memory address on the address bus issues a read memory signal and accepts data via data bus.
- 8086 operates in two operating modes. On the basis of the mode it is operating the variation of control signals occurs.

- For minimum mode, the control signals are generated by the 8086 processor but in case of maximum mode, the control signals are generated by the Bus Controller as well.

### 1. MINIMUM MODE CONFIGURATION



- 8086 operates in Minimum mode when  $MN/MX = 1$ ,
- In this mode only one processor 8086 is used.
- The important chips used for operating 8086 in this mode are:
  - Latches (8282) [Here ALE of 8086 is given to  $\overline{STB}$  of 8282]
  - Transceiver 8286:
  - $\overline{DEN}$  of 8086 is given to  $\overline{STB}$  of 8286,
  - $DT/R$  of 8086 is given to T of 8286,
  - When  $\overline{DEN} = 0$ ,  $DT/R = 1$ , then 8086 is transmitting data.

- When  $\overline{DEN} = 0$ ,  $DT/R = 0$ , then 8086 is receiving data.

- In minimum modes, 8086 generates control signals such as  $\overline{WR}$ ,  $\overline{RD}$ , and  $M/I/O$  for external peripheral devices.

### 2. MAXIMUM MODE CONFIGURATION



- 8086 Works in Maximum mode when  $MN/MX = 0$
- In Maximum mode, there is at least one more processor in the system besides 8086
- Clock is provided by 8284 Clock Generator
- The most significant part of the Maximum mode mode circuit is 8288 Bus Controller
- Instead of 8086, the bus controller provides the various control signals needed to the system in maximum mode
- Address from the address bus is latched into 8282, 8-bit latch, 3 such latches are needed.
- The ALE for this latch is given by 8288 Bus Controller
- The ALE is connected to  $\overline{STB}$  of latch
- The data bus is driven through 8286 transceiver, 2 such transceiver are needed
- The transceivers are enabled through DEN signals, while the direction of data is controlled by  $DT/R$ . (DEN for 8288 is active high)
- Both these signals are given by 8288 Bus Controller.

#### Functional Chips:

##### 1. 8284A: CLOCK GENERATOR

The 8284 is an additional component to the 8086 MPU.

The 8284A provides the following basic functions or signals: Clock generation, RESET synchronization, READY synchronization etc.



Fig. Connection of 8284A with 8086 microprocessor

8284A can produce clock in two ways:

By applying output of pulse generator at EFI (External Frequency Input). Now, we have to keep  $F/C = 1$ .

By connecting crystal oscillator across  $X_1$  and  $X_2$ . Now we have to keep  $F/C = 0$  (Frequency / Crystal) = 0.

In both the cases, the output clock frequency of 8284 is one-third of input frequency.

##### 2. 8282: ADDRESS LATCH (20 Pin DIP IC)

➤ In 8086 the address bus is multiplexed with the data bus and status signals. To de-multiplex this bus 8282 address latch is used.

➤ As the address bus is of 20 bit, three latches are required, each of 8-bit.

The block diagram of 8282 latch is as shown below:



- 8282 address latch is selected, when  $\overline{OE}$  is low and whenever  $\overline{STB}$  goes high, input is transferred to output. And when  $\overline{STB}$  remains low, output remains previous value.



Figure: 8282 Address Latch

#### PIN OUTS AND FUNCTIONS

##### #A0-A7

- DATA INPUT Pins.
- Data are inputted to 8082 Address Latch from Data Input Pins.

##### #B0-B7

- DATA OUTPUT Pins.
- Data are outputted through Data Output pins.

##### #STB

When  $STB = 0$  then it holds Data.  
When  $STB = 1$  then data bits are transferred from the Bus.  
 $\# \overline{OE}$   
Output Enable

#### 8286: TRANSCEIVER

- 8286 Transceiver allows two way communications.
- It acts as bi-directional buffer and increases the driving capability of data bus.
- It is enabled when  $\overline{OE} = 0$ .



T (connected to DT/R) controls the direction of data:  
If T=1, data is transmitted.  
If T=0, data is received.  
As the data bus of 8086 is of 16 bits, two transceivers are required.  
It is available in 20 pin DIP package.



Figure: 8286 Transceiver

#### PIN OUTS AND FUNCTIONS

##### #A0-A7

- Local Bus Data I/O Pins.

##### #B0-B7

- System Bus Data I/O Pins.

##### #OE [OUTPUT ENABLE]

- Output Enable.

##### #T [TRANSMIT CONTROL PIN]

- Transmit Control Pin.
- When T=1, Data are Transmitted.
- Data are inputted from Local Bus Data I/O pins.
- Data are outputted by System Bus Data I/O Pins.
- When T=0, Data are Received.
- Data are inputted by System Bus Data I/O pins.
- Data are outputted by Local Bus Data I/O Pins.

#### 8288 Bus Controller (20 Pin DIP IC):

It is used to produce different bus control signals like  $\overline{MRDC}$  (Memory Read Command),  $\overline{MWTC}$  (Memory Write Command),  $\overline{IORC}$  (Input Output Read Command),  $\overline{IOWC}$  (Input Output Write Command), etc depending on the condition of status signals ( $S_2$ ,  $S_1$  and  $S_0$ ) during Maximum mode operation.

#### PIN OUTS AND FUNCTIONS

##### #S2,S1 AND S0

- Status inputs are connected to the status o/p pins on the 8086 MPU.
- These 3 control signals are decoded to generate the timing signals for the system

##### #CLK [CLOCK]

- The Clock I/P provide internal timing and must be connected to the CLK O/P pin of the 8284A clock generator.

##### #ALE

- The Address Latch Enable O/P is used to demultiplex address/data bus.

##### #DEN

- The Data Bus Enable pin control the bi-directional data bus buffer in the system.

##### #DT/R

- The Data Transmit/Receive signal is output by 8288 to control the direction of the bi-directional data bus buffers.

##### #AEN

- The Address Enable I/P cause the 8288 to enable the memory control signals.

##### #CEN

- The Control Enable I/P enable the command output pins on the 8288.

#### #IOB

- The I/O bus mode input selects either the I/O Bus mode or System Bus mode.

#### #AIOWC

- The Advanced I/O Write is a command O/P used to provide I/O with an advanced I/O write control signal.

#### #IOWC

- The I/O Write command O/P provides I/O with its main write signal.

#### #IORC

- The I/O Read command O/P provides I/O with its read control signal.

#### #AMWC

- The Advanced Memory Write control pin provides memory with an advanced write signal.

#### #MWTC

- The Memory Write Control pin provides memory with its normal write control signal.

#### #MRDC

- The Memory Read Control pin provides memory with a read control signal.

#### #INTA

- The Interrupt Acknowledge O/P acknowledges an Interrupt Request input applied to INTR Pin.

#### #MCE/PDEN

- The Master Cascade / Peripheral Data Output select cascade operation for an interrupt controller if IOB is grounded.
- It enables the I/O Bus Transceiver if IOB is tied high.

Q13  
Q12  
m



Fig. Bus Cycle For Minimum mode ( I/O Read or Memory Read)

#### During T1 state:

- When ALE goes high, o/p of latch will be  $\overline{BHE}$  and A19 – A0 ( A19- A16 will be zero for I/O operation )
- $\overline{DT/R}$  go low and thereby 8086 inform 8286 transceiver to receive data from i/p device or memory.
- $M/\overline{IO}$  takes proper value, '0' for I/O operation and '1' for memory operation.

#### During T2 state:

- The status signals S7- S3 available on status bus.
- $\overline{RD}$  goes low and so memory or i/p device enabled to give data.
- $\overline{DEN}$  goes low and data buffer of 8286 is enabled.

Note: If the peripheral device ready for data transfer, then ready signal goes high. If they are not ready for data transfer, then ready signal goes low. READY signal has to be given before T3 or at the beginning of T3.

During T3 state:

- Microprocessor checks ready signal. If it is high microprocessor enters T4 state, if it is low microprocessor produces WAIT state and then checks READY.
- If it is high, it enters into T4. If it is low, it repeats the above process.

During T4 state:

- Microprocessor accepts data from data bus (data bus already received data from memory or input device)
- $\overline{RD}$  goes high and so memory or input device is disabled.
- $\overline{DEN}$  goes high and so data buffer of 8286 is disabled.

BUS CYCLE FOR O/P OPERATION (Memory Write or I/O Write)



Fig. Bus Cycle For O/P Operation (Memory Write or I/O Write)

During T1 state:

- When ALE goes high, o/p of latch will be  $\overline{BHE}$  and A19 - A0 (A19- A16 will be zero for I/O operation )
- $DT/\overline{R}$  goes low and thereby 8086 informs 8286 transceiver to receive data from i/o device or memory.
- $M/\overline{IO}$  takes proper value, '0' for I/O operation and '1' for memory operation.

During T2 state:

- The status signals S7- S3 available on status bus.
- $WR$  goes low and so memory or o/p device enabled to give data.
- $\overline{DEN}$  goes low and data buffer of 8286 is enabled.

During T3 state:

- Microprocessor check ready signal. If it is high microprocessor enters T4 state, if it is low microprocessor produces WAIT state and then checks READY.
- If it is high, it enters into T4. If it is low, it repeats the above process.

During T4 state:

- Microprocessor accepts data from data bus (data bus already received data from memory or input device)
- $\overline{WR}$  goes high and so memory or output device is disabled.
- $\overline{DEN}$  goes high and so data buffer of 8286 is disabled.

**8086 System Timing Diagram for Maximum Mode:**

In Maximum mode,  $\overline{S_2}$ ,  $\overline{S_1}$  and  $\overline{S_0}$  are given to Bus controller 8288. 8288 Bus Controller is used to produce different control signals depending on the combination of those signals  $\overline{S_2}$ ,  $\overline{S_1}$  and  $\overline{S_0}$ . The generation of control signals is as shown below:

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

**$\overline{\text{MRDC}}$  (Memory Read):** It is used to read data from memory.

**$\overline{\text{MWTC}}$  (Memory Write):** It is used to write data from memory.

**$\overline{\text{IORD}}$  (I/O Read):** It is used to read data from I/O device.

**$\overline{\text{IOWC}}$  (I/O Read):** It is used to write data into I/O device.

**$\overline{\text{AMWTC}}$  (Advanced Memory Write Command):** It is similar to  $\overline{\text{MWTC}}$  except one difference i.e. it is activated one clock cycle earlier. This gives slow memory, an extra clock cycle to prepare itself to accept data.

**$\overline{\text{AMWC}}$  (Advanced IO Write Command):** It is similar to  $\overline{\text{IOWC}}$  except one difference i.e. it is activated one clock cycle earlier. This gives slow I/O device, an extra clock cycle to prepare itself to accept data.

**ALE (Address Latch Enable):** It is used to enable the address latch.

$DT/\bar{R}$  (Data Transmit/ Receive): It is given to transceiver. It is used to control direction of dataflow.

DEN (Data Enable): It is given to transceiver through a NOT gate. It is used to enable data buffer of transceiver.

$\bar{AEN}$ , IOB, CEN: They are input signal. They are used in multi-processor environment. 8288 is enabled when CEN is high. If IOB=0,  $\bar{AEN}=X$ , then 8288 is in I/O bus mode. When CEN=0, 8288 is disabled.

MCE/  $\overline{PDEN}$ : It is o/p signal. In system bus mode, it is known as MCE (Master Cascade Enable). It is used to control cascaded 8259.

#### Bus Cycle for Input Operation (I/O Read or Memory Read) Maximum Mode:



Fig. 8086 Maximum mode for Input Operation (I/O Read or Memory Read)

#### During T1 State:

- At the beginning of T1,  $\overline{S2}$ ,  $\overline{S1}$  and  $\overline{S0}$  takes proper value; these values are given to bus controller 8288. Now 8288 produce proper control signals.

- First it makes ALE high and so o/p of latch will be  $\overline{BHE}$  and A19-A0
- Then it makes  $DT/\bar{R}$  low so transceiver can receive data.

#### During T2 State:

- The status signal S7- S3 is available on status bus.
- DEN goes high and due to not gate its o/p will be low. Data buffer of transceiver is enabled.

- $\overline{MRDC}$  or  $\overline{IORC}$  goes low and so memory or i/p device is enabled to give data on data bus

#### During T3 State:

- Microprocessor check READY signal, if it is high microprocessor enters into T4 state otherwise waits for it to become high.

#### During T4 State:

- Microprocessor accepts data from data bus.
- $\overline{MRDC}$  or  $\overline{IORC}$  goes high so memory is disabled.
- DEN goes low and due to not gate its o/p goes high so data buffer of transceiver is disabled.



Fig. 8086 Maximum mode for Input Operation (I/O Write or Memory Write)

#### During T1 State:

- At the beginning of T1 (or just before T1),  $\overline{S_2}$ ,  $\overline{S_1}$  and  $\overline{S_0}$  takes proper value; these values are given to bus controller 8288. Now 8288 produce proper control signals.
- First it makes ALE high and so o/p of latch will be  $\overline{BHE}$  and A<sub>19</sub>-A<sub>0</sub>
- Then it makes  $DT/\overline{R}$  goes high so transceiver can transmit data.
- DEN goes high and due to NOT gate its o/p goes low and so data buffer of transceiver enabled.

#### During T2 State:

- The status signal S<sub>7</sub>- S<sub>3</sub> is available on status bus.

➤  $\overline{AMWTC}$  or  $\overline{AIOWC}$  goes low and so memory or i/p device is enabled to give data on data bus

#### During T3 State:

- Microprocessor check READY signal, if it is high microprocessor enters into T4 state otherwise waits for it to become high.

#### During T4 State:

- Microprocessor accepts data from data bus.
- $\overline{AMWTC}$  or  $\overline{AIOWC}$  goes high so memory or I/O device is disabled.
- DEN goes low and due to NOT gate its o/p goes high so data buffer of transceiver is disabled.

### Introduction to Intel 80386:

- Intel 80386, also known as i386 or 386 is a 32-bit processor introduced in 1985.
- As the original implementation of the 32-bit extension of the 80286 architecture, the 80386 instruction set, programming model, and binary encodings are still the common denominator for all 32-bit x86 processors, which is termed as *i386-architecture*, *x86* or *I4-32*.
  - It has 32-bit address bus.
  - The 32-bit ALU allows the 80386 to process data faster and the 32-bit address bus allows the 80386 to address up to 4GB of memory.
  - The 80386 featured three operating modes: real mode, protected mode and virtual mode.
  - The protected mode, which was present in 80286 was extended to allow the 386 to address up to 4GB, so the memory segments can be as large as 4GB.
  - The memory management circuitry and protection circuitry in 80386 are improved over that in 80286, so 80386 is much more versatile as a CPU in a multiuser system.
  - The 80386 has a "Virtual 8086" mode, which allows it to easily switch back and forth between 80386 Protected-mode tasks and 8086 real mode tasks.
  - The 80386 processor is available in two different versions:
    - the 386 DX, and
    - the 386 SX
  - The 386 DX has a 32-bit address bus and 32-bit data bus. It is packaged in the 132 pins ceramic pin grid array package.
  - The 386 SX, which is packaged in the 100-pin flat has the same internal architecture as 386 DX, but it has only 24-bit address bus and 16-bit data bus.
  - The lower cost of packaging and ease of interfacing to 8-bit and 16-bit memory and peripherals make 386 SX suitable for use in lower cost system. But address range and memory transfer rate are lower than 386DX.

Intel 80386  
➤ 32 bit  
➤ 32 bit address bus  
➤ Real, VM, Protected  
➤ 80286  
➤ 80386  
➤ 32 bit  
➤ 32 bit data bus

### Notes:

- (i). All programs are tested in 'masm611' and verified. (The 8086 emulator (emu8086) does not support some assembler directives like -dosseg(the optional directive) so the programmer can omit it to execute the program in emu8086 )
- (ii). 'startup' directive works similar to as mov ax,@data , mov ds,ax i.e. initialization of data segment and '.exit' or 'end' directive works similar to 'end proc' and 'end main' functions.

Title program to read a character from keyboard and display it on screen

dosseg

model small

stack

.data

.code

main proc ; start procedure with procedure name main

mov ax,@data ; initialize data segment

mov ds,ax

mov ah,01h ; accepts the character from keyboard & store in 'al' register & echoes  
int 21h

mov dl, al ; transfers the input character from 'al' to 'dl' register to display it

mov ah, 02h ; displays the character in 'dl' register on screen

int 21h

mov ah,4ch ; terminates the program

int 21h

```
main endp ; ends the procedure with name 'main'  
end main ; ends the program
```

2.

**title program to Print the Sum of Two 8 Bit Numbers**

```
dosseg  
.model small  
.stack 100h  
.data  
    val1 db 89  
    val2 db 10  
    msg db 'sum of 2 numbers : $'  
.code  
main proc  
    mov ax,@data  
    mov ds,ax  
    mov ax,0  
    mov al,val1  
    add al,val2  
    aam      ;aam Converts Binary Value to Unpacked BCD.  
    add ax,3030h ;ax is Added with 3030H to Obtain ASCII Value  
    push ax  
    ;;display message
```

jea dx,msg  
mov ah,09h  
int 21h  
;;;end display message  
pop ax  
mov dl,ah  
mov dh,al  
mov ah,02h  
int 21h  
mov dl,dh  
mov ah,02h  
int 21h  
mov ax,4c00h  
int 21h  
main endp  
end main

**title Program to add numbers input from keyboard**

```
model small  
stack  
data  
code  
main proc  
    mov ax, @data  
    mov ds,ax  
    mov ah,01h
```

```

int 21h
sub al,30h
mov bl,al ;store 1st number in bl register
mov ah,01
int 21h
sub al,30h
add al,bl
push al
jnc SKIP
mov dl, '1'
mov ah,02h
int 21h
SKIP: pop al
add al,30h
mov dl,al
mov ah,02h
int 21h
mov ah,4ch
int 21h
main endp
end main

```



#### title 8-bit multiplication

```

dosseg
.model small
.stack 100h
.code
main proc
    mov ax,@data
    mov ds,ax
    mov al,05h ; multiplier must be in 'al'
    mov bl,10h ;multiplicand can be in any register
    mul bl      ;result in ax
    aam          ; aam is 8086 instruction that converts binary value to unpacked bcd
    add ax,3030h ; ax is added with 3030h to obtain ascii value
    mov ax,4C00h

```

```
int 21h
main endp
end main
```

5.

**title 16-bit by 8-bit division**

```
.dosseg
.model small
.stack 100h
.data
val1 dw 0083h ; dw (data word) for 16-bit data
val2 db 02h ; db (data byte) for 8-bit data
.code
main proc
    mov ax, @data
    mov ds,ax
    mov ax,val1 ; dividend must be in 'ax' register
    div val2 ; quotient in 'al' and remainder in 'ah' register
    mov ax,4C00h
    int 21h
main endp
end main
```

**title program to transfer a block of data from one part of the memory to another**

```
.dosseg
.model small
.data
array1 db 22h, 33h, 44h, 55h, 66h
array2 db 5 dup(?)

.code
main proc
    mov ax,@data
    mov ds,ax
    mov si,offset array1 ; starting offset address of array1 passed to 'si'.
    mov di,offset array2
    mov cx,0005h ; counter
again:
    mov al,[si] ; [ds:si] content copied to al
    mov [di],al ; [al] content copied [ds:di]
    inc ai
    inc di
    loop again ; loop continues till cx=0
    mov ah,4ch
    int 21h
main endp
end main
```

7. title program to find the largest number.

```
dosseg
.model small
.stack 100h
.data
    array db 61h,43h,45h,42h,41h
    great db 00h
.code
main proc
    mov ax,@data
    mov ds,ax
    mov cx,0005h ;counter set to 5 because array has 5 data
    mov si,offset array
    mov bl,great

again:
    cmp bl,[si] ;compare bl and [si]
    jnc nochange ;if no carry then content of bl is greater.
    mov bl,[si] ;if carry occurs then content of bl is
                ;smaller than that of content of [si]

nochange:
    inc si
loop again
mov dl,great
```

mov ah,02h
int 21h
mov ah,4ch
int 21h
main endp
end main

title program to find the smallest number

```
dosseg
.model small
.stack 100h
.data
    array db 61h,43h,45h,42h,41h
.code
main proc
    mov ax,@data
    mov ds,ax
    mov cx,0005h
    mov si,offset array
    mov bl,small

again:
    cmp bl,[si]
    jc nochange

nochange:
```

```

limit db 40
timeschk db 38
multiplier db 2
result db 30 dup(?)  

.code
begin proc
    mov ax,@data
    mov ds,ax
    mov ax,0
    lea si,array
    lea di,limit
completed
    lea bp,result
    mov cl,timeschk
2(smallest prime)
    mov bl,multiplier
    mov dl,timesmul
big:
    jmp prime
small:
    mov bl,multiplier
    mov dl,timesmul
    sub [di],1
loop big
    jmp finish

```

;need to multiply with 2,3,5,7  
 ;decreased by 1 each time checking a number is  
 ;to store the non prime numbers  
 ;no. of numbers to check.i.e.above  
 ;increase each time to compare result  
 ;times to multiply 2,3,5 and 7  
 ;check prime or not  
 ;check complete  
 ;bl = 2 again  
 ;dl=times to mul  
 ;decreasing number to check

```

prime:
    mov al,[si]
    mul bl
    cmp al,[di]
    je notprime
    add bl,1
    sub dl,1
    jnz prime
    inc si
    mov dl,timesmul
    mov bl,multiplier
    inc si
    mov al,[si]
    dec si
    cmp al,[di]
    jne prime
    mov [bp].al
    inc bp
    lea si,array
    jmp small
notprime:
    lea si,array

```

;mov 2 in al  
 ;bl has 2 ; al becomes 4  
 ;compare al with number to check prime  
 ;inc no. to multiply  
 ;dec times to multiply; like count  
 ;loop till dl=0  
 ;get 3 into si,next no to multiply  
 ;dl=times to mul  
 ;bl=2 again  
 ;si point to no.5  
 ;check if array content is over; si pointing to di ?  
 ;si points to 3 ,next number to multiply  
 ;is al=[di] ?

```

        jmp small
finish: mov cx,30
        lea bp,result
getnonprime:
        mov al,[bp]
        inc bp
loop getnonprime
        mov ax,4c00h
        int 21h
begin endp
end begin

```

11.

**title 'hello world' string display program**

```

dosseg
.model small
.stack 100h

.data
HelloMessage DB 'Hello World',13,10,'$'

.code
main proc
    mov ax,@data
    mov ds,ax      ;set DS to point to the data segment

```

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Microprocessors- Chapter-4

```

        mov ah,09          ;DOS print string function
        mov dx,OFFSET HelloMessage ;point to "Hello, world"
        int 21h            ;display "Hello, world"
        mov ah,4ch          ;DOS terminate program function
        int 21h            ;terminate the program
main endp
end main

```

**title 'hello world' string display program without using function 09h**

```

dosseg
.model small
.stack 100h
.code
main proc
    mov ax,@data
    mov ds,ax
    mov cx,len
    mov si,offset string
again:
    mov dl,[si]
    mov ah,02h
    int 21h

```

mov ax,@data  
 mov ds,ax  
 mov si,offset string >2  
 again:  
 mov dl,[si]  
 mov ah,02h  
 int 21h

```
inc si
loop again

mov ah,4ch
int 21h

main endp

.data
string db 'This is a string','$'
len dw $-string-1

end main
```

13.

**title program to print a defined string in reverse order**

```
.dosseg
.model small
.stack 100h
.data
string db 'This is a string','$'
len dw $-string-1

.code
main proc
    mov ax,@data
    mov ds,ax
    mov cx,len
```

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT  
Microprocessors- Chapter-4

```
mov si,offset string
add si,len
dec si
again:
    mov dl,[si] ;the character to be outputted must be in dl
    mov ah,02h ;character output function
    int 21h
    dec si
    loop again
    mov ah,4ch
    int 21h
main endp
endp main
```

**title Program to display the reverse of the string entered from the keyboard.**

```
.model small
.stack 64h
.data
string1 db 'Enter the string :$'
```

```
inidata label byte
 maxlen db 20
 actlen db ?
```

```
kbinput db 20 dup ('$')

string2 db 'Reverse string is :$'
result db 20 dup ('$')

.code
begin proc far
    mov ax,@data
    mov ds,ax
    mov es,ax
    call clearscreen ;clear screen and set the attribute
    mov dx, 0201h
    call setcursor ; set the cursor position
    call display1 ; display the output
    call result1
    call display2
    mov ax,4c00h
    int 21h
begin endp

clearscreen proc near
    mov ax,0600h ; request scroll screen
    mov bh,04h ;attribute
    mov cx,0000 ;from 00,00
    mov dx,184fh ;to 24,79
```

int 10h
ret
clearscreen endp

```
setcursor proc near
    mov ah,02h
    mov bh,00
    int 10h
    ret
setcursor endp
```

```
display1 proc near
    push dx
    lea dx,string1
    mov ah,09h
    int 21h
```

```
    mov ah,0Ah
    lea dx,indata
    int 21h
    pop dx
    ret
display1 endp
```

```
result1 proc near
    lea di,result
    lea si,indata
    inc si
    mov cl,[si]
    mov ch,00
    add si,cx
    back: mov bl,[si]
    mov [di],bl
    inc di
    dec si
    dec cl
    jnz back
    mov bl,'$'
    mov [di],bl
    ret
result1 endp
```

```
display2 proc near
    inc dh
    call setcursor
    push dx
    mov ah,09h
```

```
lea dx,string2
int 21h
pop dx
mov ah,09h
lea dx,result
int 21h
ret
display2 endp
```

end begin

title program to print each word of a string in different lines

```
.dosseg
.model small
.stack 100h
.code
main proc
    mov ax,@data
    mov ds,ax
    mov si,offset string
```

again:

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

```

mov dl,[si] ;the character to be outputted must be in dl
cmp dl,24h ;ASCII value of $ is 24h
jz last ;when gets $ sign, program jumps to
         ;label- last for termination
cmp dl,20h ;ASCII value of space is 20h
jz nextline ; when gets space in string jumps to
            ;label- nextline
mov ah,02h ; character output function
int 21h
inc si
jmp again

nextline:
inc si
mov dl,0dh ;carriage return or enter key
            ;pressed
mov ah,02h
int 21h
mov dl,0ah ;start in next line
mov ah,02h
int 21h
jmp again

last:
mov ah,4ch
int 21h

main endp

```

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

```

.data
string db 'I like Programming','$'
end main

;title ALP that asks user to 'Input password' and compares the entered password
;and displays 'Welcome' if it is equal to 'ncit' otherwise display 'Invalid User'.
.model small
.stack
.data
password db 'ncit','$'
msg1 db 'Insert Password','$'
msg2 db 10,13,'Welcome','$'
msg3 db 10,13,'Invalid User','$'
val db ?

.code
main proc
    mov ax,@data
    mov ds,ax

    mov dx,offset msg1
    mov ah,09h
    int 21h

    mov ah,4ch
    int 21h

```

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

```

        mov bh,0
        mov cx,4
        mov si,offset password
AGAIN: mov ah,01h
        int 21h
        mov val,al
;mov dl,'*'
;mov ah,02h
;int 21h
        mov bl,[si]
        cmp val,bl
        jne SKIP
        inc bh
SKIP:inc si
        loop AGAIN
        cmp bh,4
        jne INVALID

        mov dx,offset msg2
        mov ah,09h
        int 21h
        jmp EXIT
INVALID: mov dx,offset msg3
        mov ah,09h

```

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

```

        int 21h
EXIT:mov ah,4ch
        int 21h
main endp
end main

title alp to display the vowels present in the input string
model small
stack 100h
.data
inpstr db 255 dup(?)
oustr db 13,10;define string
.code
main proc
        mov ax,@data
        mov ds,ax
        lea si,inpstr
        lea di,oustr
        mov cx,0
        check: mov ah,1
        int 21h
        cmp al,0dh
        je exit
        cmp al,'a' ; compare with 'a'

```

```
je a1; if equals goto a1
jne e1; else goto e1 to check for next vowel
jmp check
a1:
    mov [di],al; push the content to di if char is equal to 'a'
    inc cx
    inc si
    inc di
    jmp check ; goto check to take another character
e1:
    cmp al,'e'; compare with 'e'
    je ee
    jne i1
ee:
    mov [di],al; push the content to di if char is equal to 'e'
    inc cx
    inc si
    inc di
    jmp check
i1:
    cmp al,'i'
    je ii
    jne o1
ii:
```

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Microprocessors- Chapter-4

```
mov [di],al ;push the content to di if char is equal to 'i'
inc cx
inc si
inc di
jmp check
o1:
    cmp al,'o'
    je oo
    jne u1
oo:
    mov [di],al ;push the content to di if char is equal to 'o'
    inc cx
    inc si
    inc di
    jmp check
u1:
    cmp al,'u'
    je uu
    jne check
uu:
    mov [di],al; push the content to di if the char is equal to 'u'
    inc cx
    inc si
    inc di
```

```

jmp check
exit:
call showvowels; call the procedure display it
mov ax,4c00h
int 21h
main endp
showvowels proc
mov ah,02
mov dh,10
mov dl,30
mov bh,00 ; load page number
int 10h
lea si,oustr
add si,cx
mov [si],"$" ; make $ a string
sub di,cx
mov ah,9h
mov bl,11001011b
int 10h
mov dx,offset oustr
int 21h
ret
showvowels endp
end main

```

title to input string and count number of vowel

```

dosseg
.model small
.stack 100h
.data
string db 99 dup(?)
count db 00h

```

```

.code
main proc
mov ax,@data
mov ds,ax
mov si, offset string
mov di,offset count
again:
    mov ah,01h
    int 21h
    cmp al,0dh
    jz down
    mov [si],al

```

```
inc si  
inc bl  
jmp again
```

down:

```
mov dl,0dh  
mov ah,02h  
int 21h  
mov dl,0ah  
mov ah,02h  
int 21h  
mov cl,bl  
mov ch,00h  
mov si,offset string
```

again2:

```
mov dl,[si]  
cmp dl,20h  
jz next  
mov al,[si]  
cmp al,'a'  
jz count1  
cmp al,'A'  
jz count1  
cmp al,'e'
```

Microprocessors- Chapter-4  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

```
jz count1  
cmp al,'E'  
cmp al,'i'  
jz count1  
cmp al,'T'  
jz count1  
cmp al,'o'  
jz count1  
cmp al,'O'  
jz count1  
cmp al,'u'  
jz count1  
cmp al,'U'  
jz count1  
jmp jump
```

count1:

inc bh

jump:

```
mov dl,al  
mov ah,02h  
int 21h  
inc si
```

loop again2  
jmp last

next: inc count  
inc si  
mov dl,0dh  
mov ah,02h  
int 21h  
mov dl,0ah  
mov ah,02h  
int 21h  
dec cx  
jmp again2

last:  
inc si  
mov [si],bh  
mov dl,count  
mov ah,02h  
mov ax,4c00h  
int 21h

main endp  
end main

title program to change case of the letter on given string

.model small  
.stack 100h

.data  
str1 db "How are You"  
str2 db 11 dup (?)

.code  
main proc

mov ax,@data  
mov ds,ax  
lea si,str1  
lea di,str2

mov cx,11d ; count and store the length of given string in cx

case:

cmp cx,0000h

je exit

mov ah,[si]

cmp ah,60h ;ascii value of small letters starts from 61h i.e. ascii value of 'a'=61h

ja small ; if the character has ascii value above 60h then it is small letter

cmp ah,5Ah ; ascii values of capital 'Z' is 5Ah

jb cap ; if the character has ascii value below 5Ah then it is capital letter

small:

and ah,11011111b

mov [di],ah

inc si

inc di

dec cx

jmp case

cap:

or ah, 00100000b

mov [di],ah

inc si

inc di

dec cx

jmp case

exit:

call display

mov ax,4c00h

int 21h

main endp

display proc

lea si,str2

add si,12d

mov [si],"\$"

sub di,12d

mov ah,9h

lea dx,str2

int 21h

ret

display endp

end main

title to input string and display in different line and convert lowercase to uppercase

dosseg

.model small

.stack 100h

.data

string db 99 dup(?)

count db 00h

.code

main proc

mov ax,@data

mov ds,ax

mov si, offset string

mov di,offset count

again:

```
mov ah,01h
int 21h
cmp al,0dh
jz down
mov [si],al
inc si
inc bl
jmp again
```

down:

```
mov dl,0dh
mov ah,02h
int 21h
mov dl,0ah
mov ah,02h
int 21h
mov cl,bl
mov ch,00h
mov si,offset string
```

again2:

```
mov dl,[si]
cmp dl,20h
jz next
mov al,[si]
```

```
cmp al,'a'
jc jump
cmp al,'z'+1
jnc jump
sub al,20h
```

jump:  
mov dl,al  
mov ah,02h  
int 21h  
inc si  
loop again2  
jmp last

next: inc count  
inc si  
mov dl,0dh  
mov ah,02h  
int 21h  
mov dl,0ah  
mov ah,02h  
int 21h  
dec cx  
jmp again2

```
    last:  
        mov ax,4c00h  
        int 21h  
  
    main endp  
end main  
  
21.  
title program to input a string and print each word in different lines  
  
dosseg  
.model small  
.stack 100h  
.code  
main proc  
    mov ax,@data  
    mov ds,ax  
    mov si,offset string  
again:  
    mov ah,01h  
    int 21h  
    cmp al,0dh  
    jz down  
    mov [si],al  
    inc si  
    inc bl
```

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT  
Microprocessors- Chapter-4

```
jmp again  
down:  
    mov dl,0dh  
    mov ah,02h  
    int 21h  
  
    mov cl,bl  
    mov ch,00h  
    mov si,offset string  
again2:  
    mov dl,[si]  
    cmp dl,20h  
    jz nextline  
    mov ah,02h  
    int 21h  
    inc si  
    loop again2  
    jmp last  
nextline:  
    inc si  
    mov dl,0dh  
    mov ah,02h  
    int 21h  
    mov dl,0ah
```

```
        mov ah,02h  
        int 21h  
        mov dl,0ah  
        int 21h  
        dec cx  
        jmp again2  
  
last:  
        mov ah,4ch  
        int 21h  
        main endp  
  
.data  
        string db 99 dup(?)  
end main
```