

28/12/2021

## 8086 Microprocessor

### ARITHMETIC INSTRUCTIONS

ADD, ADC, SUB, SBB, INC, DEC, MUL, DIV

#### ① Addition Instruction :-

ADD destination, Source.

Register, memory

memory, Register

Register, Register

Register, Immediate data.

Memory, Immediate data.

{ It supports  
8-bit  
and  
16-bit  
addition. }

Algorithm for its execution :-

$$\text{operand at destination} = \text{operand at destination} + \text{operand at source.}$$

Note : Result is not stored in accumulator as was the case in 8085 rather result is always stored in the destination operand.

For eg : ① ADD AL, BL

$$AL \leftarrow (AL) + (BL)$$

② ADD BX, 2401H

$$BX \leftarrow (BX) + 2401$$

Size of  
source  
and  
destination  
must be  
same.

③ ADD CL, [0428H]

→ memory.

How will you find MA?

CL = CL + <sup>8-bit.</sup> data at MA

$$MA = BA + EA$$

$$= DS \times 16_{10} + 0428H$$

$$= 2000 \times 16_{10} + 0428H$$

$$= 20428H.$$

(assumed that DS = 2000H)

④ ADD CX, [BX]

→ memory.

CX ← CX + <sup>16-bit</sup> data at MA

$$MA = BA + EA$$

$$= DS \times 16_{10} + BX$$

⑤ ADD [0410H], 0425H.

destination is memory ; Source is immediate data.

16-bit addition.

$$MA = BA + EA$$

$$= DS \times 16_{10} + 0410H$$

$$MA \leftarrow MA + 0425H$$



→ You cannot give destination and source both as memory.

ADD [BX], [0210H] X <sup>not</sup> allowed.

ADC destination, Source

Addition with Carry flag.

Algorithm for its operation :-

$$\text{destination operand} \leftarrow \text{destination operand} + \text{source operand} + \text{Carry flag value.}$$

All other things of ADC are similar to ADD.

② Subtraction Instruction :-

SUB destination, source.

Register, memory.

memory, Register

Register, Register

memory, immediate data

Register, immediate data.

Algorithm for its operation :-

$$\text{destination operand} \leftarrow \text{destination operand} - \text{source operand.}$$

→ Both 8-bit and 16-bit operations are supported.

→ But size of destination operand must match with the size of source operand

→ SUB [BX], [BX+SI] X not allowed.

SBB destination, source.

destination operand ←      destination operand →      Source operand →      value of carry flag.

All other things of SBB as similar to SUB.

### ③ Multiplication Instruction

MUL source

destination is by default accumulator

- \* for 8-bit multiplication the result is stored in AX register.
- \* for 16-bit multiplication the result is stored in DX and AX register.

#### 8-bit multiplication

MUL Register  $\rightarrow$  AX = AL  $\times$  Register

MUL memory  $\rightarrow$  AX = AL  $\times$  memory.  
                                        ↑                                ↑

For eg: ① MUL BL

$$AX \leftarrow (AL) \times (BL)$$

② MUL [0420H]  $\rightarrow$  MA = BA + EA

$$= DS \times 16_{10} + 0420H$$

$$AX \leftarrow (AL) \times (MA)$$

## 16-bit multiplication

MUL Register  $\rightarrow$ 

|    |    |
|----|----|
| H  | L  |
| DX | AX |

 = AX  $\times$  Register

MUL memory  $\rightarrow$ 

|    |    |
|----|----|
| H  | L  |
| DX | AX |

 = AX  $\times$  memory.

Higher-order 16-bit will be stored in DX  
Lower-order 16-bit will be stored in AX.

For eg: MUL BX

$$\boxed{DX \mid AX} \leftarrow (AX) \times (BX)$$

MUL  $\rightarrow$  it is unsigned multiplication instruction

IMUL  $\rightarrow$  it is signed multiplication instruction

MUL  $\rightarrow$  flags that are affected : overflow carry flag.

S, Z, A, P indeterminate.

IMUL  $\rightarrow$  flags that are affected : S, O, C

## ④ Increment Instruction :-

INC destination (Add 1 to destination value)

destination can be register or memory.  
(8), (16)

① INC BX

$$BX \leftarrow (BX) + 1$$

assume  $BX = 0200H$ .

INC BX

after execution;  $BX = 0201H$ .

② INC [0204H].

$$\begin{aligned} \text{memory} &\rightarrow MA = BA + EA \\ &= DS \times 16_{10} + EA. \end{aligned}$$

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

⑤ Decrement Instruction :-

DEC destination. (Decrements destination value by 1).

destination can be register or memory.

For eg:- DEC BX.

$$BX \leftarrow (BX) - 1$$

⑥ Negate Instruction :- makes operand negative.

NEG destination (performs 2's complement of destination)

destination can be register or memory.