# ADDRESSING MODE BYTE

The 8086 obviously offers an extensive selection of addressing modes. The next specifies most data memory addressing modes implemented in the object code? The 8086 byte of object code, known as the addressing mode byte. The addressing mode byte may byte is always the second byte of the instruction object code, unless a prefix instruction has been included prior to the initial object code. The addressing mode byte may be illustrated as follows:



mod=

Memory addressing mode. r/m specifies the exact addressing option.

There are no displacement bytes.

01

00

Memory addressing mode. r/m specifies the exact addressing option. There is one displacement byte. This displacement byte is viewed as a signed number in the range +127 to -128. When this number is used in the memory address calculation, the number is sign extended to 16 bits. In this case, the addressing mode bytes can be illustrated as follows:



where mod = 01 and disp is the 8-bit signed displacement value.

10

Memory addressing mode. r/m specifies the addressing option. There are two displacement bytes. The first displacement byte is the low-order eight bits of the displacement. The second displacement byte is the high-order eight bits of the displacement. When this number is used in the memory address calculation, the number is treated as an unsigned 16-bit number. In this case, the addressing mode bytes can be illustrated as follows:

| mod reg r/m | disp low | disp high |
|-------------|----------|-----------|
|             |          |           |

where mod = 10, disp low is the low-order eight bits of the displacement, and disp high is the high-order eight bits of the displacement.

register addressing mode. r/m specifies a register. Used in conjunction with the w bit to determine if an 8- or 16-bit register is selected.

reg

reg is used in conjunction with another bit, the w bit, in the selection of the register to be used in the operation. The w bit, which is part of the instruction op-code, selects whether an 8- or 16-bit operation is performed.

| reg | w = 0 | w = 1 |
|-----|-------|-------|
| 000 | AL    | AX    |
| 001 | CL    | CX    |
| 010 | DL    | DX    |
| 011 | BL    | BX    |
| 100 | AH    | SP    |
| 101 | СН    | BP    |
| 110 | DH    | SI    |
| 111 | BH    | DI    |

r/m specifies the addressing mode in conjunction with mod, as follows:

| r/m | mod - 00 | mod - 01       | mod - 10       | mod - 11 |       |
|-----|----------|----------------|----------------|----------|-------|
|     |          |                |                | w = 0    | w = 1 |
| 000 | BX + SI  | BX + SI + DISP | BX + SI + DISP | AL       | AX    |
| 001 | BX + DI  | BX + DI + DISP | BX + DI + DISP | CL       | CX    |
| 010 | BP + SI  | BP + SI + DISP | BP + SI + DISP | DL       | DX    |
| 011 | BP + DI  | BP + DI + DISP | BP + DI + DISP | BL       | вх    |
| 100 | SI       | SI + DISP      | SI + DISP      | AH       | SP    |
| 101 | DI       | DI + DISP      | DI + DISP      | СН       | BP    |
| 110 | Direct   | BP + DISP      | BP + DISP      | DH       | SI    |
|     | Address  |                |                | 011      |       |
| 111 | BX       | BX + DISP      | BX + DISP      | ВН       | DI    |

25 U. Let.

This table is self-explanatory, with the exception of Direct Address. When mod is 00 and r/m is 110, the offset address is taken directly from the two bytes that follow the addressing mode byte. This can be illustrated as follows:

mod reg r m addr-low addr-high

#### **MEMORY ADDRESSING TABLES**

Memory addressing modes and memory addressing byte information can be combined and summarized as follows:

| r/m = | mod = 00                         | mode = 01                                         | mod = 10                                          |
|-------|----------------------------------|---------------------------------------------------|---------------------------------------------------|
| 000   | Base Relative Indexed<br>BX + SI | Base Relative Indexed<br>BX + SI + DISP           | Base Relative Direct<br>Indexed<br>BX + SI + DISP |
| 001   | Base Relative Indexed<br>BX + DI | Base Relative Direct<br>Indexed<br>BX + DI + DISP | Base Relative Direct<br>Indexed<br>BX + DI + DISP |
| 010   | Base Relative Indexed            | Base Relative Direct                              | Base Relative Direct                              |
|       | Stack                            | Indexed Stack                                     | Indexed Stack                                     |
|       | BP + SI                          | BP + SI + DISP                                    | BP + SI + DISP                                    |
| 011   | Base Relative Indexed            | Base Relative Direct                              | Base Relative Direct                              |
|       | Stack                            | Indexed Stack                                     | Indexed Stack                                     |
|       | BP + DI                          | BP + DI + DISP                                    | BP + DI + DISP                                    |
| 100   | Implied                          | Direct, Indexed                                   | Direct, Indexed                                   |
|       | SI                               | SI + DISP                                         | SI + DISP                                         |
| 101   | Implied                          | Direct, Indexed                                   | Direct, Indexed                                   |
|       | DI                               | DI + DISP                                         | DI + DISP                                         |
| 110   | Direct<br>Direct Address         | Base Relative Direct<br>Stack<br>BP + DISP        | Base Relative Direct<br>Stack<br>BP + DISP        |
| 111   | Base Relative                    | Base Relative Direct                              | Base Relative Direct                              |
|       | BX                               | BX + DISP                                         | BX + DISP                                         |

## ADC mem/reg<sub>1</sub>, mem/reg<sub>2</sub>

Add Data With Carry From: • Register to Register

Register to Memory

Memory to Register

Add the contents of the register or memory location specified by mem/reg<sub>2</sub> and the Carry status to the contents of the register or memory location specified by mem/reg<sub>1</sub>. An 8- or 16-bit operation may be specified. Either mem/reg<sub>1</sub> or mem/reg<sub>2</sub> may be a memory operand, but one of the operands must be a register operand.

The encoding for this instruction is:



# ADD mem/reg, mem/reg, Add: 1. Register to Register 2. Register to Memory 3. Memory to Register

Add the contents of the register or memory location specified by mem/reg<sub>2</sub> to the contents of the register or memory location specified by mem/reg<sub>1</sub>. An 8- or 16-bit operation may be specified. Either mem/reg<sub>1</sub> or mem/reg<sub>2</sub> may be a memory operand, but one of the operands must be a register operand.

The encoding for this instruction is:



#### SHL mem/reg,count SAL mem/reg,count

Shift Register or Memory Location Left

Shift the contents of the specified register or memory location left by the specified number of bits. The number of bits to shift, represented by the variable count, is either one or the number contained in the CL register. This is a logical left shift.

The encoding for this instruction is:



## SHR mem/reg,count

## Shift Register or Memory Location Right

Shift the contents of the specified register or memory location right by the specified number of bits. The number of bits to shift, represented by the variable count, is either one or the number contained in the CL register. The bit shifted into the high-order bit is a zero. This is a logical right shift.

The encoding for this instruction is:



# Adressing Mode Byte Örnekleri

Opcode (binary) Add. ModeByte (binary)

Machine Code(Hexadecimal)

| ADC AX,BX               | i                                                                        |
|-------------------------|--------------------------------------------------------------------------|
| ADC [BX],AX             | ;                                                                        |
| SHR AX,1                | ;                                                                        |
| SHR AX,CL               | ;                                                                        |
| SHR [BX],1              | ;                                                                        |
| SHR WORD PTR[BX],1      | ;                                                                        |
| Machine Code(Hexadecima | al) Opcode (binary) Add. ModeByte (binary) Assembly Language Instruction |
| 03EAh                   | <b>→</b>                                                                 |
| 0001h                   | <b>──→</b>                                                               |
| D1E0h                   | <b>→</b>                                                                 |
| D32Ch                   | <b>──→</b>                                                               |