- 1、本文档共100页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[工学]第二章 指令系统1
一、指令的组成 操作码说明计算机要执行哪种操作,如传送、运算、移位、跳转等操作,它是指令中不可缺少的组成部分 二、指令的助记符格式 操作数2:常被称为源操作数src,它表示参与指令操作的一个对象 操作数1:常被称为目的操作数dest,它不仅可以作为指令操作的一个对象,还可以用来存放指令操作的结果; dest OP src dest 分号后的内容是对指令的解释 有些指令中隐含了第一操作数,如:MUL CL 三、指令的操作码和操作数 每种指令的操作码: 用一个助记符表示(指令功能的英文缩写) 对应着机器指令的一个或多个二进制编码 指令中的操作数: 可以是一个具体的数值 可以是存放数据的寄存器 或指明数据在主存位置的存储器地址 2.2 操作数的寻址方式 指令系统设计了多种操作数的来源 寻找操作数的过程就是操作数的寻址 把寻找操作数的方式叫做(操作数)寻址方式 理解操作数的寻址方式是理解指令功能的前提 操作数采取哪一种寻址方式 一方面,会影响处理器执行指令的速度和效率 另一方面,对程序设计也很重要 8086/8088CPU的寻址方式 1 立即数寻址方式 指令中的操作数直接存放在机器代码中,紧跟在操作码之后(操作数作为指令的一部分存放在操作码之后的主存单元中) 这种操作数被称为立即数imm 可以是8位数值i8(00H~FFH) 也可以是16位数值i16(0000H~FFFFH) 立即数寻址方式常用来给寄存器和存储单元赋值,多以常量形式出现 立即数寻址方式 例: 将立即数0102H送至AX寄存器 汇编指令: MOV AX,0102H ; 指令功能: AX←0102H ; 指令代码:B8 02 01 说明: 立即数寻址方式常用来给寄存器和存储单元赋初值。 在汇编语言中,立即数是以常量形式出现的。常量可以是: (1)二进制数(后缀字母B或b) (2)十进制数(不用后缀字母,或者用D或d) (3)16进制数(后缀字母H或h,以A-F开头则要加 个0) (4)字符串(用单或双引号括起的字符,表示对应 的ASCII码值,例如:‘A’=41H) (5)标识符表示的符号常量、数值表达式 (符号常量通过汇编伪指令定义) 2 寄存器寻址方式 操作数存放在CPU的内部寄存器reg中: 8位寄存器r8: AH、AL、BH、BL、CH、CL、DH、DL 16位寄存器r16: AX、BX、CX、DX、SI、DI、BP、SP 4个段寄存器seg: CS、DS、SS、ES 寄存器名表示其内容(操作数) 寄存器寻址方式 说明: 寄存器寻址方式的操作数存放于CPU的某个内部寄存器中,不需要访问存储器,因而执行速度较快,是经常使用的方法。在双操作数的指令中,操作数之一必是寄存器寻址得到的。 3 存储器寻址方式 操作数在主存储器中,用主存地址表示 程序设计时,8088采用逻辑地址表示主存地址 段地址在默认的或用段超越前缀指定的段寄存器中 指令中只需给出操作数的偏移地址(有效地址EA) 1)直接寻址方式 直接寻址方式的有效地址在指令中直接给出 默认的段地址在DS段寄存器,可使用段超越前缀改变 用中括号包含有效地址,表达存储单元的内容 直接寻址方式 例: 将数据段中偏移地址2000H处的内存数据送至AX寄存器 汇编指令: MOV AX, [2000H] 指令功能:AX←DS : [ 2000H ] 指令代码:A1 00 20 注意区别: MOV AX, 2000H 例: 将附加段中偏移地址2000H处的内存数据送至AX寄存器 MOV AX, ES:[2000H] ;段超越前缀; 指令功能:AX←ES : [ 2000H ]; 指令代码:26 A1 00 20;双字节操作码 例: 将数据段的变量WVAR(即该变量名指示的内存单元数据)送至 AX寄存器 变量指示内存的一个数据,直接引用变量名就是采用直接寻址方式 变量应该在数据段进行定义,常用的变量定义伪指令 DB和 DW分别表示定义字节变量和字变量 变量一经定义便具有逻辑地址和类型属性 例: 例如:WVAR DW 1234H ;定义字变量WVAR,它具有初值1234H MOV AX,WVAR ;指令功能:AX←WVAR 假设WVAR的偏移地址为0010H,所以上条指令实质就是如下指令: MOV AX, [0010H]; AX 1234H ; 指令功能:AX←DS : [ 0010H ], 指令代码:A1 10 00 2)寄存器间接寻址方式 有效地址存放在基址寄存器BX、BP或变址寄存器SI、DI中 默认的段地址在DS段寄存器,可使用段超越前缀改变 例: 将数据段中由BX指定偏移地址处的内存数据送至 AX寄存器 汇编指令
文档评论(0)