

# Instruction set

- Data transfer Instructions
- Arithmetic Instructions
- Logical Instructions

# Instruction set

- Data transfer Instructions

1. General Purpose grp
2. Input/Output
3. Address Object
4. Flag transfer

1) General Purpose grp

MOV

PUSH

POP

XCHG

XLAT

# Data transfer group

MOV: Copy a word or a byte

MOV destination,source

1. Memory,accumulator eg mov [SI],AL
2. Accumulator,memory
3. Register,register
4. Register,memory
5. Memory,register
6. Register,immediate
7. memory.,immediate
8. Seg-reg,reg-16 e.g. mov DS,AX
9. Seg-reg,mem-16 e.g. mov DS,[SI]
10. Reg-16,seg-reg
11. Memory,seg-reg

# Data transfer group

MOV: Copy a word or a byte

MOV destination,source

## 1. Memory,accumulator eg mov [SI],AL



Fig. 5.6.2 : MOV [SI], AL

In case of 16-bit transfer the contents of register AL are copied to memory location whose offset is [1023] and contents of register AH are copied to location whose offset is [1024]. This is indicated in Fig 5.6.3.



Fig. 5.6.3 : MOV [SI], AX

Let the contents of CS → 2105 H, IP → 187A H, DS → 2314 H and AL → 20 H

Generation of physical address (PA)

|             |                             |
|-------------|-----------------------------|
| 2 3 1 4 0 H | → Contents of DS            |
| + 1 0 2 3 H | → Offset of memory location |
| 2 4 1 6 3 H | → Physical address          |

The contents of Reg. AL will be transferred at the location whose physical address is given by 24163 H.

|                                 | Before execution | After execution  |
|---------------------------------|------------------|------------------|
| Code Segment (CS)               | 2105 H           | 2105 H           |
| <b>Instruction Pointer (IP)</b> | <b>187A H</b>    | <b>187C H</b>    |
| Data Segment (DS)               | 2314 H           | 2314 H           |
| Register AL                     | 20 H             | 20 H             |
| <b>Memory location 24163 H</b>  | <b>FF H</b>      | <b>20 H</b>      |
| Figure                          | Refer Fig. 5.6.4 | Refer Fig. 5.6.5 |

→ Note the change

→ Note the change

# Data transfer group



Fig. 5.6.4 : Before execution



Fig. 5.6.5 : After execution

# Data transfer group

MOV destination,source

2. MOV accumulator, memory eg mov AX,Temp\_Result

and Temp\_Result → FF H, AH → 00 H, AL → 0A

Generation of physical address (PA)

|             |                             |
|-------------|-----------------------------|
| 2 3 1 4 0 H | → Contents of DS            |
| + 1 2 3 4 H | → Offset of memory location |
| 2 4 3 7 4 H | → Physical address          |

The contents of Memory Location will be transferred/copied to the & the contents of Memory Location will be transferred/copied to the A

## 16-Bit Transfer

Contents of memory location whose offset is [1234] are copied to AL Reg.



Fig. 5.6.6 : MOV AX, Temp\_Result

# Data transfer group

## MOV destination,source

3. MOV destination register,source register

eg mov AX,BX

# Data transfer group

# MOV destination,source

4. MOV register, memory eg mov CX,COUNT[DI]

MOV ECX, COUNT [DI]

This instruction copies the contents of the source file to the destination file.

This instruction copies the contents of the CX register. Contents of first location are copied to CL, contents of the next location to CH register.

**Note** : Count is any variable which is defined while programming.



**Fig. 5.6.9 : Before execution**

# Data transfer group

MOV destination,source

4. MOV register,memory eg mov CX,COUNT[DI]

cessor (MU-COMP)

5-23

8086/8088 Addressing Modes & Ins



Fig. 5.6.10 : After execution

# Data transfer group

## MOV destination,source

5. MOV memory, register    eg mov COUNT[DI], CX

# Data transfer group

## MOV destination,source

6. MOV register,immediate eg MOV CL,02h

7. MOV memory, immediate eg MOV COUNT[DI],2DH

8.MOV seg reg.,reg-16 eg MOV DS,AX

9. MOV seg reg.,mem-16 eg MOV DS,[SI]

10. MOV reg-16, seg reg. eg MOV AX,DS

11.MOV memory, seg reg. eg MOV count,DS

# Data transfer group

PUSH:Push word onto stack

**PUSH Source**

**SP=SP-2**

**SS:[SP] (Top of the stack)=Operand**

- This instruction decrements the stack pointer by 2 and copies a word from a specified source to the location in the stack segment where stack pointer points.
- The source of operand (16 bit data to be stored on stack) can be a general purpose register, flag register, segment register or memory.
- The stack segment register and stack pointer must be initialised before using this instruction.
- PUSH can be used to save data on the stack so that it will not be destroyed by a execution of successive instructions.

# Data transfer group

## PUSH:Push word onto stack



# Data transfer group

PUSH:Push word onto stack

IP)

5-27

8086/8088 Addressing



**Fig. 5.6.12 : PUSH AX**

# Data transfer group

POP:Pop word off stack

**POP destination or POP Operand**

**Operand=SS:[SP](top of stack)SP=SP+2**

- This instruction copies a word from stack segment in memory to a destination specified in the instruction.
- The destination can be a general purpose register, flag register, a segment register or a memory location.
- The data in the stack pointer is not changed.
- After the word is copied to specified destination the stack pointer is automatically incremented by 2 to point to next word on stack.

# POP: P

microprocessor (MU-COMP)

Let the contents of  $477B6 \rightarrow 3BH$  and contents of  $477B7 \rightarrow 2A H$ .



Fig. 5.6.13



Fig. 5.6.14 : POP AX

## Data transfer group

### XCHG: exchange byte or word

XCHG destination,source

XCHG AX,BX

- This instruction exchanges the contents of a register with contents of another register or the contents of a register with contents of memory location.
- The register can be 8/16 bit .
- XCHG cannot directly exchange the contents of two memory locations.  
eg XCHG [1234],[5068] this transfer not possible
- The source and destination must both be words or they both must be bytes.

# Data transfer group

## XCHG: exchange byte or word

$AX \leftrightarrow BX$

This instruction will exchange the word in AX with word in BX register.

Contents of AL  $\leftrightarrow$  Contents of BL, Contents of AH  $\leftrightarrow$  Contents of BH

te :

1)

The segment registers cannot be used as registers in this instruction. The memory address part of the instruction is always zero.

2)

Since immediate operands cannot be changed neither operand in this instruction can be immediate.



Fig. 5.6.15 : XCHG AX, DX

## Data transfer group

XLAT/XLATB: Translate or replace byte

AL=DS:[BX + unsigned AL]

- This instruction replaces a byte in AL register with a byte from a look up table in the memory.i.e. it copies the value of memory byte at location DS:[BX + unsigned AL] to AL register.
- This instruction is used to translate a byte from one code to another code.
- This concept is used to convert BCD to seven segment code.

# XLAT

coprocessor (MU-COMP)

|                  |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>eneration</b> | AL $\leftarrow$ DS : [BX + AL] | <ul style="list-style-type: none"> <li>• This instruction replaces a byte in a look up table in the memory. i.e. it copies the value of memory byte at location DS : [BX + unsigned ALL] to the AL register.</li> <li>• Here contents of AL before execution acts as index to the desired location in lookup table.</li> <li>• This instruction is used to translate a byte from one code to another code.</li> <li>• Mostly this concept is used to convert BCD to seven segment code or ASCII to EDCBIC code conversion</li> </ul> |
|------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## **Generation of physical address**

