大学单片机原理与应用-胡辉-PPT文稿资料课件PPT
收藏
资源目录
压缩包内文档预览:
编号:21836274
类型:共享资源
大小:17.22MB
格式:ZIP
上传时间:2019-09-06
上传人:QQ24****1780
认证信息
个人认证
王**(实名认证)
浙江
IP属地:浙江
25
积分
- 关 键 词:
-
大学
单片机
原理
应用
利用
运用
胡辉
ppt
文稿
资料
课件
- 资源描述:
-
大学单片机原理与应用-胡辉-PPT文稿资料课件PPT,大学,单片机,原理,应用,利用,运用,胡辉,ppt,文稿,资料,课件
- 内容简介:
-
第章 程序设计 虽然单片机的每条指令能使计算机完成一种特定的操作。但要完成某一特定的任务还需要将这些指令按工作要求有序组合为一段完整的程序。程序实际上是一系列计算机指令的有序集合。我们把利用计算机的指令系统来合理地编写出解决某个问题的程序的过程,称之为程序设计。4.1 简单汇编语言程序设计 编制程序的步骤1.任务分析(硬件、软件系统分析)2.确定算法和工作步骤;3.程序总体设计和流程图绘制关于流程图符号:开始、结束-圆角矩形工作任务-矩形判断分支-菱形程序流向-程序连接-开始结束4. 分配内存,确定程序与数据区存放地址;5. 编写源程序;6. 调试、修改,最终确定程序。方法技巧1. 模块化设计(按功能分:显示、打印、输入、发送等)2. 尽量采用循环及子程序结构(节省内存)汇编语言的规范汇编语言源程序由以下两种指令构成汇编语句(指令语句)伪指令(指示性语句)汇编语句的格式: 标号:操作码操作数;注释数据表示形式: 二进制(B)、十六进制(H)、十进制(D或省略)、ASCII码(以单引号标识) 3.伪指令:控制汇编用的特殊指令,这些指令不属 于指令系统,不产生机器代码。4.1.1 分支程序分支程序可根据要求无条件或条件地改变程序执行流向。编写分支程序主要在于正确使用转移指令。分支程序有:单分支结构、双分支结构、多分支结构(散转)分支程序分支程序可根据要求无条件或条件地改变程序执行流向。编写分支程序主要在于正确使用转移指令。分支程序有:单分支结构、双分支结构、多分支结构(散转)1比较数的大小 入口条件:两个带符号数分别存在内部RAM 30H和31H单元中,试比较它们的大小,将较大的数存入32H单元中。XY为正:OV0,则XYOV=1,则XYXY为负:OV0,则XYOV1,则XY ORG0100HMOVA,30H;取初值CLRCSUBBA,31H;XYJZDZ1;X=Y?JC EBBJBOV,EB1;XY0, OV=1,XYAJMPDZ1;XY0, OV=0,XYEBB:JBOV,DZ1;XY0, OV=1,XYEB1:MOVA,31H;XYAJMPJS0DZ1:MOVA,30H;XYJS0:MOV32H,AEND例:设变量x以补码形式存放在片内RAM 30H单元中,变量y与x的关系是:编程根据x的值求y值并放回原单元。2函数运算 ORG 0000HSTART:MOV A,30H JZ NEXT ;x=0,转移 ANL A,#80H ;保留符号位 JZ ED ;x0,转移 MOV A,#05H ;x0,不转移 ADD A,30H MOV 30H,A SJMP ED NEXT:MOV 30H,#20H ED:SJMP $START:MOV DPTR,#TAB MOV A,R7 ADD A,R7 ;R72A MOV R3,A ;暂存R3 MOVC A,A+DPTR ;取高位地址 XCH A ,R3 INC A MOVC A,A+DPTR ;取低位地址 MOV DPL,A MOV DPH,R3 ;转移地址送入DPTR CLR A JMP A+DPTR TAB: DW P0 DW P1 DW PN例:根据R7的内容,转至对应的分支程序。设R7的内容为0N,对应的处理程序地址分别为P0P7 4.3.3 循环程序循环程序一般由: 初始化部分 循环体部分-处理部分、修改部分、控制部分 结束部分其结构一般有两种: 先进入处理部分,再控制循环 至少执行一次循环体 先控制循环,再进入处理部分 循环体是否执行,取决于判断结果。开始设置循环初值循环处理循环修改结束处理结束循环结束?NYYN循环控制的一般方法: 循环次数已知 利用循环次数控制 循环次数未知 利用关键字控制 利用“逻辑尺” 根据“逻辑尺”的内容,进行控制。例:统计数据块的长度 入口条件:内部RAM 30H开始的存储区有若干个数据,最后一个数据为字符FFH,结果存入40H单元。 ORG 0100HMAIN:MOV R1,#30H;R1作为地址指针 CLRA;累加器A作为计数器LOOP:CJNER1,#0FFH,NEXT;与数据FF比较,不等转移 SJMPJSH1;找到结束符号,结束循环NEXT:INC A;计数器加1 INCR1;指针加l SJMP L00P;循环JSHl:INCA ;再加入l个字符 MOV40H,A;存结果 END 4.1.3 延时程序 10.1s延时程序(晶振为12M)ORG 0100HMOV R2,#200LOOP: MOVR3,#250DJNZR3,$DJNZR2,LOOPRET由于采用12M晶振,机器周期为1s,DJNZ的指令周期为2,整个程序的执行时间为25020021s100000s0.1s 21s延时程序(晶振为12M) ORG0100H MOVR1,#10LOOP1:MOVR2,#200LOOP:MOV R3,#250DJNZR3,$DJNZR2,LOOPDJNZR1,LOOP1RET例: 50ms延时子程序。设晶振频率为12MHz,则机器周期为1us。DEL: MOV R7,#200 ;1MCDEL1:MOV R6,#123 ;1MC NOP ;1MC DJNZ R6,$ ;2MC DJNZ R7,DEL1 ;2MC RET ;2MC延时时间:t=1+200(1+1+2*123)+2+2 50000us=50ms4.2 MCS-51常用子程序 4.2.1 代码转换类程序设计 4.2.2 查表程序设计 4.2.3 定点数运算子程序 4.2.4 浮点数运算子程序 子程序问题子程序设计时注意事项:1. 给子程序赋一个名字。实际为入口地址代号。2. 要能正确传递参数: 入口条件:子程序中要处理的数据如何给予。 出口条件:子程序处理结果如何存放。 (寄存器、存储器、堆栈方式)3. 保护与恢复现场: 保护现场:压栈指令PUSH 恢复现场:弹出指令POP4. 子程序可以嵌套 4.2.1 代码转换类程序设计 1单字节十六进制数转换成双字节ASCII码 表4-1 十六进制数与ASCII码之间的关系入口条件:待转换的单字节十六进制数在寄存器R2中。出口:高四位的ASCII码在A中,低四位的ASCII码在B中。 ORG0100H MOVA,R2 MOVB,A ;暂存待转换的单字节十六进制数 LCALLMS1 ;转换低四位 XCHA,B;存放低四位的ASCII码 SWAPA ;准备转换高四位 LCALLMS1 ;转换高四位 SJMP$MS1:ANLA,#0FH;将累加器的低四位转换成 ASCII 码 ADDA,#90H DA A ADDCA,#40H DA A RET将多位十六进制数转换成ASCII码,设R0指向十六进制数低位, R2存放字节数,转换后R1指向ASCII码高位。HTASC: MOV A,R0 ;取十六进制数 ANL A,#0FH ;取低四位 ADD A,#15 ;偏移修正 MOVC A,A+PC ;查表得ASCII码 MOV R1,A ;保存 INC R1 MOV A,R0 ;取十六进制数高四位 SWAP A ; ANL A,#0F0H ADD A,#06H ;偏移修正 MOVC A,A+PC ;查表 MOV R1,A ;保存 INC R0 ;指向下一单元 INC R1 DJNZ R2,HTASC RETASCTAB:DB 30H,31H,32H,33H,34H,35H,36H,37H DB 38H,39H,41H,42H,43H,44H,45H,46H2.ASCII码转换成十六进制数入口条件:待转换的 ASCII 码在R2中。出口:转换后的十六进制数在R3中。ORG 0100HMOV A,R2 SUBB A,#30H CLR C JNB ACC.4,M1 SUBB A,#7M1:MOV R3,A SJMP $END3.十六进制整数转换成单字节码整数 入口条件:待转换的单字节十六进制整数在R2中。出口:转换后的码整数(十位和个位)在R5中,百位在R3中。MOVA,R2HBCD:MOVB,#100;分离出百位,存放在 R3中 DIVAB MOVR3,A MOVA,#10;余数继续分离十位和个位 XCHA,B DIVAB SWAPA ORLA,B ;将十位和个位拼装成码 MOVR5,A SJMP$END4双字节十六进制整数转换成双字节码整数 入口条件:待转换的双字节十六进制整数在R6、R7中。出口:转换后的三字节码整数在R3、R4、R5中。 ORG0100HHB2:CLRA;码初始化 MOVR3,A MOVR4,A MOVR5,A MOV R2,#10H;转换双字节十六进制整数HB3:MOVA,R7 ;从高端移出待转换数的一位到 CY 中 RLCA MOV R7,A MOVA,R6 RLCA MOVR6,A MOVA,R5;码带进位自身相加,相当于乘 ADDCA,R5 DAA ;十进制调整 MOVR5,A MOVA,R4 ADDC A,R4 DAA MOVR4,A MOVA,R3 ADDCA,R3 MOVR3,A;双字节十六进制数的万位数不超过,不用调整 DJNZR2,HB3;判断16位处理完? SJMP$ END5双字节码整数转换成双字节十六进制整数 入口条件:待转换的双字节码整数在R2、R3中。出口:转换后的双字节十六进制整数仍在R2、R3中。 ORG 0100HBH2:MOV A,R3;将低字节转换成十六进制 LCALL BCD1 MOV R3,A MOV A,R2;将高字节转换成十六进制 LCALL BCD1 MOV B,#100;扩大一百倍 MUL AB ADD A,R3;和低字节按十六进制相加 MOV R3,A CLR A ADDCA,B MOV R2,A SJMP $BCD1:MOVB,#10H;分离十位和个位 DIV AB MOV R4,B;暂存个位 MOV B,#10;将十位转换成十六进制 MUL AB ADDA,R4;十六进制加上个位 RET END 4.2.2 查表程序设计 MOVCA,A+DPTRMOVCA,A+PC1查表求ASCII码入口条件:R0低四位有一个十六进制数(0F)。出口:将查表找出的相应ASCII码并送回R0中。ORG0100HMOVA,R0ANLA,#0FH;屏蔽高4位ADDA,#03H;查表指令PC值与表格PC值相差3字节MOVCA,A+PC;查表MOVR0,A;存结果SJMP$ASCTAB:DB0,1,2,3,4,5,6,7DB8,9,A,B,C,D,E,F4.2.3 定点数运算子程序 1多字节码加法 入口条件:字节数在R7中,被加数在30H起始单元中,加数在40H起始单元中。出口:和在30H起始单元中,最高位进位在CY中。ORG 0100HMOV R7,#03HMOV R0,#30HMOV R1,#40HMOV A,R7 ;取字节数至 R2 中 MOV R2,A ADD A,R0;初始化数据指针MOVR0,AMOVA,R2ADDA,R1MOVR1,ACLR CBB1:DECR0;调整数据指针DECR1MOV A,R0ADDC A,R1;按字节相加DAA;十进制调整MOV R0,A;和存回 R0 中DJNZ R2,BB1;处理完所有字节END2多字节码减法入口条件:字节数在 R7 中,被减数在R0 中,减数在 R1 中。出口:差在 R0 中,最高位借位在CY中。 ORG 0100HBCDB:LCALL MN1 ;减数 R1 十进制取补 LCALL BCDA ;按多字节码加法处理 CPL C;将补码加法的进位标志转换成借位标志 MOV F0,C LCALL MN1 ;恢复减数 R1 的原始值 MOV C,F0;恢复借位标志 RETMN1:MOVA,R0 ;R1 十进制取补子程序入口 XCHA,R1;交换指针 XCHA,R0 LCALLNEG;通过 R0 实现 R1 取补 MOVA,R0 XCHA,R1 ;换回指针 XCHA,R0 RETBCDA:MOV A,R7 ;取字节数至 R2 中 MOVR2,A ADDA,R0 ;初始化数据指针 MOVR0,A MOVA,R2 ADDA,R1 MOVR1,A CLRCBCD1:DECR0;调整数据指针 DECR1 MOVA,R0 ADDCA,R1 ;按字节相加 DAA;十进制调整 MOVR0,A;和存回 R0 中 DJNZR2,BCD1;处理完所有字节 RETNEG:MOVA,R7;BCD码取补子程序 DECAMOVR2,AMOVA,R0MOVR3,ANEG0: CLRCMOVA,#99HSUBBA,R0 ;按字节十进制取补MOVR0,A;存回 R0 中INCR0 ;调整数据指针DJNZR2,NEG0 ;处理完( R2 )字节MOVA,#9AH ;最低字节单独取补SUBB A,R0MOVR0,AMOVA,R3 ;恢复指针MOV R0,ARET 4双字节二进制无符号数乘法子程序入口条件:被乘数在R2、R3 中,乘数在R6、R7中。出口:乘积在 R2 、 R3 、 R4 、 R5 中。ORG0100HMULD:MOVA,R3;计算 R3 乘 R7MOVB,R7MULABMOVR4,B ;暂存部分积MOVR5,AMOVA,R3;计算 R3 乘 R6MOVB,R6MULABADDA,R4;累加部分积MOVR4,ACLRA ADDCA,BMOVR3,AMOVA,R2 ;计算 R2 乘 R7MOVB,R7MULABADDA,R4;累加部分积MOVR4,AMOVA,R3ADDCA,BMOVR3,ACLRARLCAXCHA,R2 ;计算 R2 乘 R6MOVB,R6MULABADDA,R3 ;累加部分积MOVR3,AMOVA,R2ADDCA,BMOVR2,ARET6双字节二进制无符号数除法子程序入口条件:被除数在 R2 、 R3 、 R4 、 R5 中,除数在 R6 、 R7 中。出口: OV=0 时,双字节商在 R2 、 R3 中, OV=1 时溢出。ORG 0100HDIVD: CLR C;比较被除数和除数 MOV A,R3 SUBB A,R7 MOV A,R2 SUBB A,R6 JC DVD1 SETB OV ;溢出 RETDVD1:MOVB,#10H;计算双字节商DVD2:CLRC;部分商和余数同时左移一位MOVA,R5RLCAMOVR5,AMOVA,R4RLCAMOVR4,AMOVA,R3RLCAMOVR3,AXCHA,R2RLCAXCHA,R2MOVF0,C ;保存溢出位CLRCSUBBA,R7;计算( R2R3 R6R7 )MOVR1,AMOVA,R2SUBBA,R6ANLC,/F0;结果判断JCDVD3MOVR2,A;够减,存放新的余数MOVA,R1MOVR3,AINCR5;商的低位置一DVD3:DJNZB,DVD2 ;计算完十六位商( R4R5 )MOVA,R4;将商移到 R2R3 中MOVR2,AMOVA,R5MOVR3,ACLROV;设立成功标志RET4.2.4 浮点数运算子程序1浮点数的表示(1)二进制浮点操作数 用三个字节表示,第一个字节的最高位为数符,其余七位为阶码(补码形式),第二字节为尾数的高字节,第三字节为尾数的低字节,尾数用双字节纯小数(原码)来表示。当尾数的最高位为时,便称为规格化浮点数,简称操作数(2)十进制浮点操作数用三个字节表示,第一个字节的最高位为数符,用来表示正负数(0表示正数,1表示负数)其余七位为阶码(二进制补码形式),第二字节为尾数的高字节,第三字节为尾数的低字节,尾数用双字节BCD码纯小数(原码)来表示。当十进制数的绝对值大于时,阶码就等于整数部分的位数。 例如:156.6 的阶码是03H,156.6 的阶码是 83H ;当十进制数的绝对值小于 1 时,阶码就等于 80H 减去小数点后面零的个数。例如 :0.00362的阶码是 7EH ,0.00362 的阶码是 0FEH 。例如:有一个十进制浮点操作数存放在30H、31H、32H中,数值是0.07315,即0.7315 乘以10 的1 次方,则阶码为7FH,若加上数符(30H)=0FFH,31H=73H,(32H)=15H 。 (3)运算精度单次定点运算精度为结果最低位的当量值;单次二进制浮点算术运算的精度优于十万分之三;单次二进制浮点超越函数运算的精度优于万分之一;BCD码浮点数本身的精度比较低(万分之一到千分之一),不宜作为运算的操作数,仅用于输入或输出时的数制转换。不管那种数据格式,随着连续运算的次数增加,精度都会下降。 2浮点数加减法子程序入口条件:被加数在 R0 中,加数在 R1 中。被减数在 R0 中,减数在 R1 中。当F0=0时,程序作浮点数加法运算;当F0=1时,程序作浮点数减法运算。出口: OV=0 时,和(差)仍在 R0 中, OV=1 时,溢出。ORG0100HFADD:CLRF0 ;设立加法标志 SJMPAS ;计算代数和FSUB:SETBF0 ;设立减法标志AS: LCALLMVR1 ;计算代数和。先将 R1 传送到第二工作区 MOVC,F0 ;用加减标志来校正第二操作数的有效符号 RRCA XRLA,R1 MOVC,ACC.7ASN:MOV1EH,C ;将第二操作数的有效符号存入位 1EH 中 XRLA,R0 ;与第一操作数的符号比较 RLCAMOVF0,C ;保存比较结果 LCALLMVR0;将 R0 传送到第一工作区中 LCALLAS1 ;在工作寄存器中完成代数运算MOV0:INCR0 ;将结果传回到 R0 中的子程序入口 INCR0 MOV A,R4 ;传回尾数的低字节 MOVR0,A DECR0 MOVA,R3 ;传回尾数的高字节 MOVR0,A DECR0 MOVA,R2 ;取结果的阶码 MOVC,1FH ;取结果的数符 MOVACC.7,C ;拼入阶码中 MOVR0,A CLRACC.7 ;不考虑数符 CLROV ;清除溢出标志 CJNEA,#3FH,MV01 ;阶码是否上溢? SETBOV ;设立溢出标志MV01:MOVA,R0 ;取出带数符的阶码 RETMVR0:MOVA,R0 ;将 R0 传送到第一工作区中的子程序 MOVC,ACC.7 ;将数符保存在位 1FH 中 MOV 1FH,C MOVC,ACC.6 ;将阶码扩充为补码 MOVACC.7,C MOV R2,A ;存放在 R2 中 INC R0 MOV A,R0 ;将尾数高字节存放在 R3 中 MOV R3,A INC R0 MOV A,R0 ;将尾数低字节存放在 R4 中 MOV R4,A DEC R0 ;恢复数据指针 DEC R0 RETMVR1: MOV A,R1 ;将 R1 传送到第二工作区中的子程序 MOV C,ACC.7 ;将数符保存在位 1EH 中 MOV 1EH,C MOV C,ACC.6 ;将阶码扩充为补码 MOV ACC.7,C MOV R5,A ;存放在 R5 中 INC R1 MOV A,R1 ;将尾数高字节存放在 R6 中MOV R6,A INC R1 MOV A,R1 ;将尾数低字节存放在 R7 中 MOV R7,A DEC R1 ;恢复数据指针 DEC R1 RETAS1: MOV A,R6 ;读取第二操作数尾数高字节 ORL A,R7 JZ AS2 ;第二操作数为零,不必运算 MOV A,R3 ;读取第一操作数尾数高字节 ORL A,R4 JNZ EQ MOV A,R6 ;第一操作数为零,结果以第二操 作数为准 MOV R3,AMOV A,R7MOVR4,AMOV A,R5MOV R2,AMOV C,1EHMOV 1FH,C AS2: RETEQ: MOV A,R2 ;对阶,比较两个操作数的阶码 XRL A,R5JZ AS4 ;阶码相同,对阶结束 JB ACC.7,EQ3 ;阶符互异 MOV A,R2 ;阶符相同,比较大小 CLR C SUBB A,R5JC EQ4EQ2: CLRC ;第二操作数右规一次 MOVA,R6 ;尾数缩小一半 RRCAMOVR6,AMOVA,R7RRCA MOVR7,AINCR5 ;阶码加一 ORLA,R6 ;尾数为零否? JNZEQ ;尾数不为零,继续对阶 MOVA,R2 ;尾数为零,提前结束对阶 MO
- 温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

人人文库网所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。