

Name : Manjali Nishikant Naik  
Roll No. : 21102B0008  
Branch : Computer Engineering (CMEN)  
Division : B  
Semester : IV

classmate

Date \_\_\_\_\_  
Page 1

## Microprocessor (MP) : Assignment 1

- Q1) Draw and explain the architecture of 8086.

Sol.  $\Rightarrow$



Architecture of 8086 microprocessor

- ⇒ 1] 8086 processor is an enhanced version of 8085 processor introduced by Intel in 1976. It has a 16-bit data bus and 20-bit address bus and supports 2 stages of pipelining.
- 2] It is available in 3 versions according to frequency as 5MHz, 8MHz and 10MHz and supports 2 modes of operation : i) Maximum mode (multiple processors)  
ii) Minimum mode (single processor).
- 3] The internal architecture of 8086 is divided into 2 units :
- A] Bus Interface Unit (BIU) : It provides interface of 8086 to external memory and I/O devices. BIU performs functions like
- i] Fetches instructions from memory.
  - ii] Calculates 20-bit physical address.
  - iii] Manages 6-byte pre-fetch queue.
- ③ BIU's components are :
- i] Segment register ⇒ holds the base address for code segment.
  - ii] Instruction pointer ⇒ holds offset of next instruction in code segment.
  - iii] Address generation circuit ⇒ it generates 20-bit physical address
  - iv] Pre-fetch queue ⇒ it is a 6-byte FIFO RAM which fetches the next instruction while executing the current one.
- B] Execution Unit (EU) : ① It performs 8-bit and 16-bit arithmetic and logical operations. ② EU sends requests signals to BIU and it operates with respect to T-states (clock cycles). ③ Components of EU are as follows :
- i] General purpose registers ⇒ they are available to user for storing values; these 16-bit registers can be divided into 2 independent 8-bit registers ( $A_x \xrightarrow{AL} A_L$ ,  $A_x \xrightarrow{AH} A_H$ ).
  - ii] Special purpose registers ⇒ points to specific memory locations of segment.
    - ① Stack pointer (SP) ⇒ Points stack-top.
    - ② Base Pointer (BP) ⇒ holds offset address.
    - ③ Source index (SI) ⇒ holds offset in data segment during string operations.
    - ④ Destination index (DI) ⇒ holds offset in extra segment during string operations.  - iii] ALU ⇒ performs 8-bit and 16-bit arithmetic and logical operations.
  - iv] Status register ⇒ Has 9 flags that change/recognize state of MP.
    - ① Carry ② Parity ③ Aux. carry ④ Zero ⑤ Sign ⑥ Overflow ⑦ Trap ⑧ Interrupt control ⑨ Direction  - v] Operands ⇒ 16-bit registers to hold the operands temporarily.

2] Explain pre-fetch queue of 8086.

Sol. →

- 1] The instruction pre-fetch queue of 8086 is 6-bytes in length operating in FIFO manner and receives instructions from memory.
- 2] BIU fetches the instructions meant for the queue ahead of time from memory.
- 3] Because of this instruction queue, one instruction is being executed while other is being fetched causing an overlap. This is called pipelining and 8086 supports 2-stages of pipelining.
- 4] This pipelining increases the efficiency of the microprocessor.
- 5] MP 8086 starts operation by fetching 1 or 2 bytes of instruction. The 1<sup>st</sup> byte is always an opcode which when decoded, 1 byte in queue becomes empty and gets updated.
- 6] Queue is refilled when atleast 2 bytes of queue are empty.
- 7] For a single opcode byte, the next bytes are treated as data bytes depending upon the instruction length, otherwise, the next byte is treated as second byte of instruction opcode.

3] Now and explain flag register of 8086.

Sol. →

- 1] The 8086 flag register contents indicate the results of computation in ALU. 2] A 16-bit flag register is used in 8086 and is divided into 2 parts : i) Status flags ii) Control flags.

### A) Status Flags

- ① Carry flag → set to logic 1 whenever there is carry (or borrow).
- ② Parity flag → set to logic 1 if the result has even parity.
- ③ Auxiliary carry flag → set if carry is generated out of nibble (lower).
- ④ Zero flag → set if the result is zero.
- ⑤ Sign flag → set if MSB of result is 1 i.e., it is a -ve for signed nos.
- ⑥ Overflow flag → will be set if result of operations is too large to fit in no. of bits available.

