内存分段管理机制
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
偏移地址。段寄存器和偏移地址最长只能为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
相关文章推荐
- intel 8086的内存分段管理机制
- 深入理解计算机系统-之-内存寻址(三)--分段管理机制(段描述符,段选择子,描述符表)
- 四、保护模式之内存分段管理机制
- 操作系统管理内存的机制,分段,分页
- 全面介绍Windows内存管理机制及C++内存分配实例(二):内存状态查询
- java虚拟机内存管理机制(三):我主管写的一些jvm内存管理知识
- ios内存管理机制
- memcached源码学习-内存管理机制slab allocator
- Android 内存管理机制
- 黑马程序员--Object-C和Swift内存管理机制
- dm8127 内存分配和管理机制
- Java内存管理机制
- 内存管理机制-垃圾回收集器
- 深入了解C#系列:谈谈C#中垃圾回收与内存管理机制
- 初窥Cocos2d-x内存管理机制(1)
- (转).NET Framework 自动内存管理机制深入剖析 (C#分析篇)
- cocos2d-x之初试内存管理机制
- Cocos2d-x 3.x 内存管理机制
- Cocos2d-x 3.1 内存管理机制
- Java内存管理机制