

Ministry of Higher Education & Scientific Research

University of Technology Laser& optoelectronic Engineering Department



## 8085 instruction set

Logical instruction Control instruction Branch instruction

## 8085 instruction set Logical instruction

| Opcode<br>CMP<br>Compare<br>register or<br>memory<br>with<br>accumulator | <u>Operand</u><br>R<br>M | <b>Description</b><br>The contents of the operand (register or<br>memory) are compared with the contents of the<br>accumulator. Both contents are preserved . The<br>result of the comparison is<br>shown by setting the flags of the PSW as<br>follows:<br>if (A) < (reg/mem): carry flag is set<br>if (A) = (reg/mem): zero flag is set<br>if (A) > (reg/mem): carry and zero flags are reset<br>Example: CMP B or CMP M |
|--------------------------------------------------------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CPI</b><br>Compare<br>immediate<br>with<br>accumulator                | 8-bit data               | The second byte (8-bit data) is compared with<br>the contents of the accumulator. The values<br>being compared remain unchanged. The result<br>of the comparison is shown by setting<br>the flags of the PSW as follows:<br>if (A) < data: carry flag is set<br>if (A) = data: zero flag is set<br>if (A) > data: carry and zero flags are reset<br>Example: CPI 89H                                                       |
| ANA<br>Logical<br>AND<br>register or<br>memory<br>with<br>accumulator    | R<br>M                   | The contents of the accumulator are logically<br>ANDed with the contents of the operand (register<br>or memory), and the result is placed in the<br>accumulator. If the operand is a memory<br>location, its address is specified by the contents<br>of HL registers. S, Z, P are modified to reflect the<br>result of the operation. CY is reset. AC is set.<br>Example: ANA B or ANA M                                   |
| ANI<br>Logical<br>AND<br>immediate<br>with<br>accumulator                | 8-bit data               | The contents of the accumulator are logically<br>ANDed with the 8-bit data (operand) and the<br>result is placed in the accumulator. S, Z, P are<br>modified to reflect the result of the operation. CY<br>is reset. AC is set.<br>Example: ANI 86H                                                                                                                                                                        |

| XRA<br>Exclusive<br>OR register<br>or memory<br>with<br>accumulator | R<br>M     | The contents of the accumulator are Exclusive<br>ORed with the contents of the operand (register<br>or memory), and the result is placed in the<br>accumulator. If the operand is a memory<br>location, its address is specified by the contents<br>of HL registers. S, Z, P are modified to reflect the<br>result of the operation. CY and AC are reset.<br>Example: XRA B or XRA M |
|---------------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XRI<br>Exclusive<br>OR<br>immediate<br>with<br>accumulator          | 8-bit data | The contents of the accumulator are Exclusive<br>ORed with the 8-bit data (operand) and the<br>result is placed in the accumulator. S, Z, P are<br>modified to reflect the result of the operation. CY<br>and AC are reset.<br>Example: XRI 86H                                                                                                                                      |
| ORA<br>Logical OR<br>register or<br>memory with<br>accumulator      | R<br>M     | The contents of the accumulator are logically<br>ORed with the contents of the operand (register<br>or memory), and the result is placed in the<br>accumulator. If the operand is a memory<br>location, its address is specified by the contents<br>of HL registers. S, Z, P are modified to reflect<br>the result of the operation. CY and AC are reset.<br>Example: ORA B or ORA M |
| ORI<br>Logical OR<br>immediate<br>with<br>accumulator               | 8-bit data | The contents of the accumulator are logically<br>ORed with the 8-bit data (operand) and the<br>result is placed in the accumulator. S, Z, P are<br>modified to reflect the result of theoperation. CY<br>and AC are reset.<br>Example: ORI 86H                                                                                                                                       |
| RLC<br>Rotate<br>accumulator<br>left                                | none       | Each binary bit of the accumulator is rotated left<br>by one position. Bit D7 is placed in the position<br>of D0 as well as in the Carry flag. CY is modified<br>according to bit D7. S, Z, P,AC are not affected.<br>Example: RLC                                                                                                                                                   |
| RRC<br>Rotate<br>accumulator<br>right                               | none       | Each binary bit of the accumulator is rotated<br>right by one position. Bit D0 is placed in the<br>position of D7 as well as in the Carry flag. CY is<br>modified according to bit D0. S, Z, P,AC are not<br>affected.<br>Example: RRC                                                                                                                                               |
| RAL                                                                 | none       | Each binary bit of the accumulator is rotated left                                                                                                                                                                                                                                                                                                                                   |