|   |               |          |   |                  |
|---|---------------|----------|---|------------------|
| + | 23140         | H        | → | Address of DS    |
| + | 2134          | H        | → | Offset of BX     |
| + | <u>      </u> | 02 H     | → | Contents of AL   |
|   | <b>25276</b>  | <b>H</b> | → | Physical address |

25276 H is the base of look up table. The contents at this location are transferred to AL as shown in 5.6.16(b).



**Fig. 5.6.16(a) : XLAT**

# Data transfer group

## XLAT/XLATB: Translate or replace byte

cessor (MU-COMP)

5-31

8086/8088 Addressing Modes & In



Fig. 5.6.16(b)

# Data transfer group:Input/Output

IN: Copy data from a port

    IN accumulator, port address

e.g. IN AL,C8h

- This instruction will copy data from a port whose address is given in instruction to AX register or AL register. The data can be either 8 bit or 16 bit.
- The IN register has 2 possible formats.
  - i) Fixed port
  - ii) variable port
- For **Fixed port**, the port address is directly specified in the instruction.
- For **Variable port**, the port address is loaded into DX register before IN instruction. Since, DX is a 16 bit register, the port address can be any no between 0000H to FFFFH, so total 65,536 ports are possible.

e.g. MOV DX, 0FF0H

    IN AL,DX

# Data transfer group:Input/Output

**OUT: Output byte or word to a port**

**OUT port address, accumulator**

e.g. MOV DX,FFF8h

OUT DX,AL

- This instruction copies a byte from AL or a word from AX to the specified port.
- OUT has 2 possible forms.
  - i) Fixed port
  - ii) variable port
- For **Fixed port**, the 8 bit port address is directly specified in the instruction.

e.g. OUT 3Bh,AL
- For **Variable port**, the contents of AL or AX will be copied to the port at an address contained in DX. The DX register should be loaded with the desired port address.

e.g. MOV DX, OFF0H

# Data transfer group:Address object

## 1) LEA: Load Effective Address

### **LEA register,source**

e.g. LEA AX, COUNT

- This instruction determines the offset of variables or memory location named as source and puts the offset in the indicated 16 bit register.

# Data transfer group:Address object

## 1) LEA: Load Effective Address

Before Execution



After Execution



The LSB of offset of count is loaded in the AL register

The MSB of offset of count is loaded in the AH register



Note : The Offset of variable count is loaded in the AX register, not its contents

Fig. 5.6.17 : LEA AX, count

## Data transfer group:Address object

2) LDS : Load pointer with DS(Load register and DS with words from memory)

**LDS register,source**

e.g. LDS BX, COUNT

- This instruction is 2 byte instruction which copies a word from two memory locations into register specified in the instruction. It then copies a word from the next two memory locations into the DS register.

# Data transfer group:Address object

## 2) LDS : Load pointer with DS(Load register and DS with words from

Before Execution

5-34

8086/8088 Addressing Modes & Instruction



After Execution



The contents of location 25185 will be copied to BL and contents of 25186 to BH



The contents of locations 25187 and 25188 will be copied to DS

Fig. 5.6.18 : LDS BX, count

# Data transfer group:Address object

## 3) LES : Load pointer with ES(Load register and ES with words from memory)

**LES register,source**

e.g. LES BX, COUNT

- The Source is always a memory location.
- This instruction is 2 byte instruction which copies a word from two memory locations into register specified in the instruction. It then copies a word from the next two memory locations into the ES register.

**NOTE:**The source cannot be a register.

# Data transfer group:Address object

## 3) LES : Load pointer with ES(Load register and ES with words from memory)

### Before Execution



8086

8086/8088 Addressing Modes &amp; Instructions



### After Execution



The contents of location 25185  
 will be copied to BL and contents of  
 25186 to BH

### Memory Address



The contents of locations 25187  
 and 25188 will be copied to ES

Fig. 5.6.19 : LES BX, count

# Data transfer group:Flag transfer

These instructions are related to movement of flag register to/from a register and memory.

## 1) LAHF : Load AH register from flags(Copy lower byte of flag register to AH)

### LAHF

e.g. LAHF

- The lower byte of 8086 flag register is copied to the AH register.
- U indicates undefined i.e. value of that bit is indeterminate (it may be 0 or 1 anything)

# Data transfer group:Flag transfer

1) LAHF : Load AH register from flags(Copy lower byte of flag register to AH)

### Before Execution

|    |    |
|----|----|
| A0 | 03 |
| AH | AL |



### After Execution

|    |    |
|----|----|
| C6 | 03 |
| AH | AL |



Contents of LSB of flag register = C6 H are copied to AH register

Fig. 5.6.20 : LAHF

## Data transfer group:Flag transfer

2) SAHF : Store AH register in flags(Copy contents of AH to lower byte of flag register)

**SAHF**

e.g. SAHF

- This instruction copies the contents of AH register to the lower byte of flag register.
- U indicates undefined i.e. value of that bit is indeterminate (it may be 0 or 1 anything)

# Data transfer group:Flag transfer

## 2) SAHF : Store AH register in flags(Copy contents of AH to lower byte of flag register)

|                  |                                  |                                                             |                                                                                                                                                                                                                                   |
|------------------|----------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Mnemonic</b>  | SAHF                             | <i>(Copy contents of AH to lower byte of flag register)</i> |                                                                                                                                                                                                                                   |
| <b>Algorithm</b> | AH = flag register               | <b>Flags</b>                                                | All the flags are changed.                                                                                                                                                                                                        |
| <b>Operation</b> | AH → Lower byte of flag register |                                                             | <ul style="list-style-type: none"> <li>This instruction copies the contents of AH to the lower byte of flag register.</li> <li>It is included for 8085 compatibility.</li> <li>The OF, DF, IF and TF are not affected.</li> </ul> |

Let the contents of Flag register be 0CC6 H

### Before Execution

|    |    |
|----|----|
| A0 | 03 |
| AH | AL |



### After Execution

|    |    |
|----|----|
| A0 | 03 |
| AH | AL |



Contents of AH register are copied to LSB of flag register

Fig. 5.6.21 : SAHF

# Data transfer group:Flag transfer

## 3) **PUSHF** : Push flags onto stack(Push flag register onto stack)

**PUSHF**

e.g. PUSHF

- This instruction decrements the stack pointer by 2 and copies word in the flag register to the memory location pointed by stack pointer.
- MSB to SP-1 and LSB to SP-2.

# Data transfer group:Flag transfer

## 3) PUSHF : Push flags onto stack(Push flag register onto stack)

Step 1



Step 2



Fig. 5.6.22 : PUSHF

# Data transfer group:Flag transfer

## 4) POPF : Pop flags off stack.

**POPF**

e.g. POPF

- This instruction copies a word from the two memory locations at the top of the stack to flag register and increments the stack pointer by 2.
- SP to LSB and SP+1 to MSB.

# Data transfer group:Flag transfer

## 4) POPF : Pop flags off stack.

Step 1



Step 2



# Arithmetic group: Addition

1. ADD
2. ADC
3. INC
4. AAA
5. DAA

## 1. ADD: Add byte or word

