保护模式(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