| Rotate<br>accumulator<br>left through<br>carry         |      | by one position through the Carry flag. Bit D7 is<br>placed in the Carry flag, and the Carry flag is<br>placed in the least significant position D0. CY is<br>modified according to bit D7. S, Z, P, AC are not<br>affected.<br>Example: RAL                                                      |
|--------------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RAR<br>Rotate<br>accumulator<br>right through<br>carry | none | Each binary bit of the accumulator is rotated<br>right by one position through the Carry flag. Bit<br>D0 is placed in the Carry flag, and the Carry flag<br>is placed in the most significant position D7. CY<br>is modified according to bit D0. S, Z, P, ACare<br>not affected.<br>Example: RAR |
| <b>CMA</b><br>Complement<br>accumulator                | none | The contents of the accumulator are complemented. No flags are affected. Example: CMA                                                                                                                                                                                                             |
| <b>CMC</b><br>Complement<br>carry                      | none | The Carry flag is complemented. No other flags are affected.<br>Example: CMC                                                                                                                                                                                                                      |
| STC<br>Set Carry                                       | none | The Carry flag is set to 1. No other flags are affected.<br>Example: STC                                                                                                                                                                                                                          |

## **Control instruction**

| <u>Opcode</u><br>NOP<br>No<br>operation | <u>Operand</u><br>none | <b>Description</b><br>No operation is performed. The instruction is fetched<br>and decoded. However no operation is executed.<br>Example: NOP                             |
|-----------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HLT<br>Halt and<br>enter<br>wait state  | none                   | The CPU finishes executing the current instruction<br>and halts any further execution. An interrupt or reset is<br>necessary to exit from the halt state.<br>Example: HLT |
| <b>DI</b><br>Disable<br>interrupts      | none                   | The interrupt enable flip-flop is reset and all the interrupts except the TRAP are disabled. No flags are affected.Example: D                                             |
| <b>El</b><br>Enable                     | none                   | The interrupt enable flip-flop is set and all interrupts are enabled. No flags are affected. After a system                                                               |



- □ SOD—Serial Output Data: Bit  $D_7$  of the accumulator is latched into the SOD output line and made available to a serial peripheral if bit  $D_6 = 1$ .
- □ SDE Serial Data Enable: If this bit = 1, it enables the serial output. To implement serial output, this bit needs to be enabled.
- □ XXX Don't Care
- R7.5—Reset RST 7.5: If this bit = 1, RST 7.5 flip-flop is reset. This is an additional control to reset RST 7.5.
- $\square$  MSE Mask Set Enable: If this bit is high, it enables the functions of bits D<sub>2</sub>, D<sub>1</sub>, D<sub>0</sub>. This is a master control over all the interrupt masking bits. If this bit is low, bits D<sub>2</sub>, D<sub>1</sub>, and D<sub>0</sub> do not have any effect on the masks.
- $\square$  M7.5  $D_2 = 0$ , RST 7.5 is enabled.
  - = 1, RST 7.5 is masked or disabled.
- $\square$  M6.5—D<sub>1</sub> = 0, RST 6.5 is enabled.
  - = 1, RST 6.5 is masked or disabled.
- $\square$  M5.5—D<sub>0</sub> = 0, RST 5.5 is enabled.
  - = 1, RST 5.5 is masked or disabled.

## **BRANCHING INSTRUCTIONS**

| <u>Opcode</u><br>JMP<br>Jump<br>unconditionally | Operand<br>16-bit<br>address | <b>Description</b><br>The program sequence is transferred to the<br>memory locationspecified by the 16-bit address<br>given in the operand.<br>Example: JMP 2034H or JMP XYZ                                       |
|-------------------------------------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Jump<br>conditionally                           | 16-bit<br>address            | The program sequence is transferred to the<br>memory location specified by the 16-bit address<br>given in the operand based on the specified<br>flag of the PSW as described below.<br>Example: JZ 2034H or JZ XYZ |

| Opcode<br><b>JC</b> | Description<br>Jump on Carry | Flag Status<br>CY = 1 |
|---------------------|------------------------------|-----------------------|
| JNC                 | Jump on no Carry             | CY = 0                |
| JP                  | Jump on positive             | S = 0                 |
| JM                  | Jump on minus                | S = 1                 |
| JZ                  | Jump on zero                 | Z = 1                 |
| JNZ                 | Jump on no zero              | Z = 0                 |
| JPE                 | Jump on parity even          | P = 1                 |
| JPO                 | Jump on parity odd           | P = 0                 |

| CALL 16-bit<br>Unconditional address<br>subroutine<br>call                                                                                                                        | The program sequence is transferred to the<br>memory location specified by the 16-bit address<br>given in the operand. Before the transfer, the<br>address of the next instruction after CALL<br>(the contents of the program counter) is pushed<br>onto the stack.<br>Example: CALL 2034H or CALL XYZ                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Call 16-bit<br>conditionally address                                                                                                                                              | The program sequence is transferred to the<br>memory location specified by the 16-bit address<br>given in the operand based on the specified flag<br>of the PSW as described below. Before the<br>transfer, the address of the next instruction after<br>the call (the contents of the program counter) is<br>pushed onto the stack.<br>Example: CZ 2034H or CZ XYZ |
| OpcodeDescriptionCCCall on CarryCNCCall on no CarryCPCall on positiveCMCall on positiveCZCall on minusCZCall on zeroCNZCall on no zeroCPECall on parity everCPOCall on parity odd | Flag Status<br>CY = 1<br>CY = 0<br>S = 0<br>S = 1<br>Z = 1<br>Z = 0<br>P = 1<br>P = 0                                                                                                                                                                                                                                                                               |
| RET none<br>Return from<br>subroutine<br>unconditionally                                                                                                                          | The program sequence is transferred from the subroutine to the calling program. The two bytes from the top of the stack are copied into the program counter, and program execution begins at the new address.<br>Example: RET                                                                                                                                       |
| Return from none                                                                                                                                                                  | The program sequence is transferred from the                                                                                                                                                                                                                                                                                                                        |

Return from none The program sequence is transferred from the subroutine conditionally The two bytes from the top of the stack are copied into the program counter, and program execution begins at the new address. Example: RZ

| Opcode | Description           | Flag Status |
|--------|-----------------------|-------------|
| RC     | Return on Carry       | CY = 1      |
| RNC    | Return on no Carry    | CY = 0      |
| RP     | Return on positive    | S = 0       |
| RM     | Return on minus       | S = 1       |
| RZ     | Return on zero        | Z = 1       |
| RNZ    | Return on no zero     | Z = 0       |
| RPE    | Return on parity even | P = 1       |
| RPO    | Return on parity odd  | P = 0       |

PCHLnoneThe contents of registers H and L are copiedLoad programinto the program counter. The contents of H arecounter withplaced as the high-order byte and the contentsHL contentsof L as the low-order byte.Example: PCHL

RST 0-7 The RST instruction is equivalent to a 1-byte Restart call instruction to one of eight memory locations depending upon the number. The instructions are generally used in conjunction with interrupts and inserted using external hardware. However these can be used as software instructions in a program to transfer program execution to one of the eight locations. The addresses are: Instruction Restart Address RST 0 0000H RST 1 0008H RST 2 0010H RST 3 0018H RST 4 0020H RST 5 0028H RST 6 0030H RST 7 0038H The 8085 has four additional interrupts and these interrupts generate RST instructions internally and thus do not require any external hardware. These instructions and their Restart addresses are: Interrupt Restart Address **TRAP 0024H** RST 5.5 002CH RST 6.5 0034H RST 7.5 003CH