- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
IA-32保护模式内存管理小结,环境保护大检查小结,保护环境人人有责小结,环境保护小结,环境保护个人小结,保护环境的小结,县环境保护大检查小结,环境保护个人研究小结,诗歌鉴赏答题模式小结,保护电力设施宣传小结
1.概述
在学习 《Intel 汇编语言程序设计(第四版)》保护模式内存管理部分的时候,感觉该
部分涉及的内容比较多,而且杂,很难一次全部理解清楚,因此针对理解部分做个总结,并
列出暂时不理解的部分。
2.CPU 的工作模式
IA-32 家族的CPU 支持三种工作模式和一种准工作模式:
保护模式
这是从intel 286 引入的工作模式,是286 之后CPU 工作的主要模式,可以使用cpu
的全部特性。
实模式
和intel 8086 完全兼容的工作模式,和8086 相比增强了一些特性,比如可以切换到
保护模式或者系统管理模式
系统管理模式
80386 引入,主要用于操作系统进行电源管理以及OEM 厂商定制。
虚拟8086 模式
执行在保护模式下的一种虚拟8086 工作模式,允许多个任务同时运行。
3.CPU 支持的内存模型
IA-32 主要支持三种内存模型
平面内存模型
每个程序都独享连续的4GB 线性地址空间。多有的代码数据都包含在该空间内。
实际上程序在运行的时候依然存在两个段:代码段和数据段。
段内存模型
将线性地址分割成独立的小内存空间,用来保存对应代码,数据或者堆栈。
这些小的内存空间叫做段。每个程序由不同的段集合组成。所有的段映射到线性地址
空间中。程序通过逻辑地址访问相应的数据,CPU 将逻辑地址转换成对应的物理地址。
逻辑地址由段选择子和一个32 位的偏移量组成。
此时的段保存的是段选择子。
实模式内存模型
采用段+偏移量的模式进行寻址,同DOS 下汇编。此时的段保存的是段的地址。
4. 逻辑地址和线性地址转换
在了解逻辑地址如何转成线性地址前必须弄清如下几个概念:
段描述符
段描述符是一个包含段的位置,大小,访问控制和状态信息的数据结构。
CPU 通过这些信息区访问对应的段。
由上图可以看出一个段描述符占8 个字节。
基地址占32 位,段大小占20 位。
G 标志位表示段大小的单位,如果是0,那么以字节为单位,段最大为1MB。
如果设置为1,那么以4KB 为单位,段最大为4GB 。
GDT,LDT
GDT: Global descriptor table,全局描述符表
LDT: local descriptor table,本地描述符表
内存中的数据结构,用来保存段描述符的表。
每个系统必须有一个GDT 表,用于系统所有程序。LDT 是可选的,可定义定义一个或
者多个
GDT 中第一个段描述符系统不是用,系统保留??
如果系统存在LDT,那么GDT 必须包含指向LDT 的段描述符。
GDTR,LDTR,
IA-32 中包含一系列的内存管理寄存器,他们是GDTR,LDTR,IDTR,TR)
GDTR :GDT 寄存器
该寄存器保存GDT 结构的基地址以及GDT 结构的大小。
该寄存器位长48 位,其中0-15 未表示GDT 大小,16-47 位表示基地址
GDTR 示意图
LDTR: LDT 寄存器
LDTR 寄存器保存16 位的段选择子。32 位的段基地址,段的大小以及其他属
性信息。其示意图如下:
LDTR 保存的应该是16 位的当前LDT 的索引,它指向GDT 表中对应的段描述符。
LDTR 本身应该是16 位的,CPU 在操作系统任务切换的时候,会将当前任务的
LDT 段选择子读取到 LDTR 中,为了提高性能同时也会将LDT 中对应的数据直接读
入到对应的高速缓冲中。( 是否是这么理解?还是所有信息都会存储到LDTR 中?)
因此LDTR 应该指向当前任务的LDT。LDT 和GDT 不同,LDT 本身存储在系统段内,
本身是一个LDT 类型的段,所以这个地方用segment limit ,其实指的应该是LDT 本
身的大小。
LDT,GDT 表中最大数据:因为table limit 和segmen
您可能关注的文档
- 2015考研南开大学在职攻读项目管理硕士入学考试参考资料考研经验.pdf
- 2015考研天津大学仪器仪表工程考试科目考研真题解析考研经验复试线.pdf
- 2015考研南开大学汉硕考研真题解析考研复试线考研经验.pdf
- 2015考研南开大学艺术学复试线考研经验考研真题解析.pdf
- 2015考研天津大学机械工程学院车辆工程考试科目考研真题解析.pdf
- 2015陕西振兴计划招聘考试职位表(渭南市).doc
- 2015考研天津大学电磁场与微波技术考试科目考研真题解析参考书.pdf
- 2015考研天津大学机械工程学院桥梁与隧道工程考试科目考研真题解析.pdf
- 2015考研天津大学精密仪器与光电子工程学院光电子与光子学技术考试科目.pdf
- 2015高三入团申请书.docx
最近下载
- 2025年广西公需科目第二套答案.docx VIP
- 2025最新事业单位招聘考试公共基础知识法律基础知识试题库含答案详解ab卷.docx VIP
- 2025年事业单位招聘考试公共基础知识法律基础知识试题库附答案详解ab卷.docx VIP
- 马克思政治经济学课件.pptx VIP
- 玻璃幕墙技术交底记录(全部).docx VIP
- 干挂石材技术交底.docx VIP
- 2025年公共基础知识试题库附答案附答案详解ab卷.docx VIP
- 微生物实验室质量控制2009.ppt VIP
- 等腰三角形与等边三角形篇(解析版).pdf VIP
- GB 50058-2014 爆炸危险环境电力装置设计规范(附条文说明).pdf VIP
文档评论(0)