【完整代码已经归档到 : https://github.com/linzhanglong/mini_bootloader】
我们知道,系统启动会加载磁盘的MBR扇区到内存0x7c00那里去执行。但是毕竟MBR扇区只有512个字节,如果要实现设置GDT,读取内核,引导内核等功能,这512字节显得力不从心。所以我们这里第一步就是通过MBR去磁盘读取一块更大的空间到内存然后去执行这部分代码(称为 stage2)。这里我们尤其要注意一点就是,系统刚从BIOS启动执行磁盘MBR数据,CPU的工作模式还是实模式,寄存器都是16位的。通过段寄存器,最大可以支持的内存是[0xffff,0xffff] = 0xffff * 16 + 0xffff = 1M。总共只能索引1M的内存,而每一个段内只能索引64K范围。
我们这里先规划我们的内存和磁盘布局:
我们现在实现的代码就是通过MBR代码,把stage2的代码加载到内存0x9000执行。