目标: 创建一个文件,使BIOS能够将其当作能够boot的硬盘
当PC启动时,BIOS并不知道如何启动操作系统,所以BIOS将启动操作系统的任务委派给boot sector,因此boot sector必须放置到一个大家都知道的地方,人们约定,这个地方,应该在硬盘的第一个存储空间中(cylinder 0, head 0, sector 0),该存储空间占用512个字节.
同时,为了确认硬盘是否能够启动(boot) OS, 人们制定标准,boot sector 的第511和第512个字节应该为0xAA55,如以下示例:
详情见代码中的注释.
; ========================================
; 文件名: boot_sect_simple.asm
; 该程序对硬盘的第一个分区进行写入,总计512个字节
; 其中第511,512个字节必须为0xAA55
; 剩余的510个字节自定义,作为boot功能,用来启动os
; ========================================
; 无限循环
loop:
jmp loop
; 以0填充除上面两行、结尾的0xAA55之外的部分
; $ 表示本行代码的偏移量(offset) $$ 代表本段的地址(segment)
times 510 - ($ - $$) db 0
dw 0xAA55
使用工具nasm进行编译,进入你存放源码的文件夹中,使用以下命令
nasm -f bin boot_sect_simple.asm -o boot_sect_simple.img
编译完成后可以看到你存放源码的文件夹中多了一个名为boot_sect_simple.img的文件.
使用qemu可以从刚才生成的文件中启动,使用以下命令
qemu-system-i386.exe boot_sect_simple.img
当然,每次编译运行很麻烦,我们写一个简单的脚本Run.bat套用。
@echo OFF
nasm -f bin %1.asm -o %1.img
qemu-system-i386.exe %1.img
pause
这样每次我们运行Run.bat + “NASM源文件”就可以调试了。
.\Run.bat boot_sect_simple