SlideShare a Scribd company logo
ADDRESSING MODES
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
2
Group I : Addressing modes for
register and immediate data
Group IV : Relative Addressing mode
Group V : Implied Addressing mode
Group III : Addressing modes for
I/O ports
Group II : Addressing modes for
memory data
Addressing Modes
8086 Microprocessor
Every instruction of a program has to operate on a data.
The different ways in which a source operand is denoted
in an instruction are known as addressing modes.
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
3
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
The instruction will specify the name of the
register which holds the data to be operated by
the instruction.
Example:
MOV CL, DH
The content of 8-bit register DH is moved to
another 8-bit register CL
(CL)  (DH)
Group I : Addressing modes for
register and immediate data
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
4
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
In immediate addressing mode, an 8-bit or 16-bit
data is specified as part of the instruction
Example:
MOV DL, 08H
The 8-bit data (08H) given in the instruction is
moved to DL
(DL)  08H
MOV AX, 0A9FH
The 16-bit data (0A9FH) given in the instruction is
moved to AX register
(AX)  0A9FH
Group I : Addressing modes for
register and immediate data
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
6
Addressing Modes : Memory Access
8086 Microprocessor
20 Address lines  8086 can address up to
220
= 1M bytes of memory
However, the largest register is only 16 bits
Physical Address will have to be calculated
Physical Address : Actual address of a byte in
memory. i.e. the value which goes out onto the
address bus.
Memory Address represented in the form –
Seg : Offset (Eg - 89AB:F012)
Each time the processor wants to access
memory, it takes the contents of a segment
register, shifts it one hexadecimal place to the
left (same as multiplying by 1610), then add the
required offset to form the 20- bit address
89AB : F012  89AB  89AB0 (Paragraph to byte  89AB x 10 = 89AB0)
F012  0F012 (Offset is already in byte unit)
+ -------
98AC2 (The absolute address)
16 bytes of
contiguous memory
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
8
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
Here, the effective address of the memory
location at which the data operand is stored is
given in the instruction.
The effective address is just a 16-bit number
written directly in the instruction.
Example:
MOV BX, [1354H]
MOV BL, [0400H]
The square brackets around the 1354H denotes
the contents of the memory location. When
executed, this instruction will copy the contents of
the memory location into BX register.
This addressing mode is called direct because the
displacement of the operand from the segment
base is specified directly in the instruction.
Group II : Addressing modes
for memory data
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
9
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
In Register indirect addressing, name of the
register which holds the effective address (EA)
will be specified in the instruction.
Registers used to hold EA are any of the following
registers:
BX, BP, DI and SI.
Content of the DS register is used for base
address calculation.
Example:
MOV CX, [BX]
Operations:
EA = (BX)
BA = (DS) x 1610
MA = BA + EA
(CX)  (MA) or,
(CL)  (MA)
(CH)  (MA +1)
Group II : Addressing modes
for memory data
Note : Register/ memory
enclosed in brackets refer
to content of register/
memory
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
10
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
In Based Addressing, BX or BP is used to hold the
base value for effective address and a signed 8-bit
or unsigned 16-bit displacement will be specified
in the instruction.
In case of 8-bit displacement, it is sign extended
to 16-bit before adding to the base value.
When BX holds the base value of EA, 20-bit
physical address is calculated from BX and DS.
When BP holds the base value of EA, BP and SS is
used.
Example:
MOV AX, [BX + 08H]
Operations:
0008H  08H (Sign extended)
EA = (BX) + 0008H
BA = (DS) x 1610
MA = BA + EA
(AX)  (MA) or,
(AL)  (MA)
(AH)  (MA + 1)
Group II : Addressing modes
for memory data
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
11
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
SI or DI register is used to hold an index value for
memory data and a signed 8-bit or unsigned 16-
bit displacement will be specified in the
instruction.
Displacement is added to the index value in SI or
DI register to obtain the EA.
In case of 8-bit displacement, it is sign extended
to 16-bit before adding to the base value.
Example:
MOV CX, [SI + 0A2H]
Operations:
FFA2H  A2H (Sign extended)
EA = (SI) + FFA2H
BA = (DS) x 1610
MA = BA + EA
(CX)  (MA) or,
(CL)  (MA)
(CH)  (MA + 1)
Group II : Addressing modes
for memory data
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
12
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
In Based Index Addressing, the effective address
is computed from the sum of a base register (BX
or BP), an index register (SI or DI) and a
displacement.
Example:
MOV DX, [BX + SI + 0AH]
Operations:
000AH  0AH (Sign extended)
EA = (BX) + (SI) + 000AH
BA = (DS) x 1610
MA = BA + EA
(DX)  (MA) or,
(DL)  (MA)
(DH)  (MA + 1)
Group II : Addressing modes
for memory data
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
13
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
Employed in string operations to operate on string
data.
The effective address (EA) of source data is stored
in SI register and the EA of destination is stored
in DI register.
Segment register for calculating base address of
source data is DS and that of the destination data
is ES
Example: MOVS BYTE
Operations:
Calculation of source memory location:
EA = (SI) BA = (DS) x 1610 MA = BA + EA
Calculation of destination memory location:
EAE = (DI) BAE = (ES) x 1610 MAE = BAE + EAE
(MAE)  (MA)
If DF = 1, then (SI)  (SI) – 1 and (DI) = (DI) - 1
If DF = 0, then (SI)  (SI) +1 and (DI) = (DI) + 1
Group II : Addressing modes
for memory data
Note : Effective address of
the Extra segment register
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
14
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
These addressing modes are used to access data
from standard I/O mapped devices or ports.
In direct port addressing mode, an 8-bit port
address is directly specified in the instruction.
Example: IN AL, [09H]
Operations: PORTaddr = 09H
(AL)  (PORT)
Content of port with address 09H is
moved to AL register
In indirect port addressing mode, the instruction
will specify the name of the register which holds
the port address. In 8086, the 16-bit port address
is stored in the DX register.
Example: OUT [DX], AX
Operations: PORTaddr = (DX)
(PORT)  (AX)
Content of AX is moved to port
whose address is specified by DX
register.
Group III : Addressing
modes for I/O ports
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
15
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
In this addressing mode, the effective address of
a program instruction is specified relative to
Instruction Pointer (IP) by an 8-bit signed
displacement.
Example: JZ 0AH
Operations:
000AH  0AH (sign extend)
If ZF = 1, then
EA = (IP) + 000AH
BA = (CS) x 1610
MA = BA + EA
If ZF = 1, then the program control jumps to
new address calculated above.
If ZF = 0, then next instruction of the
program is executed.
Group IV : Relative
Addressing mode
UNIT - 2 Addressing Modes M.Brin
dha AP/EIE
16
Addressing Modes
8086 Microprocessor
1. Register Addressing
2. Immediate Addressing
3. Direct Addressing
4. Register Indirect Addressing
5. Based Addressing
6. Indexed Addressing
7. Based Index Addressing
8. String Addressing
9. Direct I/O port Addressing
10. Indirect I/O port Addressing
11. Relative Addressing
12. Implied Addressing
Instructions using this mode have no operands.
The instruction itself will specify the data to be
operated by the instruction.
Example: CLC
This clears the carry flag to zero.
Group IV : Implied
Addressing mode

