- 1、本文档共111页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第二章80x86汇编语言程序设计ppt课件
1
第二章 80x86汇编语言程序设计
2
第一节 80x86的寻址方式
指令格式:
操作码--应包含操作类型和操作数类型;
操作数--可以是数据或用地址表示。
说明—操作数类型(8/16/32位、有/无符号等)可在操作码或操作数字段中表示(Intel为后者)
存放操作数字段数据的部件:
寄存器、存储器、I/O接口,指令和堆栈。
说明--①寄存器、存储器、I/O接口均独立编址,分别构成从0编址的寄存器空间、存储器空间、I/O空间;
②指令中,堆栈不用地址表示,通过操作码表示。
寻址方式:产生操作数或其有效地址的方法。
3
80x86的寻址方式:
寻址方式
数据所在地址
立即寻址
指令、
寄存器寻址
寄存器、
直接寻址
存储器、I/O
寄存器间接寻址
存储器、I/O
寄存器相对寻址
存储器
基址变址寻址
存储器
基址变址相对寻址
存储器
比例变址寻址
存储器
基址比例变址寻址
存储器
相对基址比例变址寻址
存储器
说明:与比例有关的寻址方式在80386及以后CPU中才出现;
I/O空间和存储器的对应寻址方式表示形式不同。
4
数据所在地
寻址方式结果
备注
指令
数据
译码时取得
寄存器
物理地址
CPU内部定位
存储器
有效地址
PA=有效地址与段寄存器的组合
I/O
物理地址
I/O只有16K空间
堆栈
不按地址访问,用存储器构建
存储器的有效地址(EA)与物理地址(PA):
有效地址—基于段的地址(段内偏移地址);
EA=基址 +(变址*比例因子)+位移量
物理地址—基于存储器空间的地址。
实地址模式的PA=段地址×10H+EA
保护模式的PA=段地址的映像及变换+EA
回9页
5
存储器有效地址生成的相关约定:
组成部分
16位寻址
32位寻址
基址寄存器
BX、BP
任何32位通用寄存器(含ESP)
变址寄存器
SI、DI
除ESP外的任何32位通用寄存器
比例因子
无
1、2、4、8
位移量
0、8、16位
0、8、16、32位
存储器物理地址生成中的相关约定:
a.访存操作选择默认段寄存器规则—
取指操作和相对IP寻址的访存操作—代码段CS,
堆栈操作和用ESP/EBP为基址的访存操作—堆栈段SS,
串处理指令的目的串的访存操作—附加数据段ES,
除堆栈和串处理的除目的串外的访存操作—数据段DS。
回下页
回9页
回13页
6
b.指令中访问非默认段数据方法—段超越
可使用段超越前缀方式指明所访问数据所在的段。
段超越前缀种类:CS:、DS:、SS:、ES:、FS:、GS:。
段超越示例:
MOV AX,[10H] ;DS段10H处的一个字的数据
;赋给AX寄存器
MOV AX,ES:[10H] ;ES段10H处的一个字的数据
;赋给AX寄存器
不允许使用段超越前缀的情况:
(1)串处理指令的目的串必须用ES段;
(2)压栈/出栈指令的目的/源段必须用SS段;
(3)与程序中指令有关的操作必须用CS段。
转上页
7
1、立即寻址
操作数存放在指令中(以常量形式)。
示例:⑴MOV AH, -40 ;0C0H(-40)→AH
⑵MOV AX, 5060H ;50H→AH, 60H→AL
⑶MOV EAX, →EAX
说明:80x86的操作数类型在地址码中表示
应用:适合于对常数的操作。
8
2、寄存器寻址
操作数存放在指令所指定寄存器号的寄存器中。
示例:
MOV AH, BL ;(BL)→AH
MOV DS, AX ;(AX)→DS
MOV SI, AX ;(AX)→SI
MOV ECX, EDX ;(EDX)→ECX
错误示例:
MOV CS, AX
文档评论(0)