## 8 Control Flags

- ① Interrupt flag  $\Rightarrow$  used to mask or disable interrupt.
- ② Direction flag  $\Rightarrow$  if it is set, SI and DI are in auto-decrementing mode in string operations.
- ③ Trap flag  $\Rightarrow$  used to set the trace mode, i.e., start single-stepping mode.



Flag register of 8086

9]

Write a formula to calculate physical address. Explain why its required to calculate it.

Sol.  $\Rightarrow$

1] 8086 addresses a segmented memory and it has a 20-bit long address bus.

2] Thus, to access a specific memory location from any segment, we need a 20-bit address.

3] However, all the registers in 8086 microprocessor are of 16-bit length.

4] Instruction pointer (IP) holds 16-bit address of next code byte within code segment and is referred to as offset.

5] Thus, to produce 20-bit address using 16-bit registers, the offset address needs to be added to the segment base address.

Formula for calculating physical address

$$\text{Physical address} = \text{Segment address} \times 10H + \text{Offset address}$$

Addressing modes [Imp for MSE  $\Rightarrow$  either write types of AM  
 $\Rightarrow$  identify which AM.

A] Memory addressing mode

1] Immediate addressing mode

- $\Rightarrow$  operand is specified in instruction itself
- $\Rightarrow$  source operand is a 8-bit or 16-bit data
- $\Rightarrow$

ex.  $\Rightarrow$  `MOV CX, 2000H`  
`MOV CL, 0AH`  
`ADD CL, 45H`

2] Register addressing mode

- $\Rightarrow$  both operands are registers, i.e., operands are specified through registers.

ex.  $\Rightarrow$  `MOV CL, DL`  
`XOR AX, BX`  
`ADD AL, BL`

3] Direct addressing mode

- $\Rightarrow$  addressing of operand is directly given in instruction.  
as displacement (offset address).

ex.  $\Rightarrow$  `MOV CL, [2000H]`  
 $\Rightarrow$  moves data from location 2000H in data segment of CL.  
 $\Rightarrow$  physical address is calculated as  $DS * 10H + 2000H$  (offset)  
Assume  $DS = 5000H \quad \therefore PA = 5000H + 2000 = 52000 \quad \because CL = 52000H$

ex.  $\Rightarrow$  `MOV CX, [2000H]`

## 9] Indirect addressing mode

### ① Register indirect addressing mode

⇒ address of operand is given using a register.

⇒ operand is at  $\rightarrow 5000H$  of data segment  
of operand

ex. ⇒  $MOV CL, [BX]$  ⇒ first more address from  
 $5000H$  to  $BX$   
⇒ then  $MOV CL, [BX]$

### ② Register relative addressing mode

⇒ address of operand is given as sum of register  
and displacement.

ex. ⇒  $MOV CL, [BX + 4]$  or  $MOV CL, 04H[BX]$

↓  
if  $BX = 5000H \Rightarrow$  actual location.

$BX + 4 = 5004H$ .

### ③ Base Indexed addressing mode

⇒ only BX register is used for addressing along  
with offset address register.

Base → only B register

offset → SI and DI for data seg and BP for stack seg.

ex. ⇒  $\begin{cases} MOV CL, [BX + SI] & \rightarrow \text{Data seg } \begin{matrix} SI \\ DI \end{matrix} \\ MOV CL, [BP + SI] & \rightarrow \text{Stack seg } \begin{matrix} SI \\ DI \end{matrix} \end{cases}$

#### ④ Base relative plus indexed addressing mode

ex.  $\Rightarrow$   $MOV CL, [BX + DI + 20]$   
 $MOV [BP + SI + 2000], CL$

#### ⑤ Implied addressing mode

$\Rightarrow$  operands are implied, not specified in instructions.

ex.  $\Rightarrow$   $STC \rightarrow$  set the carry  
 $CLD \rightarrow$  clears the direction flag.

#### ⑥ I/O Addressing mode

##### I/O addressing modes



$\Rightarrow$  8 bit I/O address

