写一个boot引导程序

2022-10-31 14:59:05 浏览数 (1)

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

0 人点赞