ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:23.69KB ,
资源ID:21841950      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/21841950.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(51单片机汇编语句基础学习知识Word文件下载.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

51单片机汇编语句基础学习知识Word文件下载.docx

1、B累加器B。用于乘法和除法指令中。C进位标志位。(x)某地址单元中的内容。(x)由X寻址单元中的内容。MCS-51的寻址方式寻址的“地址”即为操作数所在单元的地址,绝大部分指令执行时都需要用到操作数,那么到哪里去取得操作数呢?最易想到的就是告诉CPU操作数所在的地址单元,从那里可取得响应的操作数,这便是“寻址”之意。MCS-51的寻址方式很多,使用起来也相当方便,功能也很强大,灵活性强。这便是MCS-51指令系统“好用”的原因之一。下面我们分别讨论几种寻址方式的原理。1.直接寻址指令中操作数直接以单元地址形式出现,例如:MOV A,68H这条指令的意义是把内部RAM中的68H单元中的数据内容传

2、送到累加器A中。值得注意的是直接寻址方式只能使用8位二进制地址,因此这种寻址方式仅限于内部RAM进行寻址。低128位单元在指令中直接以单元地址的形式给出。对于特殊功能寄存器可以使用其直接地址进行访问,还可以以它们的符号形式给出,只是特殊功能寄存器只能用直接寻址方式访问,而无其它方法。2.寄存器寻址寄存器寻址对选定的8个工作寄存器R0-R7进行操作,也就是操作数在寄存器中,因此指定了寄存器就得到了操作数,寄存器寻址的指令中以寄存器的符号来表示寄存器,例如:MOV A,R1这条指令的意义是把所用的工作寄存器组中的R3的内容送到累加器A中。值得一提的是工作状态寄存器的选择是通过程序状态字寄存器来控制

3、的,在这条指令前,应通过PSW设定当前工作寄存器组。3.寄存器间接寻址寄存器寻址方式,寄存器中存放的是操作数,而寄存器间接寻址方式,寄存器中存放的则为操作数的地址,也即操作数是通过寄存器指向的地址单元得到的,这便是寄存器间接寻址名称的由来。例如指令:MOV A,R0这条指令的意义是R0寄存器指向地址单元中的内容送到累加器A中。假如R0=#56H,那么是将56H单元中的数据送到累加器A中。寄存器间接寻址方式可用于访问内部RAM或外部数据存储器。访问内部RAM或外部数据存储器的低256字节时,可通过R0和R1作为间接寄存器。然而有必要指出,内部RAM的高128字节地址与专用积存器的地址是重叠的,所

4、以这种寻址方式不能用于访问特殊功能寄存器。外部数据存储器的空间为64kB,这时可采用DPTR作为间址寄存器进行访问,指令如下:MOVX A,DPTR这条指令的意义是与上述类似,不再赘述。4.立即寻址立即寻址就是把操作数直接在指令中给出,即操作数包含在指令中,指令操作码的后面紧跟着操作数,一般把指令中的操作数称为立即数,因此而得名。为了与直接寻址方式相区别,在立即数前加上“#”符号,例如:MOVX A,#0EH这条指令的意义是将0EH这个操作数送到累加器A中。5.变址寻址变址寻址是以DPTR或PC作为基址寄存器,以累加器A作为变址寄存器,将两寄存器的内容相加形成16位地址形成操作数的实际地址。例

5、如:MOV A,A+DPTRMOVX A,A+PCJMP A+DPTR在这三条指令中,A作为偏移量寄存器,DPTR或PC作为变址寄存器,A作为无符号数与DPTR或PC的内容相加,得到访问的实际地址。其中前两条是程序存储器读指令,后一条是无条件转移指令。6.位寻址在MCS-51单片机中,RAM中的20H2FH字节单元对应的位地址为00H7FH,特殊功能寄存器中的某些位也可进行为寻址,这些单元既可以采用字节方式访问它们,也可采用位寻址的方式访问它们。7.相对寻址相对寻址方式是为了程序的相对转移而设计的,其夜里是以PC的内容为基址,加上给出的偏移量作为转移地址,从而实现程序的转移。转移的目的地址可参

6、见如下表达式:目的地址=转移指令地址+转移指令字接数+偏移量值得注意的是,偏移量是有正负号之分的,偏移量的取值范围是当前PC值的-128+127之间。MCS-51数据传送指令数据传送指令共有29条,数据传送指令一般的操作是把源操作数传送到目的操作数,指令执行完成后,源操作数不变,目的操作数等于源操作数。如果要求在进行数据传送时,目的操作数不丢失,则不能用直接传送指令,而采用交换型的数据传送指令,数据传送指令不影响标志C,AC和OV,但可能会对奇偶标志P有影响。1. 以累加器A为目的操作数类指令(4条)这4条指令的作用是把源操作数指向的内容送到累加器A。有直接、立即数、寄存器和寄存器间接寻址方式

7、:MOV A,data ;(data)(A)直接单元地址中的内容送到累加器AMOV A,#data ;#data(A)立即数送到累加器A中MOV A,Rn ;(Rn)(A) Rn中的内容送到累加器A中MOV A,Ri ;(Ri)(A) Ri内容指向的地址单元中的内容送到累加器A2. 以寄存器Rn为目的操作数的指令(3条)这3条指令的功能是把源操作数指定的内容送到所选定的工作寄存器Rn中。有直接、立即和寄存器寻址方式:MOV Rn,data ;(data)(Rn)直接寻址单元中的内容送到寄存器Rn中MOV Rn,#data ;#data(Rn)立即数直接送到寄存器Rn中MOV Rn,A ;(A)

8、(Rn)累加器A中的内容送到寄存器Rn中3. 以直接地址为目的操作数的指令(5条)这组指令的功能是把源操作数指定的内容送到由直接地址data所选定的片内RAM中。有直接、立即、寄存器和寄存器间接4种寻址方式:MOV data,data ;(data)(data)直接地址单元中的内容送到直接地址单元MOV data,#data ;#data(data)立即数送到直接地址单元MOV data,A ;(A)(data)累加器A中的内容送到直接地址单元MOV data,Rn ;(Rn)(data)寄存器Rn中的内容送到直接地址单元MOV data,Ri ;(Ri)(data)寄存器Ri中的内容指定的地

9、址单元中数据送到直接地址单元4. 以间接地址为目的操作数的指令(3条)这组指令的功能是把源操作数指定的内容送到以Ri中的内容为地址的片内RAM中。有直接、立即和寄存器3种寻址方式:MOV Ri,data ;(data)(Ri)直接地址单元中的内容送到以Ri中的内容为地址的RAM单元MOV Ri,#data ;#data(Ri)立即数送到以Ri中的内容为地址的RAM单元MOV Ri,A ;(A)(Ri)累加器A中的内容送到以Ri中的内容为地址的RAM单元5. 查表指令(2条)这组指令的功能是对存放于程序存储器中的数据表格进行查找传送,使用变址寻址方式:MOVC A,A+DPTR ;(A)+(DP

10、TR)(A)表格地址单元中的内容送到累加器A中MOVC A,A+PC ;(PC)+1(A),(A)+(PC)(A)表格地址单元中的内容送到累加器A中6. 累加器A与片外数据存储器RAM传送指令(4条)这4条指令的作用是累加器A与片外RAM间的数据传送。使用寄存器寻址方式:MOVX DPTR,A ;(A)(DPTR)累加器中的内容送到数据指针指向片外RAM地址中MOVX A, DPTR ;(DPTR)(A)数据指针指向片外RAM地址中的内容送到累加器A中MOVX A, Ri ;(Ri)(A)寄存器Ri指向片外RAM地址中的内容送到累加器A中MOVX Ri,A ;(A)(Ri)累加器中的内容送到寄

