51汇编语言指令集符号定义表符号含义RnR0~R7寄存器n=0~7Direct直接地址,内部数据区的地址RAM(00H~7FH)SFR(80H~FFH)B,ACC,PSW,IP,P3,IE,P2,SCON,P1,TCON,P0@Ri间接地址Ri=R0或R18051/31RAM地址(00H~7FH)8052/32RAM地址(00H~FFH)#data8位常数#data1616位常数Addr1616位的目标地址Addr1111位的目标地址Rel相关地址bit内部数据RAM(20H~2FH),特殊功能寄存器的直接地址的位指令介绍指令字节周期动作说明算数运算指令1.ADDA,Rn11将累加器与寄存器的内容相加,结果存回累加器2.ADDA,direct21将累加器与直接地址的内容相加,结果存回累加器3.ADDA,@Ri11将累加器与间接地址的内容相加,结果存回累加器4.ADDA,#data21将累加器与常数相加,结果存回累加器5.ADDCA,Rn11将累加器与寄存器的内容及进位C相加,结果存回累加器6.ADDCA,direct21将累加器与直接地址的内容及进位C相加,结果存回累加器7.ADDCA,@Ri11将累加器与间接地址的内容及进位C相加,结果存回累加器8.ADDCA,#data21将累加器与常数及进位C相加,结果存回累加器9.SUBBA,Rn11将累加器的值减去寄存器的值减借位C,结果存回累加器10.SUBBA,direct21将累加器的值减直接地址的值减借位C,结果存回累加器11.SUBBA,@Ri11将累加器的值减间接地址的值减借位C,结果存回累加器12.SUBB21将累加器的值减常数值减借位C,结A,0data果存回累加器13.INCA11将累加器的值加114.INCRn11将寄存器的值加l15.INCdirect21将直接地址的内容加116.INC@Ri11将间接地址的内容加117.INCDPTR11数据指针寄存器值加1说明:将16位的DPTR加1,当DPTR的低字节(DPL)从FFH溢出至00H时,会使高字节(DPH)加1,不影响任何标志位18.DECA11将累加器的值减119.DECRn11将寄存器的值减120.DECdirect21将直接地址的内容减121.DEC@Ri11将间接地址的内容减122.MULAB14将累加器的值与B寄存器的值相乘,乘积的低位字节存回累加器,高位字节存回B寄存器说明:将累加器A和寄存器B内的无符号整数相乘,产生16位的积,低位字节存入A,高位字节存入B寄存器。如果积大于FFH,则溢出标志位(OV)被设定为1,而进位标志位为023.DIVAB14将累加器的值除以B寄存器的值,结果的商存回累加器,余数存回B寄存器说明:无符号的除法运算,将累加器A除以B寄存器的值,商存入A,余数存入B。执行本指令后,进位位(C)及溢出位(OV)被清除为024.DAA11将累加器A作十进制调整,若(A)3-09或(AC)=1,则(A)3-0←(A)3-0+6若(A)7-49或(C)=1,则(A)7-4←(A)7-4+6逻辑运算指令ANLA,Rn11将累加器的值与寄存器的值做AND的逻辑判断,结果存回累加器ANLA,direct21将累加器的值与直接地址的内容做AND的逻辑判断,结果存回累加器ANLA,@Ri11将累加器的值与间接地址的内容做AND的逻辑判断,结果存回累加器ANLA,#data21将累加器的值与常数做AND的逻辑判断,结果存回累加器ANLdirect,A21将直接地址的内容与累加器的值做AND的逻辑判断,结果存回该直接地址ANL32将直接地址的内容与常数值做ANDdirect,#data的逻辑判断,结果存回该直接地址ORLA,Rn11将累加器的值与寄存器的值做OR的逻辑判断,结果存回累加器32.ORLA,direct21将累加器的值与直接地址的内容做OR的逻辑判断,结果存回累加器33.ORLA,@Ri11将累加器的值与间接地址的内容做OR的逻辑判断,结果存回累加器34.ORLA,#data21将累加器的值与常数做OR的逻辑判断,结果存回累加器35.ORLdirect,A21将直接地址的内容与累加器的值做OR的逻辑判断,结果存回该直接地址36.ORLdirect,#data32将直接地址的内容与常数值做OR的逻辑判断,结果存回该直接地址37.XRLA,Rn11将累加器的值与寄存器的值做XOR的逻辑判断,结果存回累加器38.XRLA,direct21将累加器的值与直接地址的内容做XOR的逻辑判断,结果存回累加器39.XRLA,@Ri11将累加器的值与间接地扯的内容做XOR的逻辑判断,结果存回累加器40.XRLA,#data21将累加器的值与常数作XOR的逻辑判断,结果存回累加器XRLdirect,A21将直接地址的内容与累加器的值做XOR的逻辑判断,结果存回该直接地址42.XRLdirect,#data32将直接地址的内容与常数的值做XOR的逻辑判断,结果存回该直接地址43.CLRA11清除累加器的值为044.CPLA11将累加器的值反相45.RLA11将累加器的值左移一位46.RLCA11将累加器含进位C左移一位47.RRA11将累加器的值右移一位48.RRCA11将累加器含进位C右移一位49.SWAPA11将累加器的高4位与低4位的内容交换。(A)3-0←(A)7-4数据转移指令50.MOVA,Rn11将寄存器的内容载入累加器51.MOVA,direct21将直接地址的内容载入累加器52.MOVA,@Ri11将间接地址的内容载入累加器53.MOVA,#data21将常数载入累加器54.MOVRn,A11将累加器的内容载入寄存器55.MOV22将直接地址的内容载入寄存器Rn,direct56.MOVRn,gdata21将常数载入寄存器57.MOVdirect,A21将累加器的内容存入直接地址58.MOVdirect,Rn22将寄存器的内容存入直接地址59.MOVdirect1,direct232将直接地址2的内容存入直接地址160.MOVdirect,@Ri22将间接地址的内容存入直接地址61.MOVdirect,#data32将常数存入直接地址62.MOV@Ri,A11将累加器的内容存入某间接地址63.MOV@Ri,direct22将直接地址的内容存入某间接地址64.MOV@Ri,#data21将常数存入某间接地址65.MOVDPTR,#data1632将16位的常数存入数据指针寄存器66.MOVCA,@A+DPTR12(A)←((A)+(DPTR))累加器的值再加数据指针寄存器的值为其所指定地址,将该地址的内容读入累加器67.MOVCA,@A+PC12(PC)←(PC)+1;(A)←((A)+(PC))累加器的值加程序计数器的值作为其所指定地址,将该地址的内容读入累加器68.MOVXA,@Ri12将间接地址所指定外部存储器的内容读入累加器(8位地址)69.MOVXA,@DPTR12将数据指针所指定外部存储器的内容读入累加器(16位地址)70.MOVX@Ri,A12将累加器的内容写入间接地址所指定的外部存储器(8位地址)71.MOVX@DPTR,A12将累加器的内容写入数据指针所指定的外部存储器(16位地址)72.PUSHdirect22将直接地址的内容压入堆栈区73.POPdirect22从堆栈弹出该直接地址的内容74.XCHA,Rn11将累加器的内容与寄存器的内容互换75.XCHA,direct21将累加器的值与直接地址的内容互换76.XCHA,@Ri11将累加器的值与间接地址的内容互换77.XCHDA,@Ri11将累加器的低4位与间接地址的低4位互换布尔代数运算78.CLRC11清除进位C为079.CLRbit21清除直接地址的某位为080.SETBC11设定进位C为181.SETBbit21设定直接地址的某位为182.CPLC11将进位C的值反相83.CPLbit21将直接地址的某位值反相84.ANLC,bit22将进位C与直接地址的某位做AND的逻辑判断,结果存回进位C85.ANLC,/bit22将进位C与直接地址的某位的反相值做AND的逻辑判断,结果存回进位C86.ORLC,bit22将进位C与直接地址的某位做OR的逻辑判断,结果存回进位C87.ORLC,/bit22将进位C与直接地址的某位的反相值做OR的逻辑判断,结果存回进位C88.MOVC,bit21将直接地址的某位值存入进位C89.MOVbit,C22将进位C的值存入直接地址的某位90.JCrel22若进位C=1则跳至rel的相关地址91.JNCrel22若进位C=0则跳至rel的相关地址92.JBbit,rel32若直接地址的某位为1,则跳至rel的相关地址93.JNBbit,rel32若直接地址的某位为0,则跳至rel的相关地址94.JBCbit,rel32若直接地址的某位为1,则跳至rel的相关地址,并将该位值清除为0程序跳跃95.ACALLaddr1122调用2K程序存储器范围内的子程序96.LCALLaddr1632调用64K程序存储器范围内的子程序97.RET12从子程序返回98.RETI12从中断子程序返回99.AJMPaddr1122绝对跳跃(2K内)100.LJMPaddr1632长跳跃(64K内)101.SJMPrel22短跳跃(2K内)-128~+127字节102.JMP12跳至累加器的内容加数据指针所指@A+DPTR的相关地址103.JZrel22累加器的内容为0,则跳至rel所指相关地址104.JNZrel22累加器的内容不为0,则跳至rel所指相关地址105.CJNEA,direct,rel32将累加器的内容与直接地址的内容比较,不相等则跳至rel所指的相关地址106.CJNEA,#data,rel32将累加器的内容与常数比较,若不相等则跳至rel所指的相关地址CJNE@Rn,#data,rel32将寄存器的内容与常数比较,若不相等则跳至rel所指的相关地址CJNE@Ri,#data,rel32将间接地址的内容与常数比较,若不相等则跳至rel所指的相关地址109.DJNZRn,rel22将寄存器的内容减1,不等于0则跳至rel所指的相关地址110.DJNZdirect,rel32将直接地址的内容减1,不等于0则跳至rel所指的相关地址111.NOP11无动作符号地址功能介绍BF0HB寄存器ACCE0H累加器PSWD0H程序状态字IPB8H中断优先级控制寄存器P3B0HP3口锁存器IEA8H中断允许控制寄存器P2A0HP2口锁存器SBUF99H串行口锁存器SCON98H串行口控制寄存器P190HP1口锁存器TH18DH定时器/计数器1(高8位)TH08CH定时器/计数器1(低8位)TL18BH定时器/计数器0(高8位)TL08AH定时器/计数器0(低8位)TMOD89A定时器/计数器方式控制寄存器TCON88H定时器/计数器控制寄存器DPH83H数据地址指针(高8位)DPL82H数据地址指针(低8位)SP81H堆栈指针P080HP0口锁存器PCON87H电源控制寄存器P3.0RXD串行口输入端P3.1TXD串行口输出端P3.2INT0外部中断0请求输入端,低电平有效P3.3INT1外部中断1请求输入端,低电平有效P3.4T0定时器/计数器0计数脉冲输入端P3.5T1定时器/计数器1计数脉冲输入端P3.6WR外部数据存储器写选通信号输出端,低电平有效P3.7RD外部数据存储器读选通信号输出端,低电平有效CY(PSW.7)——进位标志位。AC(PSW.6)——辅助进位(或称半进位)标志。F0(PSW.5)——由用户定义的标志位。RS1(PSW.4)、RS0(PSW.3)——工作寄存器组选择位。OV(PSW.2)——溢出标志位。由硬件置位或清零。PSW.1——未定义位。P(PSW.0)——奇偶标志位。位寻址区20H~2FH单元是位寻址区。这16个单元(共计16×8=128位)的每一位都赋予