$\Rightarrow$  16-bit I/O address

$\Rightarrow 00H$  to  $FFH$

$\Rightarrow 0000H$  to  $FFFFH$

$\Rightarrow 256^{16}$  I/O port address

$\Rightarrow 65536$  I/O port address

ex.  $\Rightarrow$   $IN AL, 80H$

ex.  $\Rightarrow$   $MOV DX, 2000H$

[ data = 8 bit  
address = 16-bit ]

6

The instruction 'MOV BL, [SI]' comes under which type of addressing mode?

Sol.<sup>n</sup> ⇒ Here, address of the operand is given through register SI  
∴ This is register indirect addressing mode.

Q] Why 8284 is needed in 8086 based system?

Sol. →



- 1] The 8284A is used in all 8086 microprocessors to generate the system clock signal.
- 2] CLK is the processor clock and has 33% duty cycle clock signal.
- 3] When power is first applied, the capacitor will charge towards +5V.
- 4] With sufficient time constant, the RES input will be held long enough to reset the processor. Hence, 8284 generates Reset signal.
- 5] It also synchronises ready signals from memory and I/O devices.

10]

List features of 8086 microprocessor.

Sol.  $\Rightarrow$

- 1] 8086 is an enhanced version of 8085 processor introduced by Intel in 1976.
- 2] 8086 has 20-bits of address bus and 16-bits of data bus. and supports 2 stages of pipelining.
- 3] Memory of 8086 is divided into 4 segments : i] Code ii] Data iii] Stack iv] Extra
- 4] 8086 supports enhanced version of instruction set (multiplication and division)
- 5] It supports 2 operating modes : i] minimum mode (single processor) ii] maximum mode (multiprocessor)
- 6] It has instruction pre-fetch queue storing 6 bytes of instruction from memory.
- 7] It operates in 3 frequencies : i] 5MHz ii] 8MHz iii] 10MHz
- 8] It uses single phase clock with 33% of duty cycle and also 256 vector interrupts.

11

What is memory addressing capacity of 8086 and why?

Sol.<sup>o</sup> →

- 1] The memory addressing capacity of 8086 microprocessor is 1MB.
- 2] This is because 8086 is a 16-bit microprocessor having 20-bit address bus and 16-bit data bus.
- 3] We know that on N-bit address bus, we can access  $2^N$  memory locations.
- 4] Thus, for 20-bit address bus, memory locations =  $2^{20}$  bytes = 1MB
- 5] Therefore, the memory addressing capacity of 8086 is 1MB.

12] Explain memory segmentation in 8086 and list its advantages.

Sol.  $\Rightarrow$  1] Memory segmentation  $\Rightarrow$  It is the process in which the main memory of the ~~processor~~ computer is divided into different segments/partitions each one having its own base address.

2] In 8086 microprocessor, the memory is divided into 4 segments:

A] Code segment:

$\Rightarrow$  Base : CS  $\Rightarrow$  Offset : IP

$\Rightarrow$  it stores all instructions and programs

B] Stack segment:

$\Rightarrow$  Base : SS  $\Rightarrow$  offset : SP and BP

$\Rightarrow$  it stores all the <sup>stack</sup> general data (memory)

C] Data segment:

$\Rightarrow$  Base : DS  $\Rightarrow$  offset : SI

$\Rightarrow$  it stores all the general data.

D] Extra segment:

$\Rightarrow$  Base : ES  $\Rightarrow$  offset : DI

$\Rightarrow$  it stores general data and it is used as destination in string operations.



#### Advantages of memory segmentation:

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

2] It permits the programmer to access 1 MB memory using 16-bit of address.

## Memory Banking

⇒ Memory address space is equally divided into 2 parts (banks).

⇒ One of the banks containing even addresses is called Even Bank and the other one containing odd addresses is called Odd Bank.

⇒ Even bank always stores lower byte  
∴ it is called Lower Bank (LB)

⇒ Odd bank always stores higher byte  
∴ it is called Higher Bank (HB).

Data bus  
(D<sub>0</sub>-D<sub>15</sub>)

BHE



Odd addressed memory bank

(Higher)

Even addressed memory bank

(Lower)