11、存器Ri指向片外RAM地址中7. 堆栈操作类指令(2条)这4类指令的作用是把直接寻址单元的内容传送到堆栈指针SP所指的单元中,以及把SP所指单元的内容送到直接寻址单元中。这类指令只有两条,下述的第一条常称为入栈操作指令,第二条称为出栈操作指令。需要指出的是,单片机开机复位后,(SP)默认为07H,但一般都需要重新赋值,设置新的SP首址。入栈的第一个数据必须存放于SP+1所指存储单元,故实际的堆栈底为SP+1所指的存储单元。PUSH data ;(SP)+1(SP),(data)(SP)堆栈指针首先加1,直接寻址单元中的数据送到堆栈指针SP所指的单元中POP data ;(SP)(data)(S

12、P)-1(SP),堆栈指针SP所指的单元数据送到直接寻址单元中,堆栈指针SP再进行减1操作8. 交换指令(5条)这5条指令的功能是把累加器A中的内容与源操作数所指的数据相互交换。XCH A,Rn ;(A)(Rn)累加器与工作寄存器Rn中的内容互换XCH A,Ri ;(A)(Ri)累加器与工作寄存器Ri所指的存储单元中的内容互换XCH A,data ;(A)(data)累加器与直接地址单元中的内容互换XCHD A,Ri ;(A3-0)(Ri)3-0)累加器与工作寄存器Ri所指的存储单元中的内容低半字节互换SWAP A ;(A3-0)(A7-4)累加器中的内容高低半字节互换9. 16位数据传送指令

