问题:
主引导程序是软件还是固件?如果是软件,那么有谁开发?如何开发?
主引导程序是软件,操心系统人员编写。
主引导程序
- 一段存储在主引导区(MBR)中的有效代码
- 并不固化与硬件,属于操作系统代码中的一部分
- 启动操作系统内核的桥梁,用汇编完成
- 代码总量不能超过512个字节(包含0x55aa)
主引导程序的开发
汇编补充知识
- mov:赋值操作,将右操作数赋值给左操作数
mov ax,0 // 将 0 赋值给 ax 寄存器
- int : 触发中断
int 0x10 // 触发0x10 中断,对屏幕进行操作
- hlt :停止运行, CPU进入暂停状态,不执行任何操作
hlt // 使程序进入睡眠状态
- 汇编中地址的访问方式:段地址:断内偏移地址
mov byte[0xb800:0x01],0x07 // 0xb800:0x01 -> 0xb8000 + 0x01
// 段地址 0xb800 左移4位得到 0xb8000 ,之后这个结果加上 0x01
// 0x07 赋值给前面的那个地址
关于段地址和偏移地址参考如下博客:
https://blog.csdn.net/unix21/article/details/8450214
- 标签
用于标识后续指令的地址(等同为C语言中的标签,比如 goto)
- $ vs $$
$ 表示当前指令行地址
$$ 表示当前汇编段起始地址
- 中断调用 VS 函数调用
实验
- 编写一个主引导程序(汇编语言)boot.asm
- 可独立运行于 X86 架构的主机(无操作系统),运行在硬件之上
- 运行后在屏幕打印 “Hello DTOS”
实现思路
- 将关键寄存器的值设置为 0 (mov ax,0)
- 定义需要打印的数据(db "Hello DTOS")(db >>> define)
- 打印预定以好的字符数据(int 0x10)
如何验证编写的主引导程序?
- 将汇编源码编译为二进制机器码(nasm)
- 创建虚拟盘(bximage)
- 将二进制代码写入虚拟盘起始位置(dd)
- 在虚拟机中将虚拟盘作为启动盘执行(可在虚拟机上操作 vmware)
- nasm
nasm boot.asm -o boot.bin
// 编译
- bximage
bximage a.img -q -fd -size = 1.44
// -q 不需要交互
// fd:虚拟软盘,大小为 1.44M
- dd( .bin 文件 写入到虚拟软盘)
dd if=boot.bin of=a.img bs=512 count=1 conv=notrunc
// if 输入
// of 输出
// bs=512 count=1 每个写入单元大小为512,并且只要写一次就行
// conv=notrunc 连续的写入,不要有间隔
boot.asm
org 0x7c00
start:
mov ax, cs
mov ss, ax
mov ds, ax
mov es, ax
mov si, msg
print:
mov al, [si]
add si, 1
cmp al, 0x00
je last
mov ah, 0x0e
mov bx, 0x0f
int 0x10
jmp print
last:
hlt
jmp last
msg:
db 0x0a, 0x0a
db "Hello, DTOS!"
db 0x0a, 0x0a
times 510-($-$$) db 0x00 // 没有512 字节,进行添 0 处理。510去减是因为下面还有两个字节
db 0x55, 0xaa
最终生成的 a.img 之后在虚拟机进行如下操作:
如果现在直接开启的话提示找不到操作系统
需在进行如下操作
然后启动
至此编写的主引导程序顺利工作了
小结
- 主引导程序的代码量不能超过 512 字节
- 主引导程序需要使用汇编语言编写
- 主引导程序可以通过 BIOS 中断使用硬件功能
- 主引导程序运行于实模式(地址都是实际的物理地址)