**ADD destination,source**

- This instruction adds a number from source to number from destination and puts the result to specified destination.

register,register

register,memory

memory,register

register,immediate

memory,immediate

accumulator,immediate

# Arithmetic group: Addition

i) ADD register ,register e.g. ADD BL,CL

**Example**

ADD BL, CL

- This instruction can be 8/16 bit .
- This instruction adds the data in register CL  
The result is stored in BL register. It can be 8 instruction

$$BL \leftarrow BL + CL$$

**Note** : The register cannot be a segment register.

Let CL = 04 H and BL = 07 H

$$\begin{array}{r} CL \quad 04\text{ H} \\ BL \quad + \quad 07\text{ H} \\ \hline 0B\text{ H} \end{array} \rightarrow \text{Result stored in BL}$$

Before Execution

|    |  |    |
|----|--|----|
| AX |  |    |
| BX |  | 07 |
| CX |  | 04 |
| DX |  |    |
| SI |  |    |
| DI |  |    |
| BP |  |    |
| SP |  |    |

Contents of registers  
CL & BL are added &  
result is stored in BL

After Execution

|    |  |    |
|----|--|----|
| AX |  |    |
| BX |  | 0B |
| CX |  | 04 |
| DX |  |    |
| SI |  |    |
| DI |  |    |
| BP |  |    |
| SP |  |    |

Fig. 5.7.1 : ADD BL, CL

# Arithmetic group: Addition

- ii) ADD register ,memory e.g. ADD AX,[2048]



# Arithmetic group: Addition

iii) ADD memory, register e.g. ADD [2048],AX



Fig. 5.7.3 : ADD [2048], AX

# Arithmetic group: Addition

iv) ADD register ,immediate/ADD accumulator, immediate

e.g. ADD AL,74H



# Arithmetic group: Addition

v) ADD memory ,immediate e.g. ADD COST,75H

DS → 2314 H, offset (i.e. cost)  
immediate number → 75 H.

## Generation of physical address (PA)

$$\begin{array}{r} 23140 \text{ H} \\ + 5214 \text{ H} \\ \hline 28354 \text{ H} \end{array} \rightarrow \begin{array}{l} \text{Contents of DS register} \\ \text{Offset i.e. value of COST} \\ \text{Physical Address (PA)} \end{array}$$

$$\begin{array}{r} 75 \text{ H} \\ + 14 \text{ H} \\ \hline 89 \text{ H} \end{array} \rightarrow \begin{array}{l} \text{Immediate Data given in instruction .} \\ \text{Contents of memory location 28354 H} \\ \text{Result which will be stored at memory location 28354 H.} \end{array}$$



Fig. 5.7.5 : ADD COST, 75 H

# Arithmetic group: Addition

## 2) ADC: Add with carry

ADC destination,source e.g. ADC AL,BL ( ie.AL<-AL+BL+CY)

- This instruction adds destination operand contents,source operand contents and carry flag and answer is stored back to destination operand.



# Arithmetic group: Addition

## 3) INC: Increment byte or word by 1

**INC destination** e.g INC AL

| thm  | destination =destination + 1             | Addr. Mode | affected.<br>Implied addressing mode                                                                                                                                                                                                     |
|------|------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tion | destination $\leftarrow$ destination + 1 |            | <ul style="list-style-type: none"><li>• This instruction adds 1 to the destination</li><li>• The operand may be a byte or word and is an unsigned binary number.</li><li>• The destination operand may be a register location.</li></ul> |
| ole  | INC CX<br>INC AL                         |            | Add 1 to contents of CX<br>Add 1 to contents of AL register.                                                                                                                                                                             |

Before Execution

|    |  |   |  |
|----|--|---|--|
| AX |  | 9 |  |
| BX |  |   |  |
| CX |  |   |  |
| DX |  |   |  |
| SI |  |   |  |
| DI |  |   |  |
| BP |  |   |  |
| SP |  |   |  |

Increments AL by 1

After Execution

|    |  |    |  |
|----|--|----|--|
| AX |  | 0A |  |
| BX |  |    |  |
| CX |  |    |  |
| DX |  |    |  |
| SI |  |    |  |
| DI |  |    |  |
| BP |  |    |  |
| SP |  |    |  |

Fig. 5.7.7 : INC AL

# Arithmetic group: Addition

## 4) AAA: ASCII adjust after addition

**Algo:** If lower nibble of AL>9 or AF=1

then:

AL=AL+6

AH=AH+1

AF=1

CF=1

else:

AF=0

CF=0

- We enter data through keyboard is usually in ASCII code. The numbers 0 to 9 are represented by ASCII codes 30H to 39H. The 8086 allows to add the ASCII codes for two decimal digits without masking off “3” in the upper nibble of each.
- After addition, AAA instruction is used to make sure that the result is the correct unpacked BCD.
- AAA works only on AL register.

# Arithmetic group: Addition

## 4) AAA: ASCII adjust after addition

ASCII code. The numbers in ASCII code are in BCD format. AAA instruction allows to add the ASCII codes for two decimal digits without overflow. It takes nibble of each. After addition, AAA instruction is used to make sure that the result is correct unpacked BCD.

- The AAA instruction works only on AL register.
- If the lower nibble of AL register after addition is greater than 9, a carry is generated and increment AH by 1. The auxiliary carry flag and carry flag are set.

Assume

AL = 0 0 1 1 0 1 0 1    ASCII 5

BL = 0 0 1 1 1 0 0 1    ASCII 9

Add AL, BL

$$\begin{array}{r}
 & 0 & 0 & 1 & 1 & & 0 & 1 & 0 & 1 \\
 + & 0 & 0 & 1 & 1 & & 1 & 0 & 0 & 1 \\
 \hline
 & 0 & 1 & 1 & 0 & & 1 & 1 & 1 & 0 \\
 + & & & & & & 0 & 1 & 1 & 0 \\
 \hline
 & 0 & 0 & 0 & 0 & & 0 & 1 & 0 & 0
 \end{array} \rightarrow \text{Result of addition}$$

↓

Invalid BCD

$\Rightarrow$  [1] Clear higher nibble

(04 H)  $\rightarrow$  Result in AL valid BCD.

(01 H)  $\rightarrow$  Result in AH. The carry is stored in AH

Before Execution

|    |  |    |   |
|----|--|----|---|
| AX |  | 35 | } |
| BX |  | 39 |   |
| CX |  |    |   |
| DX |  |    |   |
| SI |  |    |   |
| DI |  |    |   |
| BP |  |    |   |
| SP |  |    |   |

AAA adjusts the contents of AL to two ASCII characters after addition of AL & BL

After Execution

|    |   |   |   |
|----|---|---|---|
| AX | 1 | 4 | } |
| BX |   |   |   |
| CX |   |   |   |
| DX |   |   |   |
| SI |   |   |   |
| DI |   |   |   |
| BP |   |   |   |
| SP |   |   |   |

| SF | ZF | U | AF | U | PF | U | CF |
|----|----|---|----|---|----|---|----|
| 1  | 1  | 0 | 0  | 0 | 1  | 1 | 0  |

| SF | ZF | U | AF | U | PF | U | CF |
|----|----|---|----|---|----|---|----|
| 1  | 1  | 0 | 0  | 0 | 1  | 1 | 1  |

Fig. 5.7.8 : AAA

# Arithmetc group: Addition

