您的位置:首页 > 其它

内存分段管理机制

2013-10-12 17:24 253 查看
在CPU启动时,处于实模式,寻址方式:段寄存器<<4 +
偏移地址。段寄存器和偏移地址最长只能为16bit,所以在实模式下,只能访问物理内存开始的1MB地址空间。现在的操作系统所需内存早已超过1MB,所以它必须运行在保护模式下,以获得更大的内存空间。下面来简单介绍下实模式到保护模式的切换。

保护模式使用的是段式管理模式,从实模式到保护模式的切换就是寻址方式的变换。
实模式下寻址方式
movw (0x0010), %ax

#此处实用AT&T汇编语言格式

如果假设ds=0x1000,那么这条指令的作用是将内存0x10000<<4+0x0010=0x10010处一个字的值赋给ax
保护模式寻址方式:

实模式->保护模式,需要修改CR0、GDTR,及初始化全局描述符表。
CR0格式参见http://blog.sina.com.cn/s/blog_85998e38010122wq.html

GDTR








limit 16bit.说明GDT占用的最大内存,单位byte。就是说一个GDT的大小不会超过256B。
base address,GDT在虚拟地址空间中的基地址。

GDT 表格式









GDT的第一项为0,可能这与null selector对应。从第二项开始使用。
long mode
L=1 64bit mode,灰色域被忽略,段地址全为0.
L=0 兼容模式,base address和segment
limit都有效。

CS
从实模式进入保护模式:
LGDT
CR0.PE=1
从保护模式进入实模式:
CR0.PE=0
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: