beautypg.com

Byte instructions, Byte instructions -6 – Maxim Integrated Ultra-High-Speed Flash Microcontroller User Manual

Page 53

background image

5-6

Ultra-High-Speed Flash

Microcontroller User’s Guide

2-Byte Instructions

All 2-byte instructions require a minimum of two cycles, since fetching each byte requires a separate memory access. The first byte is

the instruction op code that is decoded by the CPU. The second byte is normally an operand, or it can specify the location of the

operand. For example, “ADD A, direct” is a 2-byte, two-cycle instruction where the second byte specifies the direct address location

of the operand. Due to internal access restrictions, certain direct addressing instructions require one extra memory cycle when oper-

ating on the PSW, SP, DPS, IE, EIE, IP0, IP1, EIP0, or EIP1 register. Following are examples of these and other 2-byte instructions:

OPCODE

OPERAND/LOCATION

NO. OF CYCLES

ADD A, direct

25h

2

ADD A, #data

24h

2

SJMP rel

80h

3

ANL direct, A

52h

2 or 3

ORL direct, A

42h

2 or 3

DJNZ Rn, direct

D8h-DFh

4

3-Byte Instructions

Three-byte instructions require a minimum of three cycles since each byte fetch requires one memory cycle. The first byte, the opcode,

instructs the CPU on how to handle the next two bytes. Most 3-byte instructions involve comparison or branching, but not all. Just like

the 2-byte instructions, certain 3-byte instructions may require 1 extra memory cycle when operating on the PSW, SP, DPS, IE, EIE, IP0,

IP1, EIP0, or EIP1 register. Following are examples of 3-byte instructions.

OPCODE

OPERAND(s)/LOCATION(s)

NO. Of CYCLES

LJMP addr16

02h

3

MOV dptr, #data16

90h

3

MOV direct, direct 85h

3 or 4

JBC bit, rel

10h

4 or 5

DJNZ direct, rel

D5h

5

Maxim Integrated