Hardware manual

The 8051 Instruction Set
1-12 Atmel 8051 Microcontrollers Hardware Manual
4316A–8051–01/04
The SJMP instruction encodes the destination address as relative offset, as described
above. The instruction is 2 bytes long, consisting of the opcode and the relative offset
byte. The jump distance is limited to range of -128 to + 127 bytes relative to the instruc-
tion following the SJMP.
The LJMP instruction encodes the destination address as a 16-bit constant. The instruc-
tion is 3 bytes long, consisting of the opcode and two address bytes. The destination
address can be anywhere in the 64K Program Memory space.
The AJMP instruction encodes the destination address as an 11-bit constant. The
instruction is 2 bytes long, consisting of the opcode, which itself contains 3 of the 11
address bits, followed by another byte containing the low 8 bits of the destination
address. When the instruction is executed, these 11 bits are simply substituted for the
low 11 bits in the PC. The high 5 bits stay the same. Hence the destination has to be
within the same 2K block as the instruction following the AJMP.
In all cases the programmer specifies the destination address to the assembler in the
same way: as a label or as a 16-bit constant. The assembler will put the destination
address into the correct format for the given instruction. If the format required by the
instruction will not support the distance to the specified destination address, a “Destina-
tion out of range” message is written, into the list file.
The JMP @ A + DPTR instruction supports case jumps. The destination address is
computed at execution time as the sum of the 16-bit DPTR register and the Accumula-
tor. Typically, DPTR is set up with the address of a jump table, and the Accumulator is
given an index to the table. In a 5-way branch, for example, an integer 0 through 4 is
loaded into the Accumulator.
The code to be executed might be as follows:
MOV DPTR, # JUMP_TABLE
MOV A, INDEX_NUMBER
RL A
JMP @ A + DPTR
The RLA instruction converts the index number (0 through 4) to an even number on the
range 0 through 8, because each entry in the jump table is 2 bytes long:
JUMP_TABLE:
AJMP CASE_0
AJMP CASE_1
AJMP CASE_2
AJMP CASE_3
AJMP CASE_4
Table 1-10 shows a single “CALL addr” instruction, but there are two of them -LCALL
and ACALL -which differ in the format in which the subroutine address is given to the
CPU. CALL is a generic mnemonic which can be used if the programmer does not care
which way the address is encoded.
The LCALL instruction uses the 16-bit address format, and the subroutine can be any-
where in the 64K Program Memory space. The ACALL instruction uses the 11-bit format,
and the subroutine must be in the same 2K block as the instruction following the ACALL.
In any case the programmer specifies the subroutine address to the assembler in the
same way: as a label or as a 16-bit constant. The assembler will put the address into the
correct format for the given instructions.
Subroutines should end a RET instruction, which returns execution following the CALL.
RETI is used to return from an interrupt service routine. The only difference between RET
and RETI is that RETI tells the interrupt control system that the interrupt in progress is