## 5) DAA: Decimal adjustment for addition

**Algo:** If lower nibble of AL>9 or AF=1

then:

$$AL = AL + 06H$$

$$AF = 1$$

If AL>9FH or CF=1 then,

$$AL = AL + 60H$$

$$CF = 1$$

- This instruction is used to make sure that the result of adding two packed BCD numbers is adjusted to be a valid BCD number.
- It operates only on AL register.

e.g. Add AL,BL

$$AL = 59h$$

$$BL = 34h$$

# Arithmetic group: Addition

## 5) DAA: Decimal adjustment for addition

ssor (MU-COMP)

5-49

8086/8088 Addressing Modes & Ins

on  
on AL  $\leftarrow$  Sum in adjusted to packed BCD format

- This instruction is used to make sure that the result of two packed BCD numbers is adjusted to be a valid number.
- It operates only on AL register.
- If number in the lower nibble of AL register after addition is greater than 9 or if the auxiliary carry flag is set add 60 H.
- If the lower nibble of AL is greater than 9 or if the carry flag is set then add 60 H.

If AL = 59 H valid BCD, BL = 34 H valid BCD

$$\begin{array}{r}
 \text{ADD AL, BL} \\
 \begin{array}{r}
 \begin{array}{r} 0 & 1 & 0 & 1 \\ + & 0 & 0 & 1 & 1 \\ \hline 1 & 0 & 0 & 0 \end{array} &
 \begin{array}{r} 1 & 0 & 0 & 1 \\ + & 0 & 1 & 0 & 0 \\ \hline 1 & 1 & 0 & 1 \end{array} \\
 \underbrace{\hspace{1cm}}_8 & \underbrace{\hspace{1cm}}_{\text{D}} \end{array}
 \end{array}$$

AL = 8 DH invalid BCD after addition of AL and BL

$$\begin{array}{r}
 \text{DAA} \rightarrow \\
 \begin{array}{r}
 \begin{array}{r} 1 & 0 & 0 & 0 \\ + & 0 & 0 & 0 & 0 \\ \hline 1 & 0 & 0 & 1 \end{array} &
 \begin{array}{r} 1 & 1 & 0 & 1 \\ + & 0 & 1 & 1 & 0 \\ \hline 0 & 0 & 1 & 1 \end{array} \\
 \underbrace{\hspace{1cm}}_9 & \underbrace{\hspace{1cm}}_3 \end{array}
 \end{array}$$

$\therefore$  AL = 93 H BCD

Before Execution

|    |  |    |
|----|--|----|
| AX |  | 59 |
| BX |  | 34 |
| CX |  |    |
| DX |  |    |
| SI |  |    |
| DI |  |    |
| BP |  |    |
| SP |  |    |

DAA adjusts the addition to valid BCD

After Execution

|    |  |    |
|----|--|----|
| AX |  | 93 |
| BX |  | 34 |
| CX |  |    |
| DX |  |    |
| SI |  |    |
| DI |  |    |
| BP |  |    |
| SP |  | -  |

Fig. 5.7.9 : DAA

# Arithmetic group: Subtraction

1. SUB
2. SBB
3. DEC
4. NEG
5. CMP
6. AAS
7. DAS

# Arithmetic group: Subtraction

1. SUB: Subtract byte or word

SUB destination,source

- This instruction subtracts a number from source with number from destination and puts result in the destination location.

| Destination | Source    |
|-------------|-----------|
| Register    | Register  |
| Register    | memory    |
| Memory      | Register  |
| Accumulator | immediate |
| Register    | immediate |
| Memory      | immediate |

# Arithmetic group: Subtraction(SUB reg,reg)

Example :

SUB BL, CL

$BL \leftarrow BL - CL$

This instruction subtracts the contents of CL register from BL and result is stored in BL register.

Let  $CL \rightarrow 04H$ ,  $BL \rightarrow 07H$

$$\begin{array}{r} 07 \\ - 04 \\ \hline 03 \end{array} \rightarrow \begin{array}{l} BL \\ CL \\ \text{Result of subtraction which will be stored in BL register} \end{array}$$

Before Execution

|    |    |  |
|----|----|--|
| AX |    |  |
| BX | 07 |  |
| CX | 04 |  |
| DX |    |  |
| SI |    |  |
| DI |    |  |
| BP |    |  |
| SP |    |  |

Contents of registers  
CL & BL are subtracted &  
result is stored in BL

After Execution

|    |    |  |
|----|----|--|
| AX |    |  |
| BX | 03 |  |
| CX | 04 |  |
| DX |    |  |
| SI |    |  |
| DI |    |  |
| BP |    |  |
| SP |    |  |

Fig. 5.7.10 : SUB BL, CL

# Arithmetic group: Subtraction(SUB mem,reg) e.g.SUB [2048],AX

- Note :**
- 1) The register cannot be a segment register.
  - 2) The subtraction of two memory locations is not allowed.  
e.g. SUB [1024] , [2048] is not allowed.
  - 3) The memory uses DS as a segment register.

Let the contents of CS → 2105 H, IP → 187 A , DS → 2314 H, offset → [2048] H

## Generation of physical address

|                  |          |                               |
|------------------|----------|-------------------------------|
| 2 3 1 4 0        | H        | → Contents of DS register     |
| + 2 0 4 8        | H        | → Offset given in instruction |
| <b>2 5 1 8 8</b> | <b>H</b> | → Physical address (PA)       |

$$\begin{array}{r}
 2024 \text{ H} \quad \text{H} \rightarrow \text{Contents of memory location } 25188 \text{ H and } 25189 \text{ H} \\
 - 1005 \text{ H} \quad \text{H} \rightarrow \text{Contents of AX register} \\
 \hline
 \textbf{101F H} \quad \text{H} \rightarrow \text{Result is stored at memory location } 25188 \text{ H & } 25189 \text{ H}
 \end{array}$$



# Arithmetic group: Subtraction(SUB reg,immediate) e.g.SUB AL,24h

|                    |                                                                                                                                                                                                                |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L, 24 H<br>AL - 24 | <ul style="list-style-type: none"> <li>This immediate data can be 8/16 bit.</li> <li>This instruction subtracts the immediate number 24 H with contents of AL register. The result is stored in AL.</li> </ul> |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

$$\begin{array}{r}
 74 \text{ H} \\
 - 24 \text{ H} \\
 \hline
 50 \text{ H}
 \end{array}
 \rightarrow \begin{array}{l}
 \text{Contents of AL register} \\
 \text{Contents of Immediate Data} \\
 \text{Result which will be stored in AL register}
 \end{array}$$

Before Execution



Contents of AL are subtracted with contents 24 H & result is stored in AL



After Execution



Fig. 5.7.12 : SUB AL, 24 H

# Arithmetic group: Subtraction(SUB mem,immediate) e.g.SUB COST,14h

|                                                                |                                                                                                                                                      |
|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| COST $\leftarrow$ COST - 14 H<br>[Cost : is a memory location] | contents of memory location [i.e. memory location 28354 H]<br>instruction [i.e. memory location 28354 H]<br>Result of subtraction is stored at COST. |
|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|

Let the contents of CS  $\rightarrow$  2105 H, IP  $\rightarrow$  187 AH, DS  $\rightarrow$  2314 H, offset (i.e. cost)  $\rightarrow$  5214, immediate number  $\rightarrow$  75 H.

