IA-32 Intel手册学习笔记(二)保护模式下的内存管理

本文详细介绍了IA-32架构下保护模式的内存管理,包括分段机制和分页机制。分段提供了代码、数据和栈的隔离,而分页则实现了虚拟内存系统。分段由段选择符和偏移量组成逻辑地址,通过段描述符转换为线性地址。分页通过页目录和页表将线性地址映射到物理地址,提供虚拟内存环境。
摘要由CSDN通过智能技术生成

内存管理概述(Memory Management Overview)

Inter体系结构的内存管理可分为两部分:分段和分页。

  • 分段提供了一种机制,这种机制可以为每个程序或者任务提供单独的代码、数据和栈模块,这就保证了多个进程或者任务能够在同一个处理器上运行而不互相干扰。
  • 分页机制提供了虚拟内存系统,在这种系统中,程序的执行代码按需要被映射到物理内存中。分页机制同样可以用来隔离多个任务。
  • 在保护模式下,分段机制是必须的,分页机制是可选的

分段机制将处理器可寻址空间(即线性空间)分成若干个较小的受保护的地址空间段。段可以用来装载程序的代码,数据或者堆栈,也可以用来装载系统的数据结构(如TSS、LDT等)。当处理器上运行多个进程时,操作系统为每个进程分配属于它自己的段,同时处理器会规定这些段的边界,保证一个进程不会对另一个进程的段进行读写造成干扰。

系统中所有的段都在处理器的线性地址空间内,但是只有逻辑地址才能确定一个字节在特定段中的位置。所以在实际程序访问内存时,需要有某种机制将逻辑地址映射到线性地址。逻辑地址由段选择符和偏移量组成。通过段选择符,可以在全局/局部描述符表(GDT/LDT)中唯一定位一个段描述符,每个段描述符记录一个段在线性地址空间的基地址,然后通过和偏移量相加,得到实际的线性地址。

在保护模式下,段选择符其实就是CS寄存器,是16位的。偏移量是EIP寄存器,是32位的。上述过程其实就是将CS中16位的逻辑地址映射成32位的线性地址。

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值