学习笔记
使用教材(配书源码以及使用方法)
《一个64位操作系统的设计与实现》
http://www.ituring.com.cn/book/2450
https://www.jianshu.com/p/28f9713a9171
使用源码
[OS64位][002]源码阅读:程序3-1 boot.asm 主引导扇区程序,显示字符串
https://www.jianshu.com/p/8bbeb6e8e03f
解决问题
- 验证
org 0x7c00
对标号StartBootMessage 最终数值的影响
调试记录 (org 0x7c00)
1、使用nasm生成源码的.lst
文件
[anno@localhost Desktop]$ nasm boot.asm -o boot.bin -l boot.lst
2 、在.lst
文件中找到标号StartBootMessage 读出字节数是 0x0043
3、打开bochs
[anno@localhost Desktop]$ bochs -f ./bochsrc
输入 6
按下【回车键】
现在要进行调试,而不是直接查看结果,我们需要继续输入的不是命令c,而是命令s,表示单步执行
4、开始bochs调试
(1)s 进入单步调试
(2)b 设置断点 到0x7c00
(3)c 直接运行到断点处
(4)sreg 查看全部段寄存器的数值,发现全部自动清零
(5)u 反汇编代码,查看标号最终被解释成的数值
读出00007c36: ( ): mov bp, 0x7c43 ; bd437c
0x7c43 = 0x7c00+0x0043
正是org 0x7c00
与标号代表字节数
共同作用的结果
bochs 调试过程(1)~(5)
<bochs:1> s
Next at t=1
(0) [0x0000000fe05b] f000:e05b (unk. ctxt): xor ax, ax ; 31c0
<bochs:2> b 0x7c00
<bochs:3> c
(0) Breakpoint 1, 0x0000000000007c00 in ?? ()
Next at t=14040250
(0) [0x000000007c00] 0000:7c00 (unk. ctxt): mov ax, cs ; 8cc8
<bochs:4> sreg
es:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
cs:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
ss:0x0000, dh=0x00009300, dl=0x0000ffff, valid=7
Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
ds:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
fs:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
gs:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
ldtr:0x0000, dh=0x00008200, dl=0x0000ffff, valid=1
tr:0x0000, dh=0x00008b00, dl=0x0000ffff, valid=1
gdtr:base=0x00000000000fa1f7, limit=0x30
idtr:base=0x0000000000000000, limit=0x3ff
<bochs:5> u 0x7c00 0x7c4d
00007c00: ( ): mov ax, cs ; 8cc8
. . .
00007c36: ( ): mov bp, 0x7c43 ; bd437c
. . .
参考资料
- [OS64位][003] org 0x7c00 有什么用?
- [067][x86汇编语言]Bochs调试命令整理
- [OS64位][001]Boot:使用bochs制作虚拟软盘镜像boot.img、启动并运行boot程序