13、(1条)这条指令的功能是把16位常数送入数据指针寄存器。MOV DPTR,#data16 ;#dataH(DPH),#dataL(DPL)16位常数的高8位送到DPH,低8位送到DPLMCS-51算术运算指令算术运算指令共有24条,算术运算主要是执行加、减、乘、除法四则运算。另外MCS-51指令系统中有相当一部分是进行加、减1操作,BCD码的运算和调整,我们都归类为运算指令。虽然MCS-51单片机的算术逻辑单元ALU仅能对8位无符号整数进行运算,但利用进位标志C,则可进行多字节无符号整数的运算。同时利用溢出标志,还可以对带符号数进行补码运算。需要指出的是,除加、减1指令外,这类指令大多数都会对

14、PSW(程序状态字)有影响。这在使用中应特别注意。1. 加法指令(4条)这4条指令的作用是把立即数,直接地址、工作寄存器及间接地址内容与累加器A的内容相加,运算结果存在A中。ADD A,#data ;(A)+#data(A)累加器A中的内容与立即数#data相加,结果存在A中ADD A,data ;(A)+(data)(A)累加器A中的内容与直接地址单元中的内容相加,结果存在A中ADD A,Rn ;(A)+(Rn)(A)累加器A中的内容与工作寄存器Rn中的内容相加,结果存在A中ADD A,Ri ;(A)+(Ri)(A)累加器A中的内容与工作寄存器Ri所指向地址单元中的内容相加,结果存在A中2.

15、 带进位加法指令(4条)这4条指令除与1功能相同外,在进行加法运算时还需考虑进位问题。ADDC A,data ;(A)+(data)+(C)(A)累加器A中的内容与直接地址单元的内容连同进位位相加,结果存在A中ADDC A,#data ;(A)+#data +(C)(A)累加器A中的内容与立即数连同进位位相加,结果存在A中ADDC A,Rn ;(A)+Rn+(C)(A)累加器A中的内容与工作寄存器Rn中的内容、连同进位位相加,结果存在A中ADDC A,Ri ;(A)+(Ri)+(C)(A)累加器A中的内容与工作寄存器Ri指向地址单元中的内容、连同进位位相加,结果存在A中3. 带借位减法指令(4

