- 1、本文档共92页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
符号指令及其注释中常用符号
3.1 指令格式及常用符号;3.1 指令格式及常用符号;高5位为操作码,低3位为存放操作数的寄存器编码。如:MOV A,R0
编码为1110 1000B,其十六进制表示为E8H(低3位000为寄存器R0的编码)。功能是将当前工作寄存器R0中的数据传送到累加器A中。 ;二、双字节指令;三、三字节指令;3.1.2 符号指令的格式; 如:ANL A,#40H
功能是将立即数“40H”同累加器A中的数进行“与”操作,结果送回累加器。
ANL为“与”操作的助记符,立即数“40H”为源操作数,累加器A为目的操作数。;3.1.3 符号指令及其注释中常用的符号;addr11-----------11位目的地址;
addr16-----------16位目的地址;
rel-----------------补码形式表示的8位地址偏移量,值在-128~+127范围内;
bit----------------片内RAM位地址、SFR的位地址(可用符号名称表示);
/-------------------位操作数的取反操作前缀;
(×)----------- 表示 × 地址单元或寄存器中的内容;
← ----------------将箭头右边的内容送入箭头左边的单元中。;3.2 80C51的寻址方式; 操作数存放在寄存器中,指令中直接给出该寄存器名称的寻址方式。可以获得较高的传送和运算速度。; 指令操作码之后的字节存放的是操作数的地址,操作数本身存放在该地址指示的存储单元中的寻址方式称为直接寻址。; 寄存器中的内容为地址,从该地址去取操作数的寻址方式称为寄存器间接寻址 。;寄存器间接寻址对应的空间为:
片内RAM(采用@R0,@R1或SP);
片外RAM(采用@R0,@R1或@DPTR)。 ; 指令编码中直接给出操作数的寻址方式称为立即寻址。在这种寻址方式中,紧跟在操作码之后的操作数称为立即数。立即数可以为一个字节,也可以是两个字节,并要用符号“#”来标识。由于立即数是一个常数,所以只能作为源操作数。
立即寻址所对应的寻址空间为:ROM ; 以一个基地址加上一个偏移量地址形成操作数地址的寻址方式称为变址寻址。在这种寻址方式中,以数据指针DPTR或程序计数器PC作为基址寄存器,累加器A作为偏移量寄存器,基址寄存器的内容与偏移量寄存器的内容之和作为操作数地址。
变址寻址所对应的寻址空间为:ROM; 相对寻址是以程序计数器PC的当前值(指读出该2字节或3字节的跳转指令后,PC指向的下条指令的地址)为基准,加上指令中给出的相对偏移量 rel 形成目标地址的寻址方式 。
rel 是一个带符号的8位二进制数,取值范围是-128~+127,以补码形式置于操作码之后存放。; 对位地址中的内容进行操作的寻址方式称为位寻址。采用位寻址指令的操作数是8位二进制数中的某一位。指令中给出的是位地址。位寻址方式实质属于位的直接寻址。
寻址空间为:片内RAM的20H~2FH单元中的128可寻址位;SFR的可寻址位。;3.3 数据传送类指令(29条);3.3.1 一般传送指令
;一、16位传送;二、8位传送;1.以A为目的;2.以Rn 为目的;3.以direct 为目的;4.以@Ri为目的;3.3.2 特殊传送指令;一、ROM查表 ;二、读写片外RAM ;第二条指令以R0或R1为间址寄存器,也可以读整个64K字节的片外RAM空间。指令执行时,低8位地址在R0或R1中由P0口分时输出,ALE信号将地址信息锁存在地址锁存器中(多于256字节的访问,高位地址由P2口提供)。;2.写片外RAM; 第二条指令以R0或R1为间址寄存器,也可以写整个64K字节的片外RAM空间。指令执行时,低8位地址在R0或R1中由P0口分时输出,ALE信号将地址信息锁存在地址锁存器中(多于256字节的访问,高位地址由P2口提供)。;三、堆栈操作;四、数据交换;2.半字节交换 ;3.4 算术运算类指令(24条); ; ;例 若(A)=84H,(30H)=8DH,执行指令 ADD A,30H 之后,由于: ;二、带进位加 ;三、增1;四、十进制调整; 调整要完成的任务是:;例 若(A)=0101 0110B,表示的BCD码为,(R2)=0110 0111B,表示的BCD码为,(CY)=0。执行以下指令:
ADD A,R2
DA A
由于(A)=0010 0011B,即,且(CY)=1,即;3.4.2 减法;例 若(A)=C9H,(R2)=54H,(CY)=1,执行指令 SUBB A,R2 之后,由于: ;二
文档评论(0)