1.上电,CPU PC 指向 0xfff0
2.执行 BIOS,检查存储设备第一个512字节的内容,末尾有 0x55AA 的就是可启动设备。找到启动设备后把第一个扇区(512字节)加载到 0x7c00 内存地址处,随后 PC 跳转到 0x7c00
3.执行 0x7c00 的代码,也就是 MBR 的代码,首先把自身 512 字节的代码复制到 0x90000,随后跳转到 0x90000:go 继续执行代码
4.此时在 0x90000 执行的代码依然是 MBR bootsect.s 的代码。接下来 MBR 会把 setup.s 和 操作系统内核分别加载到内存的 0x90200 和 0x10000 处,接着跳转到 0x90200 开始执行 setup.s 的代码
5.setup.s 需要做如下事情 (为进入保护模式做准备)
- 在 BIOS 中断处理函数被覆盖之前,使用它获取设备信息,存在内存 0x90000
- 关闭中断,重置整个内存布局,把system放在内存地址 0x0
- 设置 gdt 和 idt,保证进入保护模式之后,内存和中断可以被正常访问
- 开启A20地址线,对可编程中断控制器 8259 芯片进行重编程
- 修改 cr0 寄存器,进去保护模式
- 跳转到 0x0 地址,也就是 head.s 代码处
6.此时在 head.s 做的事情包括:
- 设置内核要使用的栈段和栈指针
- 初始化 idt (触发中断什么也不干)
- 再次设置 gdt (原先 gdt 的位置后面很可能会被覆盖掉)
- 设置页表基寄存器
- 开启分页 MMU
- 把 main 函数地址压入栈中
- 使用一个 ret 指令跳转到 main 函数中
7.已进入main函数。从 0x90000 读取设备信息,划分内存边界值
8.初始化内存管理 (创建一个 mem_map,4K为单位,记录哪些内存被使用,哪些内存没有被使用)
9.注册中断向量表 (并没有注册如键盘一类的中断,键盘中断会在后边的 tty初始化进行注册,这里只是注册一部分中断)
10.blk_dev_init 初始化块设备请求链表 (TODO: 感觉这里可能还会有些别的功能?以后再说)
TODO: here