## Generation of physical address (PA) :

|                                                                                                       |                                                                               |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| $  \begin{array}{r}  23140 \quad H \\  + \quad 5214 \quad H \\  \hline  28354 \quad H  \end{array}  $ | Contents of DS register<br>Offset i.e. value of COST<br>Physical Address (PA) |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|

$$\begin{array}{r}
 75 \quad H \rightarrow \text{Contents of memory location } 28354 \text{ H} \\
 - \quad 14 \quad H \rightarrow \text{Immediate data} \\
 \hline
 61 \quad H \rightarrow \text{Result which will be stored at memory location } 28354 \text{ H.}
 \end{array}$$



Fig. 5.7.13 : SUB COST, 14 H

# Arithmetic group: Subtraction

2. SBB: Subtract byte or word with borrow
  - SBB destination,source
  - SBB AL,BL
- This instruction subtracts source and carry flag( i.e. Borrow) from destination.

## Note:

1. The source and destination register cannot be a segment register.
2. The subtraction of two memory locations is not allowed.  
e.g. SUB [1024],[2018]              not allowed
3. The memory uses DS as a segment register.

# Arithmetic group: Subtraction

Let  $AL \rightarrow 34 H$ ,  $BL \rightarrow 24 H$   $CY=1 H$

$$\begin{array}{r}
 3 \ 4 \ H \quad \rightarrow \text{Contents of AL register} \\
 - \ 2 \ 4 \ H \quad \rightarrow \text{Contents of BL register} \\
 \hline
 1 \ 0 \ H \quad \rightarrow \text{Contents of Carry Flag} \\
 - \ 0 \ 1 \ H \quad \rightarrow \text{Result} \\
 \hline
 0 \ F \ H \quad \rightarrow \text{Result}
 \end{array}$$

Before Execution

|           |  |    |  |
|-----------|--|----|--|
| <b>AX</b> |  | 34 |  |
| <b>BX</b> |  | 24 |  |
| <b>CX</b> |  |    |  |
| <b>DX</b> |  |    |  |
| <b>SI</b> |  |    |  |
| <b>DI</b> |  |    |  |
| <b>BP</b> |  |    |  |
| <b>SP</b> |  |    |  |



After Execution

|           |  |    |  |
|-----------|--|----|--|
| <b>AX</b> |  | 0F |  |
| <b>BX</b> |  | 24 |  |
| <b>CX</b> |  |    |  |
| <b>DX</b> |  |    |  |
| <b>SI</b> |  |    |  |
| <b>DI</b> |  |    |  |
| <b>BP</b> |  |    |  |
| <b>SP</b> |  |    |  |

| U | U | U | U | OF | DF | IF | TF | SF | ZF | U | AF | U | PF | U | CF |
|---|---|---|---|----|----|----|----|----|----|---|----|---|----|---|----|
| 0 | 0 | 0 | 0 | 1  | 1  | 0  | 0  | 1  | 1  | 0 | 0  | 0 | 1  | 1 | 1  |

Fig. 5.7.14 : SBB AL, BL

# Arithmetic group: Subtraction

3. DEC: Decrement byte or word by 1

DEC destination

DEC AL

- This instruction subtracts 1 from the destination word or byte .
- The destination can be a register or a memory location.
- This instruction cannot be used to decrement the contents of segment registers.

# Arithmetic group: Subtraction

J-COMP)

5-56

8086/8088 Addressing Mod



Fig. 5.7.15 : DEC AL

affected i.e. if an 8 bit destination containing 00H or 16 bit destination containing 0000H  
will be FFH or FFFFH with no carry flag.

# Arithmetic group: Subtraction

4. AAS: ASCII adjust for subtraction.

AAS

Algo: If lower nibble of AL>9 or AF=1 then:

AL=AL-06H

AH=AH-1

AF=1

CF=1

else

AF=0

CF=0

# Arithmetic group: Subtraction

high nibble of AL

- The number 0 to 9 are represented as 30 – 39 in ASCII code
- The 8086 allows us to subtract the ASCII codes for two decimal digits “3” in upper nibble of each.
- The AAS instruction is used to make sure that the result is in unpacked
- It works only on the AL register.

Let AL = 0011 1001 = 39 H = ASCII 9

Let BL = 0011 0101 = 35 H = ASCII 5

|                           |   |         |         |            |
|---------------------------|---|---------|---------|------------|
| SUB AL, BH → Result AAS   | = | 0 0 1 1 | 1 0 0 1 |            |
|                           | - | 0 0 1 1 | 0 1 0 1 |            |
|                           | 0 | 0 0 0 0 | 0 1 0 0 | = BCD = 04 |
| CF = 0 no borrow required |   |         |         |            |

Before Execution

|    |  |    |
|----|--|----|
| AX |  | 39 |
| BX |  | 35 |
| CX |  |    |
| DX |  |    |
| SI |  |    |
| DI |  |    |
| BP |  |    |
| SP |  |    |

AAA adjusts the contents of AL to two ASCII characters after subtraction of AL & BL

After Execution

|    |   |   |
|----|---|---|
| AX | 0 | 4 |
| BX |   |   |
| CX |   |   |
| DX |   |   |
| SI |   |   |
| DI |   |   |
| BP |   |   |
| SP |   |   |

No Carry

| SF | ZF | U | AF | U | PF | U | CF |
|----|----|---|----|---|----|---|----|
| 1  | 1  | 0 | 0  | 0 | 1  | 1 | 1  |

| SF | ZF | U | AF | U | PF | U | CF |
|----|----|---|----|---|----|---|----|
| 1  | 1  | 0 | 0  | 0 | 0  | 1 | 1  |

Fig. 5.7.16 : AAS

# Arithmetic group: Subtraction

5. DAS : Decimal adjust for subtraction.

DAS

Algo: If lower nibble of AL>9 or AF=1 then:

$$AL = AL - 06H$$

$$AH = AH - 1$$

$$AF = 1$$

If AL > 9FH or CF=1 then

$$AL = AL - 60H$$

$$CF = 1$$

- This instruction is used after subtracting two packed BCD numbers to make sure that the result is correct packed BCD. The result of subtraction must be in AL for DAS to work correctly.
- This instruction works only on AL register.

e.g. SUB AL,BH

DAS

# Arithmetic group: Subtraction

## 5. DAS : Decimal adjust for subtraction.

format

packed BCD

AL = 1000 0110 = 86 BCD  
BH = 0101 0111 = 57 BCD  
SUB AL, BH  
DAS

instruction is used after subtracting two packed numbers to make sure that the result is correct BCD. The result of subtraction must be in AL for work correctly.

- This instruction works only on AL register.
- If the lower nibble in AL after a subtraction is greater than 9 or if the auxiliary carry flag is set then the instruction will subtract 6 from the lower nibble of AL.
- If the result in the upper nibble is greater than 9 and the carry flag is set the DAS instruction will subtract 6 from the AL register.

AL = 0010 1111 = 2F H, CF = 0

Lower nibble of result is F H, i.e. greater than 9 so DAS subtracts 0000 0110 to give AL = 0010 1001 = 29 H BCD

# Arithmetic group: Subtraction

5. DAS : Decimal adjust for subtraction.



Fig. 5.7.17 : DAS

# Arithmetic group: Subtraction

## 6. NEG: Negate byte or word

NEG destination

NEG AX