Why it is done in 8086? ⇒ 8086 has 20-bit addressing model for memory access. Each address represents a single byte, but natural word size of 8086 is 2 bytes (16-bit data bus) ∴ we need a way to read 2 bytes at one time ∴ Even and Odd banks.

| BHE | A <sub>0</sub> | Operation                             |
|-----|----------------|---------------------------------------|
| 0   | 0              | Read or write 16 bit from both banks  |
| 0   | 1              | Read or write 8 bits from higher bank |
| 1   | 0              | Read or write 8 bits from lower bank  |
| 1   | 1              | No operation (Processor is idle)      |

ex. ⇒ 8 bit operation on even bank's

mov BL, [20000H]

mov BH, [20000H]

mov BX, [20000H]

mov BX, [2000H]

(aligned operation)

(misaligned operation)



$\begin{cases} \text{mov BL, [20000H]} \\ \Rightarrow 8 \text{ bit operation} \\ \Rightarrow BL \text{ will get value stored at offset address [20000H]} \\ \Rightarrow 8 \text{ bit operation ... only 1 bank selected} \\ \Rightarrow 20000H \Rightarrow \text{even/lower bank} \end{cases}$

⇒ BHE → 1, A<sub>0</sub> = 0

14

Explain minimum mode of operation. [supports single processor]

Sol: →

- 1] 8086 works in minimum mode when MN/M<sup>X</sup> pin is set to logic 1.
- 2] In this mode, 8086 is the only processor in the system.
- 3] Clock, Reset and Ready signals are generated by 8284 clock generator.
- 4] Address from the address bus is latched into 8282 8-bit latch.

Thus, 3 latches are needed as address bus is 20-bit.

- 5] Data bus is driven through 8286 transceivers of 8-bit.

Thus, 2 transceivers are needed as data bus is 16-bit.

- 6] Transceivers are enabled through DEN signal and direction of data is controlled by DT/R signal. (Both generated by 8086).

| DEN | DT/R | Action               |
|-----|------|----------------------|
| 1   | X    | Transceiver disabled |
| 0   | 0    | Receive data         |
| 0   | 1    | Transmit data        |

7) Control signals for all operations are generated by decoding  $M/I\bar{O}$ ,  $\bar{R}D$  and  $\bar{W}R$ .

| $M/I\bar{O}$ | $\bar{R}D$ | $\bar{W}R$ | Operation    |
|--------------|------------|------------|--------------|
| 1            | 0          | 1          | Memory read  |
| 1            | 1          | 0          | Memory write |
| 0            | 0          | 1          | I/O Read     |
| 0            | 1          | 0          | I/O write    |

8)  $M/I\bar{O}$ ,  $\bar{R}D$ ,  $\bar{W}R$  are decoded by a 3:8 decoder.

9) Bus Request (DMA) is done using HOLD and HLDA signals.

10) INTA is given by 8086 in response to interrupt on INTR line.

15) Explain maximum mode of operation. [supports multiple processors]

Sol.  $\Rightarrow$

1) 8086 work is maximum mode when MN/MX pin is logic 0.

2) In this mode, multiple processors are supported along with 8086.

3) Clock signals are provided by 8284 clock generator.

4) 8288 Bus controller is the most significant part as it provides various control signals.

5) Address from address bus is latched into 8282 8-bit latches. 3 such latches are needed for 20-bit address bus. ALE is connected to STB of latch and ALE is given by 8288 bus controller.

6) Data bus is driven through 2 8285 8-bit transceivers as data bus is of 16-bit. Transceivers are enabled through DEN signal and direction of data is controlled by DT/R signal.

DEN is connected to OE and DT/R is connected to T.

| DEN(8288) | DT/R | Action              |
|-----------|------|---------------------|
| 0         | X    | Transceiver disable |
| 1         | 0    | Receive data        |
| 1         | 1    | Transmit data       |

7) Control signals for all <sup>operations</sup> signals are generated by decoding  $\overline{S_2}$ ,  $\overline{S_1}$  and  $\overline{S_0}$  signals.