16、条)这组指令包含立即数、直接地址、间接地址及工作寄存器与累加器A连同借位位C内容相减,结果送回累加器A中。这里我们对借位位C的状态作出说明,在进行减法运算中,CY=1表示有借位,CY=0则无借位。OV=1声明带符号数相减时,从一个正数减去一个负数结果为负数,或者从一个负数中减去一个正数结果为正数的错误情况。在进行减法运算前,如果不知道借位标志位C的状态,则应先对CY进行清零操作。SUBB A,data ;(A)-(data) - (C)(A)累加器A中的内容与直接地址单元中的内容、连同借位位相减,结果存在A中SUBB A,#data ;(A)-#data -(C)(A)累加器A中的内容与立即数

17、、连同借位位相减,结果存在A中SUBB A,Rn ;(A)-(Rn) -(C)(A)累加器A中的内容与工作寄存器中的内容、连同借位位相减,结果存在A中SUBB A,Ri ;(A)-(Ri) -(C)(A)累加器A中的内容与工作寄存器Ri指向的地址单元中的内容、连同借位位相减,结果存在A中4. 乘法指令(1条)这个指令的作用是把累加器A和寄存器B中的8位无符号数相乘,所得到的是16位乘积,这个结果低8位存在累加器A,而高8位存在寄存器B中。如果OV=1,说明乘积大于FFH,否则OV=0,但进位标志位CY总是等于0。MUL AB ;(A)(B)(A)和(B)累加器A中的内容与寄存器B中的内容相乘,

18、结果存在A、B中5. 除法指令(1条)这个指令的作用是把累加器A的8位无符号整数除以寄存器B中的8位无符号整数,所得到的商存在累加器A,而余数存在寄存器B中。除法运算总是使OV和进位标志位CY等于0。如果OV=1,表明寄存器B中的内容为00H,那么执行结果为不确定值,表示除法有溢出。DIV AB ;(A)(B)(A)和(B)累加器A中的内容除以寄存器B中的内容,所得到的商存在累加器A,而余数存在寄存器B中。6. 加1指令(5条)这5条指令的的功能均为原寄存器的内容加1,结果送回原寄存器。上述提到,加1指令不会对任何标志有影响,如果原寄存器的内容为FFH,执行加1后,结果就会是00H。这组指令共

19、有直接、寄存器、寄存器减间址等寻址方式:INC A ;(A)+1(A)累加器A中的内容加1,结果存在A中INC data ;(data)+1(data)直接地址单元中的内容加1,结果送回原地址单元中INC Ri ;(Ri)+1(Ri)寄存器的内容指向的地址单元中的内容加1,结果送回原地址单元中INC Rn ;(Rn)+1(Rn)寄存器Rn的内容加1,结果送回原地址单元中INC DPTR ;(DPTR)+1(DPTR)数据指针的内容加1,结果送回数据指针中在INC data这条指令中,如果直接地址是I/O,其功能是先读入I/O锁存器的内容,然后在CPU进行加1操作,再输出到I/O上,这就是“读修

20、改写”操作。7. 减1指令(4条)这组指令的作用是把所指的寄存器内容减1,结果送回原寄存器,若原寄存器的内容为00H,减1后即为FFH,运算结果不影响任何标志位,这组指令共有直接、寄存器、寄存器间址等寻址方式,当直接地址是I/O口锁存器时,“读修改写”操作与加1指令类似。DEC A ;(A)-1(A)累加器A中的内容减1,结果送回累加器A中DEC data ;(data)-1(data)直接地址单元中的内容减1,结果送回直接地址单元中DEC Ri ;(Ri)-1(Ri)寄存器Ri指向的地址单元中的内容减1,结果送回原地址单元中DEC Rn ;(Rn)-1(Rn)寄存器Rn中的内容减1,结果送回

