内存分段管理机制

    在CPU启动时,处于实模式,寻址方式:段寄存器<<4 + 偏移地址。段寄存器和偏移地址最长只能为16bit,所以在实模式下,只能访问物理内存开始的1MB地址空间。现在的操作系统所需内存早已超过1MB,所以它必须运行在保护模式下,以获得更大的内存空间。下面来简单介绍下实模式到保护模式的切换。
    保护模式使用的是段式管理模式,从实模式到保护模式的切换就是寻址方式的变换。
    实模式下寻址方式
    movw (0x0010), %ax     #此处实用AT&T汇编语言格式
如果假设ds=0x1000,那么这条指令的作用是将内存0x10000<<4+0x0010=0x10010处一个字的值赋给ax
    保护模式寻址方式:
   

    实模式->保护模式,需要修改CR0、GDTR,及初始化全局描述符表。

 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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值