【教学课件】第3章MCS-51单片机指令系统.ppt
第3章 MCS-51单片机指令系统,3.1 MCS-51指令系统的分类、格式及一般说明3.2 寻址方式3.3 分类指令,MCS-51单片机指令系统有如下特点:,(1)指令执行时间快。(2)指令短,约有一半的指令为单字节指令。(3)用一条指令即可实现2个一字节的相乘或相除。(4)具有丰富的位操作指令。(5)可直接用传送指令实现端口的输入输出操作。,3.1 MCS-51指令系统的分类、格式及一般说明,3.1.1 指令分类3.1.2 指令格式3.1.3 指令描述符号介绍,返回本章首页,3.1.1 指令分类,按指令功能,MCS-51指令系统分为数据传递与交换、算术运算、逻辑运算、程序转移、布尔处理操作、CPU控制等6类。布尔处理操作类指令又称位操作指令。,返回本节,3.1.2 指令格式,在MCS-51指令中,一般指令主要由操作码、操作数组成。指令应具有以下功能:(1)操作码指明执行什么性质和类型的操作。例如,数的传送、加法、减法等。(2)操作数指明操作的数本身或者是操作数所在的地址。(3)指定操作结果存放的地址。,返回本节,3.1.3 指令描述符号介绍,Rn当前选中的寄存器区中的8个工作寄存器R0R7(n=07)。Ri当前选中的寄存器区中的2个工作寄存器R0、R1(i=0,1)。direct8位的内部数据存储器单元中的地址。#data包含在指令中的8位常数。#data16包含在指令中的16位常数。addr1616位目的地址。addr1111位目的地址。,rel8位带符号的偏移字节,简称偏移量。DPTR数据指针,可用作16位地址寄存器。bit内部RAM或专用寄存器中的直接寻址位。A累加器。B专用寄存器,用于乘法和除法指令中。C进位标志或进位位,或布尔处理机中的累加器。,间址寄存器或基址寄存器的前缀,如Ri,DPTR。/位操作数的前缀,表示对该位操作数取反,如/bit。片内RAM的直接地址或寄存器。()由寻址的单元中的内容。箭头左边的内容被箭头右边的内容所代替。,返回本节,3.2 寻址方式,3.2.1 立即寻址3.2.2 直接寻址3.2.3 寄存器寻址3.2.4 寄存器间接寻址3.2.5 变址寻址3.2.6 相对寻址3.2.7 位寻址,返回本章首页,3.2.1 立即寻址,指令中直接给出操作数的寻址方式。立即操作数用前面加有#号的8位或16位数来表示。例如:MOVA,#60H;A#60H MOVDPTR,#3400H;DPTR#3400HMOV30H,#40H;30H单元#40H 上述三条指令执行完后,累加器A中数据为立即数据60H,DPTR寄存器中数据为3400H,30H单元中数据为立即数40H。,返回本节,3.2.2 直接寻址,指令中直接给出操作数地址的寻址方式,能进行直接寻址的存储空间有SFR寄存器和内部数据RAM。例如:MOVPSW,#20H;PSW#20H PSW为直接寻址寄存器的符号地址。MOVA,30H;A30H内部RAM单元中的内容30H为直接给出的内部RAM的地址。,返回本节,3.2.3 寄存器寻址,以通用寄存器的内容为操作数的寻址方式。通用寄存器指A、B、DPTR以及R0R7。例如:CLR A;A0 INC DPTR;DPTRDPTR+1 ADDR5,#20H;R5#20H+R5,返回本节,3.2.4 寄存器间接寻址,以寄存器中内容为地址,以该地址中内容为操作数的寻址方式。间接寻址的存储器空间包括内部数据RAM和外部数据RAM。能用于寄存器间接寻址的寄存器有R0,R1,DPTR,SP。其中R0、R1必须是工作寄存器组中的寄存器。SP仅用于堆栈操作。,例如:MOV R0,A;内部RAM(R0)A其指令操作过程示意图如图3-1所示。又如:MOVX A,R1;A外部RAM(P2R1)其指令操作过程示意图如图3-2所示。再如:MOVX DPTR,A;外部RAM(DPTR)A 其指令操作过程示意图如图3-3所示。,图3-1 MOV R0,A间接寻址示意图,图3-2 MOVX A,R1间接寻址示意图,图3-3 MOVX DPTR,A间接寻址示意图,返回本节,3.2.5 变址寻址,变址寻址只能对程序存储器中数据进行操作。由于程序存储器是只读的,因此变址寻址只有读操作而无写操作,在指令符号上采用MOVC的形式(如图3-4所示)。例如:MOVC A,A+DPTR;A(A+DPTR)又如,MOVC A,A+PC;A(A+PC)这条指令与上条指令不同的是,基址寄存器是PC。,图3-4 变址寻址示意图,返回本节,3.2.6 相对寻址,以当前程序计数器PC的内容为基础,加上指令给出的一字节补码数(偏移量)形成新的PC值的寻址方式。相对寻址用于修改PC值,主要用于实现程序的分支转移。例如,SJMP 08H;PCPC+2+08H 指令操作示意图如图3-5所示。,图3-5 相对寻址示意图,返回本节,3.2.7 位寻址,位寻址只能对有位地址的单元作位寻址操作。位寻址其实是一种直接寻址方式,不过其地址是位地址。例如:SETB 10H;将10H位置1若22H单元中存放着数据40H,22H单元的D0位的位地址为10H,执行上述指令后(22H)=41H。又如:MOV 32H,C;32H进位位C ORL C,32H;CC32H,返回本节,3.3 分类指令,3.3.1 数据传送类指令3.3.2 算术运算类指令3.3.3 逻辑运算与循环类指令3.3.4 程序转移类指令3.3.5 调用子程序及返回指令3.3.6 位操作指令3.3.7 空操作指令,返回本章首页,3.3.1 数据传送类指令,数据传送类指令共28条,是将源操作数送到目的操作数。指令执行后,源操作数不变,目的操作数被源操作数取代。数据传送类指令用到的助记符有MOV、MOVX、MOVC、XCH、XCHD、SWAP、PUSH、POP8种。源操作数可采用寄存器、寄存器间接、直接、立即、变址5种寻址方式寻址,目的操作数可以采用寄存器、寄存器间接、直接寻址3种寻址方式。MCS-51单片机片内数据传送途径如图3-6所示。,图3-6 MCS-51单片机片内数据传送图,1以A为目的操作数,MOV A,Rn;A RnMOV A,direct;A(direct)MOV A,Ri;A(Ri)MOV A,#data;A#data,2以Rn为目的操作数,MOV Rn,A;Rn AMOV Rn,direct;Rn(direct)MOV Rn,#data;Rn#data,3以直接地址为目的操作数,MOV Ri,A;(Ri)AMOV Ri,direct;(Ri)(direct)MOV Ri,#data;(Ri)#data,4以间接地址为目的操作数,MOV Ri,A;(Ri)AMOV Ri,direct;(Ri)(direct)MOV Ri,#data;(Ri)#data例如:设(30H)=6FH,R1=40H,执行MOV R1,30H后,30H单元中数据取出送入R1间接寻址的40H单元,(40H)=6FH。,5以DPTR为目的操作数,MOV DPTR,#data16;DPTR#data16例如执行 MOV DPTR,#2000H 后,(DPTR)=2000H。,6访问外部数据RAM,MOVX A,DPTR;A(DPTR)MOVX DPTR,A;(DPTR)AMOVX A,Ri;A(P2Ri)MOVX Ri,A;(P2Ri)A,7读程序存储器,MOVC A,A+DPTR;A(A+DPTR)MOVC A,A+PC;A(A+PC)例如已知A=30H,DPTR=3000H,程序存储器单元(3030H)=50H,执行MOVC A,A+DPTR后,A=50H。,8数据交换,l字节交换XCH A,Rn;A RnXCH A,direct;A(direct)XCH A,Ri;A(Ri)l半字节交换XCHD A,Ri;A03(Ri)03SWAP A;A03A47,9堆栈操作,所谓堆栈是在片内RAM中按“先进后出,后进先出”原则设置的专用存储区。数据的进栈出栈由指针SP统一管理。堆栈的操作有如下两条专用指令:PUSH direct;SP(SP+1),(SP)(direct)POPdirect;(direct)(SP),SP SP-1PUSH是进栈(或称为压入操作)指令。指令执行过程如图3-7所示。,图3-7 指令PUSH操作示意图,图3-8 指令POP操作示意图,【例3.1】将片内RAM 30H单元与40H单元中的内容互换。,方法1(直接地址传送法):MOV31H,30H MOV30H,40H MOV40H,31H SJMP$,方法2(间接地址传送法):MOVR0,#40H MOVR1,#30H MOVA,R0 MOVB,R1 MOVR1,A MOVR0,B SJMP$,方法3(字节交换传送法):MOVA,30H XCHA,40H MOV30H,A SJMP$,方法4(堆栈传送法):PUSH30H PUSH40H POP30H POP40H SJMP$,返回本节,3.3.2 算术运算类指令,1加法指令ADD A,Rn;A A+RnADD A,direct;A A+(direct)ADD A,Ri;A A+(Ri)ADD A,#data;A A+#data,2带进位加指令ADDC A,Rn;A A+Rn+CADDC A,direct;A A+(direct)+CADDC A,Ri;A A+(Ri)+CADDC A,#data;A A+#data+CC为来自PSW状态寄存器中的进位位C。例如,设A=20H,R0=21H,C=1,执行指令 ADDC,R0后,A=42H。,3带借位减指令SUBB A,Rn;A A-Rn-CSUBB A,direct;A A-(direct)-CSUBB A,Ri;A A-(Ri)-CSUBB A,#data;A A-#data C例如,设A=39H,R0=20H,(20H)=32H,C=1,执行指令 SUBB,R0后,A=06H。,4乘法指令MUL AB;BA ABA和B中各存放一个8位无符号数,指令执行后,16位乘积的高8位在B中,低8位存A中。例如,A=30H,B=60H,执行 MUL AB 后,A=00H,B=12H。,5除法指令 DIV AB;AB商在A中,余数在B中 A和B中各存放一个8位无符号数,A放被除数,B放除数。指令执行后,A中存放商,B中存入余数。若B=00H,则指令执行后OV=1,A与B不变。例如,A=30H,B=07H,执行 DIV AB 后,A=06H,B=06H。,6加1指令INC A;A A+1INC Rn;Rn Rn+1INC direct;(direct)(direct)+1INC Ri;(Ri)(Ri)+1INC DPTR;DPTR DPTR+1例如,(30H)=22H,执行 INC 30H 后,(30H)=23H。,7减1指令DEC A;A A-1DEC Rn;Rn Rn-1DEC direct;direct(direct)-1DEC Ri;(Ri)(Ri)-1例如,R0=30H,(30H)=22H,执行 DEC R0 后,(30H)=21H。,8十进制调整指令DA A;把A中按二进制相加的结果调整成按BCD码相加的结果例如,A=65BCD,B=78BCD,C=0,执行下列语句ADDA,BDAA后,A=43 BCD,C=1。,【例3.2】试把存放在R1R2和R3R4中的两个16位数相加,结果存于R5R6中。解:参考程序如下:MOVA,R2;取第一个数的低8位 ADDA,R4;两数的低8位相加 MOVR6,A;保存和的低8位,MOVA,R1;取第一个数的高8位 ADDCA,R3;两数的高8位相加,并把低8位相加时的进位位加进来 MOVR5,A;把相加的高8位存入R5寄存器中 SJMP$,返回本节,3.3.3 逻辑运算与循环类指令,1“与”操作指令 2“或”操作指令3“异或”操作指令4求反与清除指令5循环指令,返回本节,3.3.4 程序转移类指令,1无条件转移指令l绝对(短)转移指令AJMPaddr11;PC100 addr11 l长转移指令LJMPaddr16;PC addr16l短(相对)转移指令SJMPrel;PC PC+2+rell 间接转移指令JMPA+DPTR;PC A+DPTR,2条件转移指令l累加器为零(非零)转移指令l减1非零转移指令l两数不等转移指令l相对偏移量rel的求法,表3-1 程序存储器空间32个2K地址范围,返回本节,3.3.5 调用子程序及返回指令,1调用子程序指令LCALL addr16;PCPC+3,SPSP+1,(SP)PC710;SPSP+1,(SP)PC158,PCaddr16ACALL addr11;PC PC+2,SPSP+1,(SP)PC70;SP SP+1,(SP)PC158,PC100addr11,2返回指令RET;PC158(SP),SPSP-1;PC70(SP),SPSP-1RETI;PC158(SP),SPSP-1;PC70(SP),SPSP-1,返回本节,3.3.6 位操作指令,1位数据传送指令MOVC,bit;C(bit)MOV bit,C;bitC2位状态修改指令CLRC;C0CLRbit;(bit)0CPLC;CCPLbit;(bit)(bit)SETBC;C1SETBbit;(bit)1,3位逻辑运算指令ANLC,bit;CC(bit)ANLC,/bit;CC(bit)ORLC,bit;CC(bit)ORLC,/bit;CC(bit),4位转移指令JCrel;若C=1,则转移(PCPC+2+rel);否则程序顺序执行JNCrel;若C=0,则转移(PCPC+2+rel);否则程序顺序执JBbit,rel;若(bit)=1,则转移(PCPC+3+rel);否则程序顺序执行,JNBbit,rel;若(bit)=0,则转移(PCPC+3+rel);否则程序顺序执行JBCbit,rel;若(bit)=1,则PCPC+3+rel,(bit)0;否则程序顺序执行功能:分别检测指定位是1还是0,若条件符合,则CPU转向指定的目标地址去执行程序;否则,顺序执行下条指令。,返回本节,3.3.7 空操作指令,NOP;PC PC+1这是一条单字节指令。执行时,不作任何操作(即空操作),仅将程序计数器PC的内容加1,使CPU指向下一条指令继续执行程序。这条指令常用来产生一个机器周期的时间延迟。,返回本节,本章到此结束,谢谢您的光临!,结束放映,返回本章首页,THANK YOU VERY MUCH!,