| $\overline{S_2}$ | $\overline{S_1}$ | $\overline{S_0}$ | Processor state   | 8088 Output                                            |
|------------------|------------------|------------------|-------------------|--------------------------------------------------------|
| 0                | 0                | 0                | Int. Acknowledge  | $\overline{\text{INTA}}$                               |
| 0                | 0                | 1                | Read I/O port     | $\overline{\text{IORC}}$                               |
| 0                | 1                | 0                | Write I/O port    | $\overline{\text{IOWC}}$ and $\overline{\text{AIOWC}}$ |
| 0                | 1                | 1                | Halt              | None                                                   |
| 1                | 0                | 0                | Instruction fetch | $\overline{\text{MRDC}}$                               |
| 1                | 0                | 1                | Memory Read       | $\overline{\text{MRDC}}$                               |
| 1                | 1                | 0                | Memory write      | $\overline{\text{MWTC}}$ and $\overline{\text{AMWTC}}$ |
| 1                | 1                | 1                | Inactive          | None                                                   |

## Minimum mode read cycle

$m/\bar{I}O = 1$  then memory read;  $m/\bar{I}O = 0$  then I/O read



## Minimum Mode Read Cycle

$T_1 \Rightarrow$  ALE goes high as the multiplexed buses carry address till it goes low.

$T_2 \Rightarrow$  MP asks for data by making  $\overline{RD}$  low and  $\overline{WR}$  high.

Transceiver is enabled by  $\overline{DEN} = 0$

Data takes some time called 'Propagation delay' to reach MP from memory.

$T_3 \Rightarrow$  Memory starts sending data on the data bus and MP checks ready signal: if ready = 1  $\Rightarrow$  MP completes machine cycle in next  $T_4$  state; if ready = 0  $\Rightarrow$  MP inserts a wait state between  $T_3$  and  $T_4$ .

$T_4 \Rightarrow$  MP captures data sent by memory device.

All signals like  $\overline{RD}$  and  $\overline{DEN}$  are deactivated.

## Minimum mode write cycle



Minimum mode write cycle

17]

Draw and explain write/read operation timing diagram for maximum mode?

Sol. →

### A) Maximum mode - Read Cycle



⇒ T<sub>1</sub> ⇒ ALE is high and multiplexed buses carry address and  $\overline{S_2}, \overline{S_1}, \overline{S_0}$  are active.

T<sub>2</sub> ⇒ AD<sub>15</sub>-AD<sub>0</sub> buses carry address until ALE goes low and BHE/S<sub>7</sub> is allowed to carry address.

T<sub>3</sub> ⇒ Address is no longer present in multiplexed bus, transceiver (half T<sub>2</sub>) is enabled by DEN=1. Bus will now carry signals S<sub>3</sub>-S<sub>7</sub> until mid of T<sub>4</sub>. Data will take time to travel to MP.

T<sub>4</sub> ⇒ Memory starts sending data on data bus

### B) Maximum mode - Write Cycle

Maximum Mode Write Cycle



18]

Differentiate between minimum mode and maximum mode of 8086.

Sol": →

### Minimum mode

- 1] MN/ $\overline{Mx}$  pin is set to logic 1.
- 2] There can be only one processor.
- 3] The 8086 generates INTA for interrupt acknowledgement.
- 4] Performance is slower as multiprocessor cannot be performed.
- 5] The 8086 itself provides an ALE for the latch.
- 6] It is used for small systems.
- 7] The system is more affordable.
- 8]  $\overline{DEN}$  and  $\overline{DT/R}$  signals for the transceivers are given by 8086 itself.

### Maximum mode

- 1] MN/ $\overline{Mx}$  pin is set to logic 0.
- 2] There can be multiple processors.
- 3] The 8288 Bus Controller generates the interrupt acknowledgement signal (INTA).
- 4] Performance is faster as multiprocessor can be performed.
- 5] The 8288 Bus Controller provides ALE for the latch.
- 6] It is used for large systems.
- 7] The system costs more money.
- 8] DT/R signals for the transceivers are given by 8288 bus controller.

23] Explain interrupt vector table. / 29] Explain types of interrupt.

Sol: ⇒ 1] An interrupt is a special condition that arises during the working of microprocessor.

2] Microprocessor services it by executing a subroutine called Interrupt Service Routine (ISR).

3] The sources of interrupts for 8086 are:

