Skip to main content

8085 Addressing Modes

Addressing modes: The different methods which are used to select or address the operands are called addressing modes or the different modes or ways that a microprocessor uses to access data are called addressing modes.

There are five addressing modes:
  • Immediate addressing mode
  • Register addressing mode
  • Direct addressing mode
  • Indirect addressing mode
  • Implied addressing mode

Immediate addressing mode: 

  • In this addressing mode, 8-bit data or 16-bit data is specified in instruction itself.
  • These instructions can be either two byte or three byte instructions.
  • The instructions containing 'I' indicates immediate addressing mode.
Example: 
MVI C, 31H
LXI H, 3210H

Register addressing mode:

  • In this addressing mode, the source and destination operands are general purpose registers (B, C, D, E, H and L).
  • These instructions are one byte instructions.
Example: 
MOV A, B
PCHL

Direct addressing mode: 

  • In this addressing mode, the 16-bit address of the operand is given within the instruction itself.
  • These instructions are three byte instructions.
Example:
LDA 5600H
STA C200H

Indirect addressing mode:

  • In this addressing mode, the memory address where the operand is located is indicated by the contents of the register pair.
  • These instructions are one byte instructions.
Example:
MOV A, M
LDAX C

Implied addressing mode:

  • In this addressing mode, no operand is required.
  • It is also known as implicit addressing mode.
  • These instructions are one byte instructions.
Example:
RAL
CMA

Comments

Popular posts from this blog

Logical Group Instructions (Part-VI) - RLC, RRC, RAL, RAR

RLC: This instruction rotates the contents of accumulator to the left by one bit. It will shift B0 to B1, B1 to B2,............B7 to B0 as well as to carry flag . Only CY flag is modified. It is a one byte instruction. Implied addressing mode is used. Before execution: After execution: Example: If A = 0101 0111 = 57H and CY = 1 RLC ; Now A = 10101110 = AEH and CY = 0. RRC: This instruction rotates the contents of accumulator to the right by one bit. It will shift B7 to B6, B6 to B5,............B0 to B7 as well as to carry flag. Only CY flag is modified. It is a one byte instruction. Implied addressing mode is used. Before execution: After execution: Example: If A = 1001 1010 = 9AH and CY = 1 RLC ; Now A = 0100 1101 = 4DH and CY = 0. RAL: This instruction rotates the contents of accumulator to the left by one bit along with the carry . It will shift B0 to B1, B1 to B2,............B7 to CY and CY to B0 . Only CY flag is modifi...

Stack Operations Instructions (Part-II) - SPHL and XTHL

SPHL: This instruction copies the contents of HL register pair to the stack pointer (SP). It means that the stack pointer will now point to the memory location whose address was given in the HL register pair. No flags are affected. It is a one byte instruction. Register addressing mode is used. Example: If HL = 2030H, then SPHL ; This instruction will copy 2030H into SP. So SP will point to the memory location 2030H. XTHL: This instruction exchanges the contents of the memory location pointed by stack pointer with the contents of the L register and the contents of the next memory location with the contents of H register. This instruction does not alter the contents of the stack pointer. No flags are affected. It is a one byte instruction. Register Indirect addressing mode is used. Example: If HL = 5601H, SP = 2000H, (2000H) = 30H and (2001H) = 20H, then XTHL ; This instruction will exchange the contents of the memory location 2000H i.e. 3...

Program to exchange the contents of two memory locations

Statement: Exchange the contents of memory locations 2000H and 2001H. Example:  Initially, (2000H) = 34H (2001H) = 20H After exchanging, (2000H) = 20H (2001H) = 34H Program 1 using direct addressing instructions: LDA 2000H               ; Get the contents of location 2000H into accumulator MOV B, A                  ; Move the contents of accumulator into register B LDA 2001H                ; Get the contents of location 2001H into accumulator STA 2000H                 ; Store the contents of accumulator into location 2000H MOV A, B                  ; Move the contents of register B into accumulator STA 2001H                 ; Store the contents of accumulator into location 2001H HLT  ...