BIOS引导原理
首先要了解BIOS的引导原理。启动时自检过程中会去检查磁盘的第0磁头第0磁道的第1扇区,检查其是否以0x55和0xaa为结尾,如果是的话,就认为它是一个引导扇区。
接着就会将这个扇区复制到内存的0x7c00处,随后从0x7c00处开始执行。
BIOS跳转到引导程序的之前,会初始化处理器,设置CS寄存器为0x0000,指令指针寄存器IP为0x7c00.
这个时候cpu处于实模式下,物理地址必须经过CS和IP寄存器转换才能得到,公式为:物理地址=(CS<<4) IP。对应的也是物理地址的0x7c00.
初始化寄存器
这里涉及到几个寄存器
cs | “代码段寄存器”,对应于内存中的存放代码的内存区域,用来存放内存代码段区域的入口地址(段基址) |
---|---|
ax | 累加寄存器 |
ds | 数据段寄存器 |
es | 附加段寄存器 |
ss | 堆栈段寄存器 |
sp | 栈指针寄存器 |
初始化寄存器的过程中,就是将cs的值设置到DS、ES、SS、AX中,然后设置栈指针寄存器SP.
代码语言:javascript复制;将程序开始位置设置为0x7c00处,并给BaseOfStack赋值为0x7c00
org 0x7c00
BaseOfStack equ 0x7c00
Label_Start:
;初始化寄存器
mov ax, cs
mov ds, ax
mov es, ax
mov ss, ax
mov sp, BaseOfStack
清屏
使用BIOS的10h的中断服务程序来清屏。
INT 10h, AH=06h时,功能是按指定范围滚动窗口。
具体功能看这里:
(转载)BIOS中断大全
BIOS中断大全
设置屏幕光标位置为左上角(0,0)处
使用INT10h的主功能号AH=02h可以实现设置光标位置的功能
代码语言:javascript复制;设置屏幕光标位置为左上角(0,0)的位置
mov ax, 0x0200
mov bx, 0x0000
mov dx, 0x0000
int 10h
显示字符串
使用BIOS的INT10的主功能AH=13h可以显示字符串
填满第一个扇区
为了确保boot的映像大小刚好是第一个扇区的大小,使用下面的方法来填满整个扇区。
代码语言:javascript复制;填满整个扇区的512字节
times 510 - ( $ - $$ ) db 0
dw 0xaa55 ;===确保以0x55 0xaa为结尾
在qemu中运行
先是使用bximage创建一个1.44mb的软盘,然后将编译后的boot.bin写入到img文件中,接着在qemu中运行。
转载请注明来源:https://longjin666.cn/?p=1293