i] External signal (Hardware interrupt):

⇒ These interrupt signals occur on external pins of MP. 8086. It has 2 pins to accept hardware interrupt i) NMI ii) INTR.

ii] Special instructions (Software interrupt):

⇒ These interrupts are caused by writing the software interrupt instruction which are assigned values in the IVT.

4] Interrupt Vector Table (IVT):

⇒ IVT has some pre-defined values for particular interrupts and can also accommodate user-defined interrupts.

⇒ Each interrupt has dedicated 4 bytes (2-CS and 2-IP) and it contains total 256 (0 to 255) interrupts.

⇒ Thus, size of IVT =  $4 \times 256 = 1024$  bytes = 1KB

⇒ IVT is divided into 3 parts as follows:

A] Dedicated interrupts (INT 0 to INT 4)

① INT 0 (divide error) ⇒ this interrupt occurs whenever there is division error i.e., when result of division is too large to be stored.

② INT 1 (single step) ⇒ it puts MP in single stepping mode.

⇒ useful for debugging ⇒ displays contents of all registers.

③ INT 2 (NMI) ⇒ MP executes this ISR in response to interrupt on NMI line.

④ INT 3 (Breakpoint) ⇒ used to cause breakpoints in program.

⇒ caused by writing INT3H or INT ⇒ used for debugging.

⑤ INT 4 (overflow) ⇒ occurs if overflow flag is set ⇒ used to detect overflow error in signed operations.

### B] Reserved interrupts (INT 5 to INT31)

- ⇒ These levels are reserved by Intel to be used in higher processors like 80386, Pentium, etc.
- ⇒ They are not available to the user.

### C] User-defined interrupts (INT 32 to INT255)

- ⇒ These are user-defined, software interrupt.
- ⇒ ISRs for these interrupts are written by users to service various user-defined conditions.
- ⇒ Its ISR is obtained by MP from location  $n \times 4$  in IVT.

20]

Design the power on Reset and manual Reset circuit  
for 8086 microprocessor.

Sol: →



Q1] What is demultiplexing of address and data bus? Also explain the significance of ALE pin.

Sol.  $\Rightarrow$  1] Multiplexing is done to reduce no. of pins of 8086 microprocessor.

2] However, external memory needs to separate the address for decoding and data transfer.

3] The signal lines AD<sub>0</sub>-AD<sub>15</sub> in 8086 are used for dual purpose:

i] To carry address bits ii] To carry data bits.

This is called multiplexing of address and data bus.

4] The address bus is required to locate the memory for data transfer to I/O devices and the data bus is used to transfer data from MP to memory devices and vice-versa.

5] To avoid mixing of address and data buses, they must be demultiplexed. This can be done with the help of an ALE latch.

The bus is connected as an input to the latch.

6] ALE pin  $\Rightarrow$  It is an Address Latch Enable signal which indicates that valid address is available on bus AD<sub>0</sub>-AD<sub>15</sub>.

7] It is an active high signal and remains high during T<sub>1</sub> state.

8] If ALE is logic 1 (high), it enables the address bits (A<sub>0</sub>-A<sub>15</sub>) and if ALE is logic 0 (low), it enables the data bits (D<sub>0</sub>-D<sub>15</sub>).

24]

Explain following instructions:

Sol: →

a] DAA ⇒ Decimal Adjust Accumulator

⇒ It is used to adjust the decimal after the addition/subtraction operation ⇒ it basically converts the result of binary sum into BCD number.

b] AAA ⇒ It is used to adjust ASCII after addition.

⇒ This instruction is mainly useful for adding strings of digits where there is exactly one decimal digit per byte in a string.

c] XLAT ⇒ This instruction is used to translate a byte in AL using a table in the memory. It changes AL register from the table index to table entry.

d] LAHF ⇒ load lower byte of flag register in AH. This instruction copies the contents of lower byte of 8086 flag register to AH register.

Q5

Explain string instructions of 8086 microprocessor.

Sol.  $\Rightarrow$

String instructions of 8086 microprocessor are as follows:

① MOV S:

- i) MOVSB  $\Rightarrow$  moves contents of byte given by DS:SI into ES:DI
- ii) MOVSW  $\Rightarrow$  moves contents of word given by DS:SI into ES:DI