More Related Content

PPTX
02 Addressing Modes.pptx
PPTX
4-ADDRESSING_MODES_E logic circuits.pptx
PPTX
Lecture 28 , 29 & 30(instruction set & addressing mode of 8086.pptx
PPTX
UNIT-I MICROPROCESSOR PROGRAMMING AND STACK.pptx
PPTX
Chapter 4 addressing mode in microprocessor.pptx
PPTX
Mastering Assembly Language: Programming with 8086
DOCX
Notes 8086 instruction format
PPTX
Chapter 1 archietecture of 8086
02 Addressing Modes.pptx
4-ADDRESSING_MODES_E logic circuits.pptx
Lecture 28 , 29 & 30(instruction set & addressing mode of 8086.pptx
UNIT-I MICROPROCESSOR PROGRAMMING AND STACK.pptx
Chapter 4 addressing mode in microprocessor.pptx
Mastering Assembly Language: Programming with 8086
Notes 8086 instruction format
Chapter 1 archietecture of 8086

Similar to ADDRESSING MODES in 8086 MICROPROCESSOR.ppt (20)

PPTX
8086 microprocessor pptx JNTUH ece 3rd year
PPTX
address5ng modes.pptx IS A GOOD MATERIAL
PDF
Microprocessor module 4.pdfbabssbabanjxnsb
PDF
8086 lectures
PDF
8086 microprocessor
PDF
8086 lectures
PDF
8086 Register organization and Architecture details
PPT
Unit 1
PPTX
introduction to Architecture of 8086 and it's application
PPTX
8086 Micro-processor and MDA 8086 Trainer Kit
PPTX
Presentation on 8086 microprocessor
PPTX
Microprocessor Architecture.pptx
PPTX
8086 addressing modes
PDF
8086addressingmodes-200319141110.pdf
PDF
Module 2 instruction set
PPTX
addressing-modes-of-8086-mr-binu-joy-2 (2).pptx
PPTX
Introduction of 8086 micro processor .
PPTX
Chapter 2 and 3 8086,8088 architecture and HW specification.pptx
PDF
8086 Architecture, Pin diagram, Addressing modes (3).pdf
PPT
intel 8086 introduction
8086 microprocessor pptx JNTUH ece 3rd year
address5ng modes.pptx IS A GOOD MATERIAL
Microprocessor module 4.pdfbabssbabanjxnsb
8086 lectures
8086 microprocessor
8086 lectures
8086 Register organization and Architecture details
Unit 1
introduction to Architecture of 8086 and it's application
8086 Micro-processor and MDA 8086 Trainer Kit
Presentation on 8086 microprocessor
Microprocessor Architecture.pptx
8086 addressing modes
8086addressingmodes-200319141110.pdf
Module 2 instruction set
addressing-modes-of-8086-mr-binu-joy-2 (2).pptx
Introduction of 8086 micro processor .
Chapter 2 and 3 8086,8088 architecture and HW specification.pptx
8086 Architecture, Pin diagram, Addressing modes (3).pdf
intel 8086 introduction
Ad

Recently uploaded (20)

PPTX
bas. eng. economics group 4 presentation 1.pptx
PPTX
Recipes for Real Time Voice AI WebRTC, SLMs and Open Source Software.pptx
PDF
Mitigating Risks through Effective Management for Enhancing Organizational Pe...
PDF
PPT on Performance Review to get promotions
PDF
The CXO Playbook 2025 – Future-Ready Strategies for C-Suite Leaders Cerebrai...
DOCX
ASol_English-Language-Literature-Set-1-27-02-2023-converted.docx
PPTX
FINAL REVIEW FOR COPD DIANOSIS FOR PULMONARY DISEASE.pptx
PPTX
Welding lecture in detail for understanding
DOCX
573137875-Attendance-Management-System-original
PPTX
additive manufacturing of ss316l using mig welding
PPTX
UNIT 4 Total Quality Management .pptx
PDF
Operating System & Kernel Study Guide-1 - converted.pdf
PDF
R24 SURVEYING LAB MANUAL for civil enggi
PPTX
UNIT-1 - COAL BASED THERMAL POWER PLANTS
PDF
BMEC211 - INTRODUCTION TO MECHATRONICS-1.pdf
PPT
Project quality management in manufacturing
PPT
Mechanical Engineering MATERIALS Selection
PDF
July 2025 - Top 10 Read Articles in International Journal of Software Enginee...
PPTX
Construction Project Organization Group 2.pptx
PPTX
CARTOGRAPHY AND GEOINFORMATION VISUALIZATION chapter1 NPTE (2).pptx
bas. eng. economics group 4 presentation 1.pptx
Recipes for Real Time Voice AI WebRTC, SLMs and Open Source Software.pptx
Mitigating Risks through Effective Management for Enhancing Organizational Pe...
PPT on Performance Review to get promotions
The CXO Playbook 2025 – Future-Ready Strategies for C-Suite Leaders Cerebrai...
ASol_English-Language-Literature-Set-1-27-02-2023-converted.docx
FINAL REVIEW FOR COPD DIANOSIS FOR PULMONARY DISEASE.pptx
Welding lecture in detail for understanding
573137875-Attendance-Management-System-original
additive manufacturing of ss316l using mig welding
UNIT 4 Total Quality Management .pptx
Operating System & Kernel Study Guide-1 - converted.pdf
R24 SURVEYING LAB MANUAL for civil enggi
UNIT-1 - COAL BASED THERMAL POWER PLANTS
BMEC211 - INTRODUCTION TO MECHATRONICS-1.pdf
Project quality management in manufacturing
Mechanical Engineering MATERIALS Selection
July 2025 - Top 10 Read Articles in International Journal of Software Enginee...
Construction Project Organization Group 2.pptx
CARTOGRAPHY AND GEOINFORMATION VISUALIZATION chapter1 NPTE (2).pptx
Ad

ADDRESSING MODES in 8086 MICROPROCESSOR.ppt

  • 2. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 2 Group I : Addressing modes for register and immediate data Group IV : Relative Addressing mode Group V : Implied Addressing mode Group III : Addressing modes for I/O ports Group II : Addressing modes for memory data Addressing Modes 8086 Microprocessor Every instruction of a program has to operate on a data. The different ways in which a source operand is denoted in an instruction are known as addressing modes. 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing
  • 3. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 3 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing The instruction will specify the name of the register which holds the data to be operated by the instruction. Example: MOV CL, DH The content of 8-bit register DH is moved to another 8-bit register CL (CL)  (DH) Group I : Addressing modes for register and immediate data
  • 4. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 4 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing In immediate addressing mode, an 8-bit or 16-bit data is specified as part of the instruction Example: MOV DL, 08H The 8-bit data (08H) given in the instruction is moved to DL (DL)  08H MOV AX, 0A9FH The 16-bit data (0A9FH) given in the instruction is moved to AX register (AX)  0A9FH Group I : Addressing modes for register and immediate data
  • 5. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 6 Addressing Modes : Memory Access 8086 Microprocessor 20 Address lines  8086 can address up to 220 = 1M bytes of memory However, the largest register is only 16 bits Physical Address will have to be calculated Physical Address : Actual address of a byte in memory. i.e. the value which goes out onto the address bus. Memory Address represented in the form – Seg : Offset (Eg - 89AB:F012) Each time the processor wants to access memory, it takes the contents of a segment register, shifts it one hexadecimal place to the left (same as multiplying by 1610), then add the required offset to form the 20- bit address 89AB : F012  89AB  89AB0 (Paragraph to byte  89AB x 10 = 89AB0) F012  0F012 (Offset is already in byte unit) + ------- 98AC2 (The absolute address) 16 bytes of contiguous memory
  • 6. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 8 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing Here, the effective address of the memory location at which the data operand is stored is given in the instruction. The effective address is just a 16-bit number written directly in the instruction. Example: MOV BX, [1354H] MOV BL, [0400H] The square brackets around the 1354H denotes the contents of the memory location. When executed, this instruction will copy the contents of the memory location into BX register. This addressing mode is called direct because the displacement of the operand from the segment base is specified directly in the instruction. Group II : Addressing modes for memory data
  • 7. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 9 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing In Register indirect addressing, name of the register which holds the effective address (EA) will be specified in the instruction. Registers used to hold EA are any of the following registers: BX, BP, DI and SI. Content of the DS register is used for base address calculation. Example: MOV CX, [BX] Operations: EA = (BX) BA = (DS) x 1610 MA = BA + EA (CX)  (MA) or, (CL)  (MA) (CH)  (MA +1) Group II : Addressing modes for memory data Note : Register/ memory enclosed in brackets refer to content of register/ memory
  • 8. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 10 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing In Based Addressing, BX or BP is used to hold the base value for effective address and a signed 8-bit or unsigned 16-bit displacement will be specified in the instruction. In case of 8-bit displacement, it is sign extended to 16-bit before adding to the base value. When BX holds the base value of EA, 20-bit physical address is calculated from BX and DS. When BP holds the base value of EA, BP and SS is used. Example: MOV AX, [BX + 08H] Operations: 0008H  08H (Sign extended) EA = (BX) + 0008H BA = (DS) x 1610 MA = BA + EA (AX)  (MA) or, (AL)  (MA) (AH)  (MA + 1) Group II : Addressing modes for memory data
  • 9. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 11 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing SI or DI register is used to hold an index value for memory data and a signed 8-bit or unsigned 16- bit displacement will be specified in the instruction. Displacement is added to the index value in SI or DI register to obtain the EA. In case of 8-bit displacement, it is sign extended to 16-bit before adding to the base value. Example: MOV CX, [SI + 0A2H] Operations: FFA2H  A2H (Sign extended) EA = (SI) + FFA2H BA = (DS) x 1610 MA = BA + EA (CX)  (MA) or, (CL)  (MA) (CH)  (MA + 1) Group II : Addressing modes for memory data
  • 10. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 12 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing In Based Index Addressing, the effective address is computed from the sum of a base register (BX or BP), an index register (SI or DI) and a displacement. Example: MOV DX, [BX + SI + 0AH] Operations: 000AH  0AH (Sign extended) EA = (BX) + (SI) + 000AH BA = (DS) x 1610 MA = BA + EA (DX)  (MA) or, (DL)  (MA) (DH)  (MA + 1) Group II : Addressing modes for memory data
  • 11. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 13 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing Employed in string operations to operate on string data. The effective address (EA) of source data is stored in SI register and the EA of destination is stored in DI register. Segment register for calculating base address of source data is DS and that of the destination data is ES Example: MOVS BYTE Operations: Calculation of source memory location: EA = (SI) BA = (DS) x 1610 MA = BA + EA Calculation of destination memory location: EAE = (DI) BAE = (ES) x 1610 MAE = BAE + EAE (MAE)  (MA) If DF = 1, then (SI)  (SI) – 1 and (DI) = (DI) - 1 If DF = 0, then (SI)  (SI) +1 and (DI) = (DI) + 1 Group II : Addressing modes for memory data Note : Effective address of the Extra segment register
  • 12. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 14 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing These addressing modes are used to access data from standard I/O mapped devices or ports. In direct port addressing mode, an 8-bit port address is directly specified in the instruction. Example: IN AL, [09H] Operations: PORTaddr = 09H (AL)  (PORT) Content of port with address 09H is moved to AL register In indirect port addressing mode, the instruction will specify the name of the register which holds the port address. In 8086, the 16-bit port address is stored in the DX register. Example: OUT [DX], AX Operations: PORTaddr = (DX) (PORT)  (AX) Content of AX is moved to port whose address is specified by DX register. Group III : Addressing modes for I/O ports
  • 13. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 15 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing In this addressing mode, the effective address of a program instruction is specified relative to Instruction Pointer (IP) by an 8-bit signed displacement. Example: JZ 0AH Operations: 000AH  0AH (sign extend) If ZF = 1, then EA = (IP) + 000AH BA = (CS) x 1610 MA = BA + EA If ZF = 1, then the program control jumps to new address calculated above. If ZF = 0, then next instruction of the program is executed. Group IV : Relative Addressing mode
  • 14. UNIT - 2 Addressing Modes M.Brin dha AP/EIE 16 Addressing Modes 8086 Microprocessor 1. Register Addressing 2. Immediate Addressing 3. Direct Addressing 4. Register Indirect Addressing 5. Based Addressing 6. Indexed Addressing 7. Based Index Addressing 8. String Addressing 9. Direct I/O port Addressing 10. Indirect I/O port Addressing 11. Relative Addressing 12. Implied Addressing Instructions using this mode have no operands. The instruction itself will specify the data to be operated by the instruction. Example: CLC This clears the carry flag to zero. Group IV : Implied Addressing mode