单片机原理与应用(二)(1).doc_第1页
单片机原理与应用(二)(1).doc_第2页
单片机原理与应用(二)(1).doc_第3页
单片机原理与应用(二)(1).doc_第4页
单片机原理与应用(二)(1).doc_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

单片机原理与应用(二)第三章 单片机的指令系统及程序设计单片机的应用可归纳为是对单片机的内、外存储器进行“存取”的操作,而“输入输出”的操作是对P0、P1、P2、P3这四个与芯片外部引脚相连的专用存储器的“存取”。 “存取”操作是在存储器之间进行的,可以直接用存储器的地址,如18、35H也可以用专用的或自定义的变量名,如 A,R1, P3, Addr1,X1,ON。3.1 MCS-51单片机指令系统概述共有111条指令。指令长度:单字节有49条,双字节有45条,三字节有17条。执行时间:单周期指令有57条,双周期指令有52条,四周期指令有2条。有7种寻址方式,42种助记符,33种功能。指令可分为三大类:1数据传送指令:MOV、MOVC、MOVX2运算指令: ADDC、SUBB、RLC、ANL、SETB、CLR3转移控制指令:LJMP、JB、JNB、JZ、CJNE、DJNZ、LCALL、RET指令格式:标号: 功能助记符 (目标操作数),(源操作数) ;注释 例 START: MOV R1,#25H ; 常数25H送给寄存器R1 MOV A,45H ; 地址45H单元中的内容送给寄存器A功能助记符也叫操作码。3.2 MCS-51单片机指令系统的寻址方式 立即(常数)寻址:MOV A,#18 ; 等价于C语言的A=18 表示为:A18MOV A,#3CH ; 等价于C语言的A=0X3C A3CH MOV DPTR,#25D8H 直接寻址: MOV A,18 ; 等价于C语言的A=数组名18 A(18)MOV A,5BH ; 等价于C语言的A=数组名5BH A(5BH) MOV DPH,62H ANL 40H,#50HLJMP 1234H 寄存器寻址: MOV A,R1 ; 等价于C语言的A=R1 AR1MOV 27H,SP 寄存器间接寻址:MOV A,R1 ; 等价于C语言的A=数组名R1 A(R1)MOVX A,R1 MOVX A,DPTR ; 等价于C语言的A=数组名DPTR A(DPTR)MOV R0,#56H ; 等价于C语言的数组名R0=0X56 (R0)56H 相对(PC)寻址: SJMP 0E4H ; 等价于C语言的 goto 标号;JZ -115 ; 等价于C语言的 if (A=0) goto 标号; 变址寻址:MOVC A,A+DPTR ; 等价于C语言的A=数组名A+DPTR A(A+DPTR)MOVC A,A+PC 位寻址: MOV C,25H C(25H) MOV 25H,C (25H)C SETB P1.0 P1.01 CLR P2.5 P2.50 SETB 37H (37H)1 应表示为:(26H).71 更确切。 因为: MOV 37H, #1 也表示为:(37H)1 3.3 MCS-51单片机指令系统的使用要点 3.3.1 会影响标志位的指令PSW中的 C:进位 AC:半进位 OV:溢出 P:奇偶例:(-104)+(-117)= (10011000) + (10001011) 补码运算执行 MOV A, #98H 10011000 ADD A, #8BH 10001011 之后 A=23H=35, C=1, AC=1, OV=1, P=1 100100011关于溢出:指令进行算术运算时,是以补码进行的。 值的范围:-128+127,当运算的结果超出此范围时,OV=1 。例:(-5)+(-6)= (11111011) + (11111010)执行 MOV A, #0FBH 11111011ADD A, #0FAH +11111010之后 A=F5H= -11, C=1, AC=1, OV=0, P=0 111110101 3.3.2 伪指令:提供汇编的控制信息。1. ORG 16位地址 ;指明下一条的地址 例1:ORG100H ;指明下一条指令的地址是100HLJMPMain1 ;这条指令从程序存储器地址的100H开始存放2. 标号: DB 单字节数据项表 ;针对程序存储器 例2: ORG 2000H MA:DB 68H,0F5H,128 ;MA2000H,(2000H)=68H,(2001H)=128 若执行指令 MOV DPTR,#MA ;等价于 MOV DPTR,#2000H CLR A ; A0MOVC A,A+DPTR ;A(A+DPTR)=(0+2000H)=68H3. 标号: DW 双字节数据项表 ; 例3: ORG0F00H MA: DW68F5H,0234H4. 名字 EQU 表达式 ;给表达式的值或字符串取名这里的“名字”等同于高级语言中的变量名。高级语言中注重“变量”,而汇编语言注重“地址”。 例4:ABCEQU58H ; ABC58H DianHuoEQUP1.4 ; DianHuoP1.4指令 MOVA,ABC ; 等价于 MOV A,58H ;A(58H)指令 MOVA,#ABC ; 等价于 MOV A,#58H ;A58H 指令 SETBDianHuo ; 等价于 SETB P1.45. 名字 DATA 直接字节地址 ;给内存RAM单元取名 6. 名字 WDATA 直接字节地址 ;给外存RAM单元取名7. 名字 BIT 位地址 ;给可寻址的位单元取名例5: DianHuo EQUP1.4 ; DianHuoP1.4(或 DianHuo BITP1.4 ; DianHuoP1.4 ) 指令 SETBDianHuo ; 等价于 SETB P1.4BIT、DATA、WDATA是EQU的特例。8. 标号: END ;9. 标号: DS 表达式 ;空出若干个存储单元 3.3.3 指令系统的分类:共111条,可分为五大类。1. 数据传送指令:不影响C、AC、OV ,影响P。1). 内部数据存储器RAM的传输指令 汇编指令 机器指令 MOV A,R5 11101r r r MOV A,65H 11100101 01100101 MOV A,#65H 11100100 01100101 MOV A,R1 1110011 i MOV R6,A (书上有错) MOV R3,82H 10101r r r 10000010 MOV R0,#7DH 01111r r r 01111101 MOV 15H,A ; (15H)A MOV 38H,R5 ; (38H)R5 MOV 6EH,R1 ; (6EH)(R1) MOV 53H,#8EH ; (53H)8EH例: K3EQU 38H ; 请注意格式的对齐 MOV K3,R5 ; (K3)R5 MOV 0E3H,2AH MOV R0,A MOV R1,75H MOV R0,#3BH MOV DPTR,15A3H ; DPTR15A3H PUSH 67H ; SPSP+1 , (SP)(67H) POP PSW ; PSW(SP), SPSP1 XCH A,R3 ; 字节交换 AR3 XCH A,27H ; A(27H) XCH A,R1 ; A(R1) XCHDA,R0 ; 字节的低4位交换,高4位不变 SWAPA ; A的高4位和低4位交换2). 累加器A与外部数据存储器RAM的传送指令 MOVX A,DPTR ; A(DPTR) MOVX DPTR,A MOVX A,R1 ;A(P2R1) MOVX R0,A ;(P2R0) A3). 查表指令(对程序存储器ROM) MOVC A,A+PC MOVC A,A+DPTR ; A(DPTR+A)例:对内部RAM:MOV A,R0 ; R0的内容为表格中存放数据的地址。对外部RAM:MOVX A,R0 ; P2,R0 为存放数据的地址MOVX A,DPTR ; 对程序ROM:MOVC A,A+DPTR ;一般A=0,DPTR作为增量。 表中取出的值与指定的值(如字符B)比较、判别: CJNE A, B, L1或 CJNE A,#42H,L1 ; 若 A42H 则转移到L1执行。2. 算术操作指令1). 加法指令 :、会影响C、AC、OV 、P。 不带进位的加法运算 ADD A,R3 ; AA+R3 带进位的加法运算 ADDC A,R3 ; AA+R3+C 增量指令 INC A INC R4 ; R4R4+1 INC R1 ; (R1)(R1)+1 十进制调整指令 DA A ; 当A的高四位(低四位)的C=1(AC=1)或者大于9,则进行加6调整。例: MOV A,#59H ADD A,#69H ; A59H+69H=C2H, C=0, AC=1 必须保证两个操作数均为BCD码 DA A ; AC2H+66H=28H,C=12). 减法指令 :会影响C、AC、OV 、P。 带借位减法指令 SUBB A,R5 SUBBA,63H ; AA(63H)C SUBB A, R1 SUBB A,#4AH 减1指令 DEC A DEC R3 DEC R1 DEC 57H3). 乘法指令 MUL AB ; AAB 结果的高8位在B, 低8位在A。4). 除法指令 DIV AB ; AAB 结果的商在A, 余数在B。3. 逻辑运算指令1). 单操作数逻辑运算指令 累加器清零 CLR A 其余的寄存器或存储单元的清零,只能用 MOV R3,#00H 累加器取反 CPL A 累加器左移 RL A RLC A ; 带进位C 累加器右移 RR A RRC A ; 带进位C2). 双操作数逻辑运算指令:注意操作数没有 ANL 35H,R2的形式。 逻辑与 ANL 35H,A ; (35H)(35H)A 逻辑或 ORL A,R1 ; AA(R1) 逻辑异或 若 MOV 6BH,#0C5H 11000101 XRL 6BH,#59H ;(6BH)(6BH) + 59H=9CH + 01011001主要用在判断两个字节内容是否相等。 10011100 相等时的结果为0。4. 控制转移指令 1). 无条件转移 AJMP 11位地址 ;(PC)PC的高5位后接11位地址 PC的高5位 地址段(2KB) 00000bbb XX 000007FF 00001bbb XX 08000FFF 00010bbb XX 100017FF 00011bbb XX 18001FFF | | 11110bbb XX F000F7FF 11111bbb XX F800FFFF SJMP -128+127的偏移量 ;PCPC+2+偏移量 LJMP 16位地址 ;PC 16位地址 JMP A+DPTR ;PC(A+DPTR)例: 应用JMP指令实现switch case转移功能。 START: MOV DPTR,#TEMP MOV 35H,ARL A ADD A,35H ;A=A*3 JMPA+DPTR TEMP: LJMP CL0 ; 当A=0 LJMP CL1 ;当A=1 LJMP CL2 ;当A=2 LJMP CL9 ;当A=92).条件转移 测试条件转移 JZ -128+127的偏移量 ; 当(A)0时,(PC)(PC)+2+偏移量 JNZ -128+127的偏移量 ; (A)0 JC -128+127的偏移量 ; (C)1 JNC -128+127的偏移量 ; (C)0 JB bit,-128+127的偏移量 ; (bit)1 ,(PC)(PC)+3+偏移量 JNB bit,-128+127的偏移量 ; (bit)0 JBC bit,-128+127的偏移量 ; (bit)1 ,同时(bit)0 比较不相等转移CJNE A,#69H,-128+127的偏移量 ;当(A)69H时,PCPC+3+偏移量 ;当(A)69H时, PCPC+3 循环控制转移DJNE R5,-128+127的偏移量 ;R5R51,;当R50时,PCPC+2+偏移量DJNE 37H,-128+127的偏移量 ;(37H)(37H)1,;当(37H)0时,PCPC+3+偏移量3).调用和返回 调用 ACALL 11位地址 ; LCALL 16位地址 ;SPSP+1,(SP)PC+2的低字节, ;SPSP+1,(SP)PC+2的高字节, ;PC16位地址。 返回 RET ;子程序返回 PC的高字节(SP),SPSP1,;PC的低字节(SP),SPSP1。 RETI ;中断返回4).空操作 NOP 5. 位操作指令1). 位传送MOV C,27H MOV 5DH,C2). 位修改(置位或清零) CLR C ;C0 CLR P1.4 CPL C ; 求反 CPL 48H SETB C ;C1 SETB 6DH3). 位逻辑与 ANL C,45H ;CC(45H) ANL C,/45H ;CC(45H)4). 位逻辑或 ORL C,5BH ;CC(5BH) ORL C,/5BH ;CC(5BH) 各种指令操作码的含义:1. MOV: 内部数据存储器传送 16. XCH: 两字节交换 31. ADD:不带进位的加法2. MOVX:外部数据存储器传送 17. JBC:位变量为1则置0并转移 32. CLR: 清0 3. SETB: 位变量置1 18. INC: 加1 33. SJMP:相对于PC转移4. SWAP:ACC的高低4位交换 19. MOVC:外部程序存储器传送 34. AJMP:短转移5. RETI:中断返回 20. LCALL:子程序长调用 35. RLC:带进位左移6. CJNE:比较不相等则转移 21. DJNE:相减结果为0则转移 36. MUL:乘法7. JZ: ACC的内容为0则转移 22. SUBB:带进位减法 37. DA: 十进制调整8. ADDC:带进位的加法 23. POP: 出栈 38. XCHD:低半字节交换9. ANL:逻辑与 24. CPL: 位变量取反 39. JB: 位变量为1则转移 10. RRC:带进位右移 25. JNZ:ACC的内容不为0则转移 40. RL: 左移11. XRL:逻辑异或 26. ORL: 逻辑或 41. JNC:进位位不为1则转移12. DIV:除法 27. JNB: 位变量为0则转移 42. RET:子程序返回13. LJMP:长转移 28. PUSH:进栈 43. JMP:间接转移14. DEC:减1 29. NOP: 空指令 44. ACALL:子程序短调用15. RR: 右移 30. JC: 进位位为1则转移 45. 伪指令作业二:填空题:1. 通用寄存器R0R7在工作寄存器区中有四组,由程序状态字中的 位和 位来选择确定。2. MCS-51片内地址 范围内的数据存储器,既可以字节寻址又可以位寻址。3. 在MCS51单片机中,如果采用6MHz晶振,则1个机器周期的执行时间是 。4假定累加器A=49H,执行指令:201AH: MOVC A,A+PC后,送入A的是程序存储器 单元的内容。5若DPTR=5306H,A=49H,执行下列指令:MOVC A,A+DPTR后,送入A的是程序存储器 单元的内容。6假定SP=45H,ACC=46H,B=47H,执行下列指令:PUSH ACCPUSH B后,SP= ,(46H)= ,(47H)= 。7假定SP=47H,(46H)=46H,(47H)=47H。执行下列指令:POP DPHPOP DPL后,DPTR= ,SP= 。8若A=56H,R0=56H,(56H)=79H。执行指令:ADD A,R0后,A= ,CY= ,AC= ,OV= 。9若A=0FFH,R0=46H,(46H)=0FFH,CY=1。执行指令: ADDC A,R0后,A= ,CY= ,AC= ,OV= 。10假定A=45H,B=67H。执行指令: MUL AB后,寄存器B= ,累加器A= ,CY= ,OV= 。11假定A=0FCH,B=35H。执行指令:DIV AB后,累加器A= ,寄存器B= ,CY= ,OV= 。3.4 汇编语言程序设计及实用程序举例关于结构化程序设计(面向过程) 自顶向下,逐步细化。细化的每个步骤应尽可能划分成大的部分:即能划分成三部分就不要划分成四部分,能划分成两部分就不要划分成三部分。直至不能再分解。对每个部分模块化,每个模块使用结构化方法设计。【补充:关于面向对象的程序设计(在结构化程序设计的基础上面向数据)】顺序结构程序 双分支结构程序3.4.1 顺序结构程序3.4.2 分支结构程序 N S1=1 Y L1 指令系列1 指令系列2 与框图对应的程序:(S1是位变量) L2单分支结构程序: 双分支结构程序:(其他指令) (其他指令) 单分支结构程序 JBS1,L1 JBS1,L1 指令系列 指令系列1 S1=1 YL1: (其他指令) SJMP L2 N L1:指令系列2 指令系列 L2:(其他指令) L1 3.4.3 循环结构程序 1.先循环后判别 2.先判别后循环R3为专用变量名 L1 L11.先循环后判别 (其他指令) 指令系列 R3=0 Y L1: 指令系列 L2 N DJNZ R3,L1 N R3=0 指令系列 (其他指令) Y L3DJNZ R3,L1 这一条指令执行的结果为: R3R31 如果 R30 则 转移到L1 否则 执行下一条指令。2.先判别后循环方法一: 方法二: 方法三: (其他指令) (其他指令) (其他指令)L1: DJNZ R3,L2 L1: MOV A,R3 L1: MOV A,R3 SJMP L3 JZ L3 JNZ L2L2: 指令系列 L2: 指令系列 SJMP L3 SJMP L1 SJMP L1 L2:指令系列L3: (其他指令) L3: (其他指令) SJMP L1 (其他指令)3.4.4 子程序设计1. 子程序的结构例:软件延时3ms,设Fosc=6MHz。DELAY3: MOVR5,#3 DEL0: MOVR4,#250 DEL1: DJNZR4,DEL1 ;2504s=1ms DJNZR5,DEL0 RET 使用 LCALL DELAY3 或 ACALL DELAY3 调用。软件延时程序流程图: 软件延时3ms R53 R4250 R4R4-1N R4=0 Y R5R5-1 N R5=0 Y RET 2. 子程序的参数传递 1) 无参数 2) 用累加器A、寄存器R0R7 3) 通过操作数地址 4) 通过堆栈:见P49页的例3-49 3. 现场保护和恢复现场:主要在中断子程序的进入。 4. 堆栈的设置:SP的初值为07H,应予再设置,如MOV SP,#60H。 5. 子程序的嵌套:与堆栈的存储空间有关。3.4.5 单片机实用程序 1.【例3-44】求表中最小的数(查表)并保存。2.【例3-45】延时子程序3.【例3-47】两个8位二进制数相加4.【例3-50】双字节BCD转换成二进制数 (书上有遗漏指令,因其说明有误。) 5.【例3-51】8位二进制数转换成三位BCD码;6.【例3-52】二进制码转换成ASCII码;7.【例3-53】ASCII码转换为4位二进制数。8. 双字节BCD相加9. 双字节无符号数相加、相减;10. 双字节乘、除单字节(举例:模拟运行验证结果) 分析:设R5、R4为被乘数, R3为乘数,则 (R7、R6)R5*R3, (B、A)R4*R3, R5A, R6R6+B,R7R7+C,结果在R7、R6、R5中。 补充:单片机上的主程序大多如下所示:主程序LED(扫描)显示输出键盘(扫描)输入键处理事件处理例题一:一、设在8051单片机内部的RAM中,已知(60H)=63H,(61H)=35H, (62H)=61H,(63H)=20H,请分析下列程序执行后,所涉及到的各存储单元和寄存器以及端口最后的内容。MOV R1,62H ; R1(62H)=61HMOV A,R1 ; A(R1)=(61H)=35HMOV R1,63H; (R1)=(61H)(63H)=20HMOV R0,A ; R0A=35HMOV R0,#63H; (R0)=(35H)63HMOV 60H,R1 ; (60H)R1=61HMOV DPTR,#1234H; DPH12H, DPL34H 或 PDTR1234HMOV A,DPL; ADPL=34HMOV DPL,61H; DPL(61H)=20HMOV SP,#61H; SP61HPUSH A; SPSP+1=62H, (SP)=(62H)A=34H结果: (62H)=34H , SP=62H , DPL=20H , A=34H , DPH=12H , (60H)=61H , (35H)=63H , R0=35H , (61H)=20H , R1=61H例题二: 试编写一查表子程序(外部RAM),从首地址为1000H,长度为12H的外部数据存储器数据表中,查找出字符T,查到则置F0=1并将其地址存入外部数据存储器的1050H和1051H单元中(低前高后)否则置F0=0。并画出对应程序的流程图。子程序: SB1:MOV DPTR, #1000H ; 取出数据表的首地址 MOV R2, #12H ; 循环次数的初值L1: MOVX A, DPTR ; 取表中数据CJNE A, T, L2; 判A=T, 不是则转到L2 SETB F0 ; 查找到, 置F0=1MOV R4, DPH; 暂时保存DPTR到R4,R5 MOV R5, DPL; MOV DPTR, #1050H; 取存放的地址到DPTR中 MOV A, R5; MOVX DPTR, A; 存T所在地址的低字节 INC DPTR; 存放的地址+1MOV A, R4; MOVX DPTR, A; 存T所在地址的高字节RET; 子程序返回 L2:INC DPTR; 数据表的地址指针+1DJNZ R2, L1; 循环值-1CLR F0 ; 循环结束,没找到T,F0清0RET; 子程序返回伪代码:1、初始化数据指针和循环量2、取出表中数据3、判所取数据=T吗?是,转到4、(不是) 数据指针+15、判查表结束?没有,转到26、(结束,没查到) F0置07、结束8、(查到) F0置19、 T所在地址存到1050H和1051H单元中9.1 数据指针的低字节送到1050H单元9.2 数据指针的高字节送到1051H单元10、结束流程图: 查表子程序 DPTR数据表的首地址1000H R2循环次数12H 取表中数据到A A=T N 数据表的指针DPTR+1 Y R2R2-1 F0=1 R2=0 N T所在地址存到1050H和1051H单元中 Y F0=0 返回 作业三:一、连线立即寻址: MOVC A,A+DPTR 直接寻址: SETB P1.0 寄存器寻址: MOV DPTR,#25D

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论