21、寄存器Rn中8. 十进制调整指令(1条)在进行BCD码运算时,这条指令总是跟在ADD或ADDC指令之后,其功能是将执行加法运算后存于累加器A中的结果进行调整和修正。DA AMCS-51逻辑运算及移位指令逻辑运算和移位指令共有25条,有与、或、异或、求反、左右移位、清0等逻辑操作,有直接、寄存器和寄存器间址等寻址方式。这类指令一般不影响程序状态字(PSW)标志。1. 循环移位指令(4条)这4条指令的作用是将累加器中的内容循环左或右移一位,后两条指令是连同进位位CY一起移位。RL A ;累加器A中的内容左移一位RR A ;累加器A中的内容右移一位RLC A ;累加器A中的内容连同进位位CY左移一位

22、RRC A ;累加器A中的内容连同进位位CY右移一位2. 累加器半字节交换指令(1条)这条指令是将累加器中的内容高低半字节互换,这在上一节中内容已有介绍。 累加器中的内容高低半字节互换3. 求反指令(1条)这条指令将累加器中的内容按位取反。CPL A ; 累加器中的内容按位取反4. 清零指令(1条)这条指令将累加器中的内容清0。CLR A ; 0(A),累加器中的内容清05. 逻辑与操作指令(6条)这组指令的作用是将两个单元中的内容执行逻辑与操作。如果直接地址是I/O地址,则为“读修改写”操作。ANL A,data ;累加器A中的内容和直接地址单元中的内容执行与逻辑操作。结果存在寄存器A中。A

23、NL data,#data ;直接地址单元中的内容和立即数执行与逻辑操作。结果存在直接地址单元中。ANL A,#data ;累加器A的内容和立即数执行与逻辑操作。结果存在累加器A中。ANL A,Rn ;累加器A的内容和寄存器Rn中的内容执行与逻辑操作。ANL data,A ;直接地址单元中的内容和累加器A的内容执行与逻辑操作。ANL A,Ri ;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行与逻辑操作。6. 逻辑或操作指令(6条)这组指令的作用是将两个单元中的内容执行逻辑或操作。ORL A,data ;累加器A中的内容和直接地址单元中的内容执行逻辑或操作。ORL data,#data

24、 ;直接地址单元中的内容和立即数执行逻辑或操作。ORL A,#data ;累加器A的内容和立即数执行逻辑或操作。ORL A,Rn ;累加器A的内容和寄存器Rn中的内容执行逻辑或操作。ORL data,A ;直接地址单元中的内容和累加器A的内容执行逻辑或操作。ORL A,Ri ;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行逻辑或操作。7. 逻辑异或操作指令(6条)这组指令的作用是将两个单元中的内容执行逻辑异或操作。XRL A,data ;累加器A中的内容和直接地址单元中的内容执行逻辑异或操作。XRL data,#data ;直接地址单元中的内容和立即数执行逻辑异或操作。XRL A,#

25、data ;累加器A的内容和立即数执行逻辑异或操作。XRL A,Rn ;累加器A的内容和寄存器Rn中的内容执行逻辑异或操作。XRL data,A ;直接地址单元中的内容和累加器A的内容执行逻辑异或操作。XRL A,Ri ;累加器A的内容和工作寄存器Ri指向的地址单元中的内容执行逻辑异或操作。MCS-51控制转移指令控制转移指令用于控制程序的流向,所控制的范围即为程序存储器区间,MCS-51系列单片机的控制转移指令相对丰富,有可对64kB程序空间地址单元进行访问的长调用、长转移指令,也有可对2kB字节进行访问的绝对调用和绝对转移指令,还有在一页范围内短相对转移及其它无条件转移指令,这些指令的执行一般都不会对标志位有影响。1. 无条件转移指令(4条)这组指令执行完后,程序就会无条件转移到指令所指向的地址上去。长转移指令访问的程序存储器空间为16地址64kB,绝对转移指令访问的程序存储器空间为11

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1