- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3章 指令系统_1 34页
第3章 指令系统 指令的基本构成 3.1 寻址方式 操作数来源 4 种 指令本身 寄存器 存储器 输入端口 1、立即数(常数) 取值范围如下表: 4、 指令的执行时间 一条指令的执行时间=∑ 寻址方式——寻找操作数的方法 寻找操作数的地址(一般指源操作数) 寻找要执行的下一条指令的地址 在8086指令系统中,说明操作数所在地址的寻址方式可分为8种: ①立即寻址 ⑤ 寄存器相对寻址 ②寄存器寻址 ⑥基址-变址寻址 ③直接寻址 ⑦相对的基址-变址寻址 ④寄存器间接寻址 ⑧隐含寻址 3.1.3 输入输出端口寻址 I/O寻址:直接和间接 1. I/O直接寻址 I/O地址直接在指令中提供 IN AL , 82H ;输入 OUT 80H , AX ;输出 注意:寻址范围为0~255,最大端口号为FFH 2. I/O间接寻址 先在DX寄存器中设置I/O端口地址,指令使用DX寄存器作间寻址 IN AL , DX ;输入 OUT DX , AX ;输出 注意:a.只能使用DX作为间接寻址寄存器,寻址范围为0~65535,最大端口号为FFFFH b.只能使用AX或AL,其他寄存器不行 3.1.4 存储器寻址 有效地址的完整表达式为: EA = 基址 + 变址×比例因子 + 位移量 基址:8086只能使用 BP BX 位移量: 8 或 16 或 32 位的数 变址: 8086只能使用SI DI 比例因子:变址寄存器可乘以一个比例因子,在Pentium系列CPU中使用,8086中没有。 2、 寄存器间接寻址 操作数的偏移地址(有效地址EA)放在寄存器中 只有SI、DI、BX和BP可作间址寄存器 例: MOV AX, [BX] MOV CL, CS:[DI] 错误例 : × MOV AX, [DX] × MOV CL, [AX] 例: MOV AX, [BX+8] MOV CX, TABLE[SI] MOV AX, [BP+1000H] ; 默认段寄存器为SS 指令操作例:MOV AX,DATA[BX] 若(DS)=6000H, (BX)=1000H, DATA=2A00H, (63A00H)=66H, (63A01H)=55H 则物理地址 = 60000H + 1000H + 2A00H = 63A00H 指令执行后:(AX)=5566H (见下页图示) 例: MOV AX, [BX] [SI] MOV AX, [BX+SI] MOV AX, DS: [BP] [DI] 错误例: × MOV AX, [BX] [BP] × MOV AX, [DI] [SI] 小结 寄存器间接、寄存器相对、基址变址、相对基址变址四种寻址方式的比较: 寻址方式 指令操作数形式 寄存器间接 —— 只有一个寄存器(BX/BP/SI/DI之一) 寄存器相对 —— 一个寄存器加上位移量 基址—变址 —— 两个不同类别的寄存器 相对基址-变址 —— 两个不同类别的寄存器加上位移量 与地址有关的寻址 段内直接转移 段内间接转移 段间直接转移 段间间接转移 3.2 指令系统 指令系统: (1)指令向后兼容(x86系列) (2)应用广泛,资料易于寻找 指令按功能分为六大类 (1)数据传送类; (2)算术运算类; (3)逻辑运算和移位; (4)串操作; (5)控制转移类; (6)处理器控制。 部分8086常用指令 6、 隐含寻址 指令操作数是隐含的,在指令中未显式地指明。 例:MUL BL 指令隐含了被乘数AL及乘积AX 类似的指令还有:DIV、CBW、MOVS等 (AL)×(BL)→AX 指令由( )和( )构成 如何取得操作数——称为( ) 操作码 操作数 寻址 寻址方式可分为 立即寻址 直接寻址 寄存器相对寻址 寄存器寻址 基址-变址寻址 基址-变址相对寻址 寄存器间接寻址 存储
文档评论(0)