AT89C51RD2-RDTIM Atmel, AT89C51RD2-RDTIM Datasheet - Page 22

no-image

AT89C51RD2-RDTIM

Manufacturer Part Number
AT89C51RD2-RDTIM
Description
MCU 8-Bit AT89 80C51 CISC 64KB Flash 3.3V/5V 64-Pin VQFP Tray
Manufacturer
Atmel
Datasheet
22
AT89C51RD2/ED2
Reset Value = XXXX XX0X0b
Not bit addressable
Note:
ASSEMBLY LANGUAGE
INC is a short (2 bytes) and fast (12 clocks) way to manipulate the DPS bit in the AUXR1 SFR.
However, note that the INC instruction does not directly force the DPS bit to a particular state,
but simply toggles it. In simple routines, such as the block move example, only the fact that DPS
is toggled in the proper sequence matters, not its actual value. In other words, the block move
routine works the same whether DPS is '0' or '1' on entry. Observe that without the last instruc-
tion (INC AUXR1), the routine will exit with DPS in the opposite state.
; Block move using dual data pointers
; Modifies DPTR0, DPTR1, A and PSW
; note:
; unless an extra INC AUXR1 is added
;
00A2
;
0000 909000MOV DPTR,#SOURCE ; address of SOURCE
0003 05A2 INC AUXR1 ; switch data pointers
0005 90A000 MOV DPTR,#DEST ; address of DEST
0008 LOOP:
0008 05A2 INC AUXR1 ; switch data pointers
000A E0 MOVX A,@DPTR ; get a byte from SOURCE
000B A3 INC DPTR ; increment SOURCE address
000C 05A2 INC AUXR1 ; switch data pointers
000E F0 MOVX @DPTR,A ; write the byte to DEST
000F A3 INC DPTR ; increment DEST address
0010 70F6JNZ LOOP ; check for 0 terminator
0012 05A2 INC AUXR1 ; (optional) restore DPS
1. Bit 2 stuck at 0; this allows to use INC AUXR1 to toggle DPS without changing GF3.
AUXR1 EQU 0A2H
DPS exits opposite of entry state
4235J–8051–01/08

Related parts for AT89C51RD2-RDTIM