Skip to main content

Instruction Classification

8085 microprocessor instructions can be categorized into five different groups:
  • Data transfer operations group
  • Arithmetic operations group
  • Logical operations group
  • Branch operations group
  • Stack, Input/Output and Machine control operations group

Data transfer operations group: 

  • Data transfer instructions transfer data or copy data from source to destination. 
  • Source can be any data or contents of memory location or contents of any register. 
  • Destination can be register or memory location. 
  • These instructions do not affect the flag register.

Arithmetic operations group:
Arithmetic instructions perform:
  • addition 
  • subtraction 
  • increment
  • decrement operations.

Logical operations group:
The logical instructions perform:
  • logical operations like AND, OR, EX-OR
  • rotate operation
  • compare operation
  • complement operation

Branch operations group:
  • These instructions allow 8085 processor to change the sequence of the program under certain test conditions or unconditionally.
  • These instructions include branch instructions, subroutine call and return instructions, and restart instructions.

Stack, Input/Output and Machine control operations group:
  • These instructions control the stack operations, input/output operations and machine operations.
  • Stack instructions allow the transfer of data from stack memory to register pair and from register pair to stack memory.
  • Input/output instructions allow the transfer of 8-bit data to input/output port.
  • Machine instructions control the machine operations such as interrupt, halt or do nothing.

Important notations used in instructions:

M                         Memory location pointed by HL register pair
r                           8-bit register
Rp                       16-bit register pair
Rs                        Source register 
Rd                       Destination register
addr                    16-bit address

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...

Program to pack the two unpacked BCD numbers

Statement: Pack the two unpacked BCD numbers stored in memory locations 2000H and 2001H and store the result in memory location 2002H. The least significant digit is stored at 2000H. Example: (2000H) = 04H (2001H) = 09H Result = (2002H) = 94H Program: LDA 2001H                        ; Obtain the most significant BCD digit RLC                                    ; Rotate left  RLC                                    ; Rotate left  RLC                                    ; Rotate left  RLC                                    ; Rotate left...

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  ...