《Orange's 一个操作系统的实现》读书手记3(4)--- [ 保护模式(Protect Mode)]

                                                                         保护模式(Protect Mode)  (4)

 3.1.3 实模式到保护模式,不一般的jmp

 

    在前面例程的[SECTION .s16]代码部分,初始化了32位代码段的描述符,即将LABEL_SEG_CODE32的物理地址赋给eax,然后把它分成三部分赋给GDT表中DESC_CODE32的相应位置。DESC_CODE32的段界限和属性在使用Descriptor宏时已经指定。然后将GDT的首地址填充到了GdtPtr里面,执行lgdt [GdtPtr]时把GdtPtr中6个字节的值加载到GDTR寄存器,这样,32位代码段的描述符就已经完完全全地填写好了。

 

    8086只有20位地址总线,即A19-A0,为了访问超过1M的内存,需要打开存储器的A20地址线,IBM使用了8042键盘控制器上的一根线来控制,通过in/out操作8042的控制寄存器即可自由的打开和关闭A20:

    in      al, 92h

    or     al, 00000010b

    out   91h, al

 

    在控制寄存器CR0有一个很重要的位,即第0位,也叫PE(protect enable)位,此位为0时,CPU运行于实模式,为1时,CPU运行于保护模式。执行:

    mov   eax, cr0

    mov   eax, 1

    mov

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值