② LODS S:

- i) LODSB  $\Rightarrow$  moves byte address at DS:SI to AL:SI ; SI inc/dec by 1.
- ii) LODSW  $\Rightarrow$  moves word address at DS:SI into AX:SI ; SI inc/dec by 2

③ STOS S:

- i) STOSB  $\Rightarrow$  moves contents of AL to byte address given by ES:DI ; DI inc/dec by 1
- ii) STOSW  $\Rightarrow$  moves contents of AX to byte address given by ES:DI , DI inc/dec by 2.

④ CMP S:

- i) CMPSB  $\Rightarrow$  compares byte at ES:DI with byte at DS:SI and sets flags
- ii) CMPSW  $\Rightarrow$  compares word at ES:DI with word at DS:SI and sets flags.

⑤ SCAS:

- i) SCASB  $\Rightarrow$  compares byte at ES:DI with AL and sets flag.
- ii) SCASW  $\Rightarrow$  compares word at ES:DI with AX and sets flag.

⑥ REPZ/REPE  $\Rightarrow$  repeat the given instruction while CX = 0 i.e., ZF = 1

⑦ REPNEZ/REPNE  $\Rightarrow$  repeat the given instruction while CX != 0 i.e., ZF = 0

Q26

Write a program to ADD/SUB two 16-bit numbers.

Sol. →

i) Addition:

Program →

- model small
- stack 100h
- data

```
n1 dw 1234h
n2 dw 0F321h
sum dw ?
ends
```

.code

```
start:    mov ax, @data
          mov ds, ax
          mov ax, n1
          mov bx, n2
          mov cx, 00h
          add ax, bx
          jnc down
          inc cx
```

```
down:     mov sum, ax
          mov sum+2, dx
          mov ah, 4ch
          int 21h
```

end

start

ii) Subtraction:

- model small
- stack 100h
- data

```
n1 dw 0F321h
n2 dw 1234h
diff dw ?
ends
```

.code

```
start:    mov ax, @data
          mov ds, ax
          mov ax, n1
          mov bx, n2
          mov cx, 00h
          sub ax, bx
          jnc down
          inc cx
```

```
down:     mov diff, ax
          mov diff+2, dx
          mov ah, 4ch
          int 21h
```

end

start

Q1] What is assembly directives ? Explain DB, SEGMENT, ENDS,  
· MODEL SMALL

Sol<sup>n</sup> ⇒ 1] Assembly directives ⇒ It is a statement/reserved key-word to give direction to the assembler to perform task of the assembly process.

2] They indicate how an operand or a section of the program is to be processed by the assembler.

3] It controls the organization of the program and provide necessary information to the assembler to understand the assembly language programs to generate necessary machine codes.

4] An assembler supports directives to define data, to organize segments, to control procedure, to define macros.

DB ⇒ Define byte ⇒ defines a byte type (8-bit) variable  
⇒ reserves specific amount of memory locations to each variable.

SEGMENT ⇒ used to indicate the beginning of a code/data / stack/extra segment

ENDS ⇒ used to indicate the end of a code.

MODEL SMALL ⇒ model represents memory model for the program.  
⇒ small indicates separate segments for code and data fit in one 64KB.

28]

Write assembly language program to transfer data stored in data segment to extra segment.

Sol.  $\Rightarrow$

| Labels | Mnemonics | Operands  |
|--------|-----------|-----------|
| START  | MOV       | AX, @DATA |
|        | LEA       | DS        |
|        | MOVSB     | CX        |
|        | REP NZ    | LEN       |
| INT    | ARR1      |           |
|        | ARR2      |           |
|        | SI        |           |
|        | DI        |           |
|        | 21H, 4CH  |           |
|        | ES        |           |

Program  $\Rightarrow$

- model small
- stack 100H
- data

arr1 db 02H, 09H, 06H, 10H, 07H

arr2 db ?

len dw \$-arr1

ends

code

start

    mov ax, @data

    mov ds, ax

    mov es, ax

    mov cx, len

    lea si, arr1

    lea di, arr2

    repnz movsb

    mov ah, 4CH

    int 21H

ends

end start