Algo: Invert all bits of operand and add 1 to inverted operand.

- This instruction replaces the number in a destination with 2's complement of that number.
- The destination can be a register or memory location.
- This instruction forms the 2's complement by subtracting the original word or byte in the indicated destination from zero.
- It is useful for changing the sign of a signed word or a byte.

# Arithmetic group: Subtraction

## 6. NEG: Negate byte or word

- Attempt to negate a byte containing -128 or a word containing -32768. It changes to the operand and sets Overflow flag.

Example : NEG AX

AX  $\leftarrow$  2's complement of number in AX.

Suppose AX = 00A3 H = 0000 0000 1010 0011

Then it's 2's complement will be,

$$0000\ 0000\ 1010\ 0011 = 1111\ 1111\ 0101\ 1100 \leftarrow \text{1's complement of } 00A3 \text{ H}$$

$$\begin{array}{r} + \\ \hline 1111\ 1111\ 0101\ 1101 \end{array} \leftarrow \text{2's complement of number}$$

= FF5D H  $\leftarrow$  contents of AX after execution

**Before Execution**



**After Execution**



The bits in AX are complimented & 1 is added to them

Fig. 5.7.18 : NEG AX

# Arithmetic group: Subtraction

## 7. CMP: Compare byte or word

CMP destination,source

E.g. CMP BH,CL

Algo: Destination-source

- This instruction compares a word/byte from source with byte/word from destination. The comparison is done by subtracting the source byte or word from the destination byte or word.
- The result is not stored in either of the source or destination. The destination and source remain unchanged , only flags are updated.
- The source may be register, memory location or an immediate number.
- The destination may be register , memory location.

| Compare            | CF | ZF | SF |
|--------------------|----|----|----|
| Source>destination | 1  | 0  | 1  |
| Source<destination | 0  | 0  | 0  |
| Source=destination | 0  | 1  | 0  |

# Arithmetic group: Subtraction

## 7. CMP: Compare byte or word

- The source may be register, memory location or an immediate number.
- The destination may be a register or memory location.

| Compare              | CF | ZF | SF |                                   |
|----------------------|----|----|----|-----------------------------------|
| Source > destination | 1  | 0  | 1  | Subtraction required borrow, so C |
| Source < destination | 0  | 0  | 0  | No borrow required CF = 0         |
| Source = destination | 0  | 1  | 0  | Result of subtraction is zero     |

Example : CMP BH, CL

Compares a byte in CL with byte in BH.

Let CL → 05 H and BH → 04 H, CF → 0, ZF → 0, SF → 0:

$$= \begin{array}{r} 0000 \ 0100 \\ - 0000 \ 0101 \\ \hline 0000 \ 0100 \end{array} \rightarrow \text{BH}$$

$$- \begin{array}{r} 0000 \ 0101 \\ \hline 0000 \ 0100 \end{array} \rightarrow \text{CL}$$

Carry flag → 0 → Result of subtraction

Carry flag → 1 ← 2's complement of the result i.e. result comparison of BH and CL registers

- (i) The source and destination both cannot be memory locations.
- (ii) The compare instructions are often used with conditional Jump instructions.
- (iii) One of the

# Arithmetic group: Multiplication

1. MUL
2. IMUL
3. AAM

1.MUL: Multiply byte or word unsigned

MUL source

MUL CX

Algo: When operand is a byte  $AX=AL \times \text{operand}$ ,

When operand is a word  $(DX:AX)=AX \times \text{operand}$

- This instruction multiplies an unsigned byte from source with an unsigned byte in the AL register or an unsigned word from source with an unsigned word in AX.
- Byte then result in AX
- Word then result in DX and AX.

# Arithmetic group: Multiplication

1 MUL

- The source can be a register or memory location.
- This instruction cannot be used to multiply immediate data. If we want to multiply immediate data. Then that immediate data has to be stored into some valid register and then multiplied with byte or word in AL or AX

**Example**

MUL CX

DX:AX = CX \* AX : Result of multiplication MSB will be stored in DX register and the LSB will be stored in AX register.

Let AX  $\leftarrow$  0009 H, CX  $\leftarrow$  0054 H, DX  $\leftarrow$  FFFF H (initial data) CS  $\leftarrow$  2105 H, IP  $\leftarrow$  187 AH

MUL CX : 0009 H  $\leftarrow$  contents of AX register

$\times$  0054 H  $\leftarrow$  contents of CX register

**02F4 H**  $\leftarrow$  Result of multiplication which will be stored as follows :

DX  $\leftarrow$  0000 H (i.e. MSB)

AX  $\leftarrow$  02F4 H (i.e. LSB)

Before Execution

|    |    |    |
|----|----|----|
| AX | 00 | 09 |
| BX |    |    |
| CX | 00 | 54 |
| DX |    |    |
| SI |    |    |
| DI |    |    |
| BP |    |    |
| SP |    |    |

Operands

After Execution

|    |    |    |
|----|----|----|
| AX | 02 | F4 |
| BX |    |    |
| CX | 00 | 54 |
| DX | 00 | 00 |
| SI |    |    |
| DI |    |    |
| BP |    |    |
| SP |    |    |

Result of LSB of multiplication is stored in AX reg. & MSB in DX

Fig. 5.7.19 : MUL AX, CX

# Arithmetic group: Multiplication

2. IMUL: Multiply byte or word signed.

IMUL source

IMUL BL

Algo: When operand is a byte  $\rightarrow AX=AL \times \text{operand}$

When operand is a word  $\rightarrow (DX:AX)=AX \times \text{operand}$

- This instruction multiplies a signed byte from some source and a signed byte in AL, or a signed word from some source and a signed word in AX.
- The source can be register or memory location.
- When signed byte is multiplied by AL, a signed result will be put in AX.
- When a signed word is multiplied by AX, the MSB 16-bits are put in DX and LSB 16-bits are put in AX.
- If the magnitude of product does not require all bits of the destination, the unused bits are filled with the copies of the sign bit.
- To multiply a signed byte by a signed word it is necessary to move signed byte into lower byte of word and fill the upper byte of word with copies of sign bit. This can be done by CBW instruction.

# Arithmetic group: Multiplication

## 2. IMUL: Multiply byte or word signed.

### CDW instruction.

- If the upper byte of 16 bit result or upper word of 32 bit result contains only copies of sign bit (all 0's or all 1's) then the CF and OF will both be zeros.
- If the upper byte of 16 bit result or upper word of 32 bit result contains part of the product then the CF and OF will both be zeros.

Example : IMUL BL *net*

Let AL = 69 decimal = 0100 0101 = 45H

BL = 14 decimal = 0000 1110 = 0EH.

$$\begin{array}{r} \text{IMUL BL} \quad 45 \text{ H} \quad \leftarrow \text{Contents of AL register} \\ \times \quad 0E \text{ H} \quad \leftarrow \text{Contents of BL register} \\ \hline 03 \text{ CE } \text{H} \quad \leftarrow \text{Result of multiplication AX=03CE H} \end{array}$$

MSB = 0, Positive result magnitude in true form.  $\therefore$  SF = 0, CF = 0F = 1

Before Execution



After Execution



| SF | ZF | OF | AF | U | PF | U | CF |
|----|----|----|----|---|----|---|----|
| 1  | 1  | 0  | 0  | 0 | 1  | 1 | 1  |

| SF | ZF | OF | AF | U | PF | U | CF |
|----|----|----|----|---|----|---|----|
| 0  | 1  | 0  | 0  | 0 | 0  | 1 | 1  |

Fig. 5.7.20 : IMUL BH

# Arithmetic group: Multiplication

3. AAM – Integer multiply byte or word ASCII adjust for multiply  
AAM

e.g. MUL BH

AAM AX

Algo: AH=Quotient of AL/10

AL=remainder of AL/10

- Numerical data coming into a computer from a terminal through keyboard is usually in ASCII code. The numbers 0 to 9 are represented by ASCII codes 30H to 39H
- Before multiplying two ASCII digits, the upper nibble bits of each need to be masked. This leaves unpacked BCD in each byte. After the two unpacked BCD digits are multiplied, the AAM instruction is used to adjust the product of two unpacked BCD digits in AX.
- It works only on register AL.
- It is used after multiplying the two unpacked BCD numbers.

# Arithmetic group: Multiplication

## 3. AAM – Integer multiply byte or word ASCII adjust for multiply

- digits in AX.
- It works only on register AL.
- It is used after multiplying the two unpacked BCD numbers

### Example

Let  $AL \rightarrow 0000\ 0101$  = unpacked BCD 5  
 $BH \rightarrow 0000\ 1001$  = unpacked BCD 9  
MUL BH :  $AL * BH \rightarrow$  Result in AX register  
 $AX = 0000\ 0000\ 00101101 = 002D H$   
AAM AX :  $0000\ 01000\ 0000\ 0101 = 0405 H$   
Which is unpacked BCD for 45.

Before Execution

|    |   |
|----|---|
| AX | 5 |
| BX | 9 |
| CX |   |
| DX |   |
| SI |   |
| DI |   |
| BP |   |
| SP |   |

AAA adjusts the contents of AX to two ASCII characters after multiplication of AL & BL

After Execution

|    |    |    |
|----|----|----|
| AX | 04 | 05 |
| BX |    |    |
| CX |    |    |
| DX |    |    |
| SI |    |    |
| DI |    |    |
| BP |    |    |
| SP |    |    |

Fig. 5.7.21 : AAM

# Arithmetic group: Division

1. DIV
2. IDIV
3. AAD
4. CBW
5. CWD

## 1. DIV- Divide byte or word unsigned

DIV source

DIV BH

Algo: When operand is a byte:

AL=AX/operand (Quotient)

AH=remainder (Modulus)

When operand is a word:

AX=(DS:AX)/operand (Quotient)

DX= remainder(modulus)

# Arithmetic group: Division

## 1.DIV- Divide byte or word unsigned:

### BYTE divisor

$(AL) \leftarrow \text{Quotient of } (AX) / (\text{source})$   
 $(AH) \leftarrow \text{Remainder of } (AX) / (\text{source})$

### Word divisor

$(AX) \leftarrow \text{Quotient of } (DX : AX) / (\text{source})$   
 $(DX) \leftarrow \text{Remainder of } (DX : AX) / (\text{source})$

### Example : DIV BH

Divide word in AX by the byte in BH

$AX / BH$ , AL  $\rightarrow$  Quotient = 5 E H = 94 decimal.

AH  $\rightarrow$  remainder = 65 H = 101 decimal.



Fig. 5.7.22 : DIV BH

# Arithmetc group: Division

## 2.IDIV- Integer Divide byte or word

IDIV source

IDIV BL

**Algo:** When operand is a byte:

AL=AX/operand (Quotient)

AH=remainder (Modulus)

When operand is a word:

AX=(DS:AX)/operand (Quotient)

DX= remainder(modulus)

e.g. Let AX=03 ABH    BL=00 D3H

IDIV BL

Quotient in AL=ECH    Remainder in AH=27H

# Arithmetic group: Division

## 2.IDIV- Integer Divide byte or word

$AX \leftarrow$  quotient of  $(DS : AX) / \text{source}$

$DX \leftarrow$  remainder of  $(DS : AX) / \text{source}$

This instruction performs two operation :

1. Divide a signed word by a signed byte
2. Divide a signed double word by a signed word.

Example

A signed word divided by a single byte

Let  $AX = 03\ AB\ H$        $BL = 00\ D3\ H$

IDIV BL

Quotient in  $AL = EC\ H$

Remainder in  $AH = 27\ H$



Fig. 5.7.23 : IDIV BL

# Arithmetic group: Division

## 3. AAD: ASCII adjust for division

**AAD**

**DIV CL**

Algo:  $AL = (AH * 10) + AL$

$AH=0$

- It converts two unpacked BCD digits in AH and AL to the equivalent binary number in AL. This adjustment must be made before dividing the two unpacked BCD digits in AX, by an unpacked BCD byte .

After the division

$AL \rightarrow$  unpacked BCD quotient

$AH \rightarrow$  unpacked BCD remainder

# Arithmetic group: Division

## 3. AAD: ASCII adjust for division



Fig. 5.7.24 : AAD

# Arithmetic group: Division

## 4. CBW: Convert byte to word

CBW

Algo: If MSB bit of AL=1 then AH=255(FFH)  
else AH=0

- This instruction copies the sign bit in AL to all the bits in AH. AH is then said to be a sign extension of AL.
- This operation must be done before a signed byte in AL can be divided by another signed byte with IDIV instruction.

# Arithmetic group: Division

CBW - Convert byte to word

|                  |                                                                |                                                                                                                                                                                                                                                                                                |                         |
|------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| <b>Mnemonic</b>  | CBW                                                            | <b>Flags</b>                                                                                                                                                                                                                                                                                   | No flags are affected.  |
| <b>Algorithm</b> | If MSB bit of AL = 1 then<br>AH = 255 (FF H)<br>else<br>AH = 0 | <b>Addr. Mode</b>                                                                                                                                                                                                                                                                              | Implied Addressing mode |
| <b>Operation</b> |                                                                | <ul style="list-style-type: none"> <li>This instruction copies the sign bit in AL to all the bits in AH. AH is then said to be a sign extension of AL.</li> <li>This operation must be done before a signed byte in AL can be divided by another signed byte with IDIV instruction.</li> </ul> |                         |
| <b>Example</b>   | AX = 00AC H = - 163 decimal                                    | <b>CBW</b><br>Convert signed byte in AL to signed word in AX.<br>Result : 1 1 1 1 1 1 1 1 1 0 1 0 0 1 1 = - 163 decimal                                                                                                                                                                        |                         |

## Before Execution



## After Execution



Fig. 5.7.25 : CBW

# Arithmetic group: Division

## 5. CWD: Convert word to double word.

CWD

Algo: If MSB bit of AX=1 then, DX= 65535(FFFFH)

else DX=0

- This instruction copies the sign bit of word in AX to all the bits of DX register. DX is sign extension of AX then.
- It must be done before signed word in AX can be divided by another signed word with IDIV instruction.

# Arithmetic group: Division

## 5.CWD: Convert word to double word.

|       |                                                                                                                                                                                                                                                                            |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ation | <ul style="list-style-type: none"><li>This instruction copies the sign bit of word in AX to all the bits of DX register. It is extension of AX then.</li><li>It must be done before signed word in AX can be divided by another signed word in IDIV instruction.</li></ul> |
| ple   | If DX = 4AA3 H and AX = 00AC H                                                                                                                                                                                                                                             |

### Before Execution



### After Execution



The MSB of AX i.e. 0 is copied to DX

Fig. 5.7.26 : CWD

# Bit manipulation instructions

## Logicals:

### 1) NOT- Not byte or word

NOT destination

Algo: If bit is 1 turn it to 0

If bit is 0 turn it to 1

- This instruction inverts each bit of byte or word at the specified destination i.e. it finds 1's complement of the number.
- The destination can be a register or a memory location.
- The destination cannot be immediate data.
- The destination cannot be a segment register.

# Bit manipulation instructions

## 1) NOT- Not byte or word

|           |                                                        |                                                                                                                                                                                                                                                                           |
|-----------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | Destination $\leftarrow \overline{\text{Destination}}$ | <ul style="list-style-type: none"><li>This instruction inverts each bit of byte or specified destination i.e. it finds 1's complement number.</li><li>The destination can be a register or a memory location.</li><li>The destination cannot be immediate data.</li></ul> |
| Example   | NOT AX<br>AX $\leftarrow \overline{\text{AX}}$         | <p>The destination cannot be a segment register.</p> <p>This instruction complements the contents of AX.</p>                                                                                                                                                              |

### Before Execution



### After Execution



The bits in AX are complimented  
**Fig. 5.8.1 : NOT AX**

# Bit manipulation instructions

## Logicals:

### 2) AND - AND byte or word

AND destination ,source

AND AL,BL

Algo: destination= destination ^ source

- This instruction ANDs each bit in a source byte or word with the same number bit in a destination byte or word . The result is stored at specified location.
- The contents of specified source do not change.
- The source can be a register, memory location or an immediate number.
- The destination can be register or memory location.
- The source and destination both cannot be memory locations.
- The segment registers cannot be used as source or destination.

# Bit manipulation instructions

## 2) AND - AND byte or word

$$AL = 1001\ 0011 = 93\ H$$

$$BL = 0111\ 0101 = 75\ H$$

$$AL = 0001\ 0001 = 11\ H$$

| Addressing Modes & Instructions |                  |                 |
|---------------------------------|------------------|-----------------|
|                                 | Before execution | After execution |
| AL                              | 93 H             | 11 H            |
| BL                              | 75 H             | 75 H            |

### Before Execution

|    |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|
| AL | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
|----|---|---|---|---|---|---|---|---|

AND AL,BL

|    |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|
| BL | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |
|----|---|---|---|---|---|---|---|---|

### After Execution

The result of ANDing AL  
is stored in AL

|    |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|
| AL | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|----|---|---|---|---|---|---|---|---|

|    |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|
| BL | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |
|----|---|---|---|---|---|---|---|---|

Fig. 5.8.2 : AND AL, BL

# Bit manipulation instructions

## Logicals:

### 3) OR – Inclusive or byte or word

OR destination,source

OR AL,BL

Algo: destination= destination  $\vee$  source

- This instruction ORs each bit in a source byte or word with the same number bit in a destination byte or word . The result is stored at specified location.
- The contents of specified source do not change.
- The source can be a register, memory location or an immediate number.
- The destination can be register or memory location.
- The source and destination both cannot be memory locations.
- The segment registers cannot be used as source or destination.

# Bit manipulation instructions

## 3) OR – Inclusive or byte or word

|            |                                                                                                                                                                     |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | The segment registers cannot be used as source or destination. Destination can be a register or Memory location.                                                    |
| OR AL , BL | <ul style="list-style-type: none"><li>This instruction ORs each bit in a AL register with a BL register.</li><li>The result is stored in the AL register.</li></ul> |

Let AL = 93 H and BL = 75 H

### Before Execution

|          |                                                                                                                     |   |   |   |   |   |   |   |   |
|----------|---------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|
| AL       | <table border="1"><tr><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td></tr></table> | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 1        | 0                                                                                                                   | 0 | 1 | 0 | 0 | 1 | 1 |   |   |
| OR AL,BL | <table border="1"><tr><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td></tr></table> | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |
| 0        | 1                                                                                                                   | 1 | 1 | 0 | 1 | 0 | 1 |   |   |

### After Execution

The result of ORing AL  
is stored in AL

|    |                                                                                                                     |   |   |   |   |   |   |   |   |    |                                               |   |
|----|---------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|----|-----------------------------------------------|---|
| BL | <table border="1"><tr><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td></tr></table> | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | CF | <table border="1"><tr><td>0</td></tr></table> | 0 |
| 0  | 1                                                                                                                   | 1 | 1 | 0 | 1 | 0 | 1 |   |   |    |                                               |   |
| 0  |                                                                                                                     |   |   |   |   |   |   |   |   |    |                                               |   |
|    | <table border="1"><tr><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td></tr></table> | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |    |                                               |   |
| 1  | 1                                                                                                                   | 1 | 1 | 0 | 1 | 1 | 1 |   |   |    |                                               |   |

Fig. 5.8.3 : OR AL, BL

# Bit manipulation instructions

## Logicals:

### 4) XOR – Exclusive or byte or word

XOR destination,source

XOR AL,BL

Algo: destination= destination  $\setminus$  source

- This instruction logically XORs each bit in a source byte or word the corresponding bit in the destination and stores the result in the destination.
- The contents of specified source do not change.
- The source can be a register, memory location or an immediate number.
- The destination can be register or memory location.
- The source and destination both cannot be memory locations.
- The segment registers cannot be used as source or destination.

# Bit manipulation instructions

## 4) XOR – Exclusive or byte or word

- The source and destination both cannot be memory locations.
- The segment registers cannot be used as source or destination.

ple

XOR AL, BL

- This instruction XORs each bit in a in BL register.
- The result is stored in the AL register

AL = 93 H and BL = 75H

### Before Execution

|    |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|
| AL | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
|----|---|---|---|---|---|---|---|---|

XOR AL, BL

|    |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|
| BL | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |
|----|---|---|---|---|---|---|---|---|

### After Execution

The result of XORing AL  
is stored in AL

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |
|---|---|---|---|---|---|---|---|

|    |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|
| BL | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |
|----|---|---|---|---|---|---|---|---|

Fig. 5.8.4 : XOR AL, BL

# Bit manipulation instructions

## Logicals:

### 5) TEST – Test byte or word

TEST destination,source

TEST AL,75h

Algo: destination= destination ^ source

- This instruction ANDs contents of a source byte or word with contents of specified destination word.
- The source can be register , memory location,immediate data.
- The source and destination both cannot be memory locations.
- Segment registers are not allowed to be used as source or destination.
- The destination can be a register or memory location.
- Flags are affected but neither operand is changed
- It is used to set flags before conditional JUMP.

TEST AL,75h (AND immediate number 75h with AL)

PF=0,SF=0,ZF=0,CF=0,OF=0

# Bit manipulation instructions

## 5) TEST – Test byte or word

|                  |                                                                                                                                                                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"><li>• The destination can be a register or memory location.</li><li>• Flags are affected, but neither operand is <u>changed</u>.</li><li>• It is used to set flags before <u>conditional JUMP</u>.</li></ul> |
| TEST AL,<br>75 H | Let $AL = 0\ 1\ 1\ 1\ 0\ 1\ 0\ 1$<br>AND Immediate number 75H with AL.<br>$PF = 0, SF = 0, ZF = 0, CF = 0, OF = 0$                                                                                                                             |