ACKNOWLEDGMENT Thanks to John Hartman for his contribution of the AS8051 cross assembler. John L. Hartman jhartman@compuserve.com
8051 REGISTER SET The following is a list of the 8051 registers used by AS8051: a,b - 8-bit accumulators r0,r1,r2,r3 - 8-bit registers r4,r5,r6,r7 dptr - data pointer sp - stack pointer pc - program counter psw - status word c - carry (bit in status word) 8051 INSTRUCTION SET The following tables list all 8051 mnemonics recognized by the AS8051 assembler. The following list specifies the format for each addressing mode supported by AS8051: #data immediate data byte or word data r,r1,r2 register r0,r1,r2,r3,r4,r5,r6, or r7 @r indirect on register r0 or r1 @dptr indirect on data pointer @a+dptr indirect on accumulator plus data pointer @a+pc indirect on accumulator plus program counter addr direct memory address bitaddr bit address label call or jump label The terms data, addr, bitaddr, and label may all be expressions. Note that not all addressing modes are valid with every in- struction. Refer to the 8051 technical data for valid modes. Inherent Instructions nop Move Instructions mov a,#data mov a,addr mov a,r mov a,@r mov r,#data mov r,addr mov r,a mov addr,a mov addr,#data mov addr,r mov addr,@r mov addr1,addr2 mov bitaddr,c mov @r,#data mov @r,addr mov @r,a mov c,bitaddr mov dptr,#data movc a,@a+dptr movc a,@a+pc movx a,@dptr movx a,@r movx @dptr,a movx @r,a Single Operand Instructions clr a clr c clr bitaddr cpl a cpl c cpl bitaddr setb c setb bitaddr da a rr a rrc a rl a rlc a swap a dec a dec r dec @r inc a inc r inc dptr inc @r div ab mul ab pop addr push addr Two Operand Instructions add a,#data add a,addr add a,r add a,@r addc a,#data addc a,addr addc a,r addc a,@r subb a,#data subb a,addr subb a,r subb a,@r orl a,#data orl a,addr orl a,r orl a,@r orl addr,a orl addr,#data orl c,bitaddr orl c,/bitaddr anl a,#data anl a,addr anl a,r anl a,@r anl addr,a anl addr,#data anl c,bitaddr anl c,/bitaddr xrl a,#data xrl a,addr xrl a,r xrl a,@r xrl addr,a xrl addr,#data xrl c,bitaddr xrl c,/bitaddr xch a,addr xch a,r xch a,@r xchd a,@r Call and Return Instructions acall label lcall label ret reti in data out data rst data Jump Instructions ajmp label cjne a,#data,label cjne a,addr,label cjne r,#data,label cjne @r,#data,label djnz r,label djnz addr,label jbc bitadr,label jb bitadr,label jnb bitadr,label jc label jnc label jz label jnz label jmp @a+dptr ljmp label sjmp label Predefined Symbols: SFR Map --------- 4 Bytes ---------- ---- ---- ---- ---- FC FF F8 FB F4 F7 F0 B F3 EC EF E8 EB E4 E7 E0 ACC E3 DC DF D8 DB D4 D7 D0 PSW D3 CC [ TL2 TH2 ] CF C8 [ T2CON RCAP2L RCAP2H ] CB C4 C7 C0 C3 BC BF B8 IP BB B4 B7 B0 P3 B3 AC AF A8 IE AB A4 A7 A0 P2 A3 9C 9F 98 SCON SBUF 9B 94 97 90 P1 93 8C TH0 TH1 8F 88 TCON TMOD TL0 TL1 8B 84 PCON 87 80 P0 SP DPL DPH 83 [...] Indicates Resident in 8052, not 8051 A is an allowed alternate for ACC. Predefined Symbols: SFR Bit Addresses ---------- 4 BITS ---------- ---- ---- ---- ---- FC FF F8 FB F4 B.4 B.5 B.6 B.7 F7 F0 B.0 B.1 B.2 B.3 F3 EC EF E8 EB E4 ACC.4 ACC.5 ACC.6 ACC.7 E7 E0 ACC.0 ACC.1 ACC.2 ACC.3 E3 DC DF D8 DB D4 PSW.4 PSW.5 PSW.6 PSW.7 D7 D0 PSW.0 PSW.1 PSW.2 PSW.3 D3 CC [ T2CON.4 T2CON.5 T2CON.6 T2CON.7 ] CF C8 [ T2CON.0 T2CON.1 T2CON.2 T2CON.3 ] CB C4 C7 C0 C3 BC IP.4 IP.5 IP.6 IP.7 BF B8 IP.0 IP.1 IP.2 IP.3 BB B4 P3.4 P3.5 P3.6 P3.7 B7 B0 P3.0 P3.1 P3.2 P3.3 B3 AC IE.4 IE.5 EI.6 IE.7 AF A8 IE.0 IE.1 IE.2 IE.3 AB A4 P2.4 P2.5 P2.6 P2.7 A7 A0 P2.0 P2.1 P2.2 P2.3 A3 9C SCON.4 SCON.5 SCON.6 SCON.7 9F 98 SCON.0 SCON.1 SCON.2 SCON.3 9B 94 P1.4 P1.5 P1.6 P1.7 97 90 P1.0 P1.1 P1.2 P1.3 93 8C TCON.4 TCON.5 TCON.6 TCON.7 8F 88 TCON.0 TCON.1 TCON.2 TCON.3 8B 84 P0.4 P0.5 P0.6 P0.7 87 80 P0.0 P0.1 P0.2 P0.3 83 [...] Indicates Resident in 8052, not 8051 A is an allowed alternate for ACC. Predefined Symbols: Control Bits ---------- 4 BITS ---------- ---- ---- ---- ---- FC FF F8 FB F4 F7 F0 F3 EC EF E8 EB E4 E7 E0 E3 DC DF D8 DB D4 RS1 F0 AC CY D7 D0 P OV RS0 D3 CC [ TLCK RCLK EXF2 TF2 ] CF C8 [ CPRL2 CT2 TR2 EXEN2 ] CB C4 C7 C0 C3 BC PS PT2 BF B8 PX0 PT0 PX1 PT1 BB B4 B7 B0 RXD TXD INT0 INT1 B3 AC ES ET2 EA AF A8 EX0 ET0 EX1 ET1 AB A4 A7 A0 A3 9C REN SM2 SM1 SM0 9F 98 RI TI RB8 TB8 9B 94 97 90 93 8C TR0 TF0 TR1 TF1 8F 88 IT0 IE0 IT1 IE1 8B 84 87 80 83 [...] Indicates Resident in 8052, not 8051
... Exit the ASxxxx Documentation
Last Updated: September 2023