0169-进入保护模式
2023-08-18 10:44 作者:jiangbo4444 | 我要投稿
环境
Time 2022-11-10
WSL-Ubuntu 22.04
QEMU 6.2.0
NASM 2.15.05
前言
说明
参考:《x86汇编语言:从实模式到保护模式》李忠
目标
从十六位的实模式进入 32 位保护模式。
汇编代码
全局描述符表
lgdt 命令用来加载 GDT,需要给一个地址,该地址就是下面的全局描述表。
全局描述符表 GDT 的地址包含四十八位,低十六位为界限值,高三十二位为物理地址。
GDT 中定义了三个段,第 0 个默认都是 0,第一段定义了显存的位置。
第二段定义了代码段的位置。
A20 地址线
打开 A20 地址线,可以访问更大的内存空间。
打开保护模式
保护模式启动标志在 cr0 寄存器,将最低位的保护模式打开。
三十二位指令
最后使用一个跳转指令,清空加载的 16 位指令,刷新成 32 位指令。下面就是 bits 32 定义的指令。
显示 hello
从 GDT 中获取高速缓存器的内容放入数据段,然后执行输出。
总结
了解了从实模式进入保护模式的方法。