文章目录
- 前言
- MBR
- 1) 512 字节镜像
- 2) 0x55 和 0xAA
- qemu 运行
- 参考
前言
上篇《自己动手写一个操作系统——我们能做什么,我们需要做什么》我们介绍到 BIOS 会遍历每个磁盘的第一个扇区查找 MBR,找到后便将 MBR 加载到内存并跳转过去。如果没找到,就会报错,无法启动。
MBR
接下来,我们就编写(制作)一个 MBR。
BIOS 识别 MBR 的唯一条件就是,第一个扇区的最后两个字节为 0x55 和 0xAA,而不管前 510 个字节是什么数据。就算前 510 个字节是错误的数据(指令),CPU 也照样取出指令去执行,大不了就是跑飞呗。
所以,我们制作一个简单的 MBR
- 1) 大小为 512 字节
- 2) 最后两个字节为 0x55 和 0xAA
- 3) 前 510 字节全为 0
1) 512 字节镜像
dd if=/dev/zero of=${OUTPUT}/mbr.img bs=512 count=1
2) 0x55 和 0xAA
最后两个字节修改为 0x55 和 0xAA
vim -b mbr.img
:%!xxd -g 1
# 最后两个字节修改为 55 AA
:%!xxd -r
:wq
qemu 运行
qemu-system-i386 -daemonize -m 128M -drive file=output/mbr.img,index=0,media=disk,format=raw
说明 BIOS 已经检测到了 MBR。 🆗
如果没有检测到(我们手动将 0x55 和 0xAA 修改成 0x00),是下面这种情况:
not a bootable disk
No bootable device
参考
在Linux下使用vim配合xxd查看并编辑二进制文件