0169-进入保护模式
环境
- Time 2022-11-10
- WSL-Ubuntu 22.04
- QEMU 6.2.0
- NASM 2.15.05
前言
说明
参考:《x86汇编语言:从实模式到保护模式》李忠
目标
从十六位的实模式进入 32 位保护模式。
汇编代码
jmp start
gdt_info:
dw gdt_end - gdt_start - 1
dd gdt_start + 0x7c00
gdt_start:
dq 0
dd 0x8000ffff
dd 0x0040920b
dd 0x7c0001ff
dd 0x00409800
gdt_end:
start:
lgdt [cs:gdt_info + 0x7c00]
in al,0x92
or al,0000_0010b
out 0x92,al
cli
mov eax,cr0
or eax,1
mov cr0,eax
jmp 10_0_00b:bits32
bits 32
bits32:
mov cx,1_0_00b
mov ds,cx
mov byte [0x00],'h'
mov byte [0x02],'e'
mov byte [0x04],'l'
mov byte [0x06],'l'
mov byte [0x08],'o'
jmp $
times 510 - $ + $$ db 0
db 0x55
db 0xaa
全局描述符表
lgdt 命令用来加载 GDT,需要给一个地址,该地址就是下面的全局描述表。
全局描述符表 GDT 的地址包含四十八位,低十六位为界限值,高三十二位为物理地址。
GDT 中定义了三个段,第 0 个默认都是 0,第一段定义了显存的位置。
第二段定义了代码段的位置。
A20 地址线
打开 A20 地址线,可以访问更大的内存空间。
打开保护模式
保护模式启动标志在 cr0 寄存器,将最低位的保护模式打开。
三十二位指令
最后使用一个跳转指令,清空加载的 16 位指令,刷新成 32 位指令。下面就是 bits 32 定义的指令。
显示 hello
从 GDT 中获取高速缓存器的内容放入数据段,然后执行输出。
总结
了解了从实模式进入保护模式的方法。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2020-07-12 【JavaScript】函数—可重用的代码块
2020-07-12 【JavaScript】循环语句