最近看了《Orange`s 一个操作系统的实现》,萌生了自己写一个玩具操作系统的想法,
首先从计算机启动过程开始
计算机启动时,会按以下步骤执行:
1、加电自检,执行BIOS中的自检程序。
2、寻找启动设备,硬盘,软盘,优盘等,然后读取它的第一个扇区,如果这个扇区是以0xAA55结束,那么BIOS就认为它是引导扇区。
3、BIOS将其中的程序加载到内存0x7c00处,然后将控制权交给这段程序。
书中的引导扇区代码如下:
org 07c00h ; 告诉编译器程序加载到7c00处
mov ax, cs
mov ds, ax
mov es, ax
call DispStr ; 调用显示字符串例程
jmp $ ; 无限循环
DispStr:
mov ax, BootMessage
mov bp, ax ; ES:BP = 串地址
mov cx, 16 ; CX = 串长度
mov ax, 01301h ; AH = 13, AL = 01h
mov bx, 000ch ; 页号为0(BH = 0) 黑底红字(BL = 0Ch,高亮)
mov dl, 0
int 10h ; 10h 号中断
ret
BootMessage: db "Hello, OS world!"
times 510-($-$$) db 0 ; 填充剩下的空间,使生成的二进制代码恰好为512字节
dw 0xaa55 ; 结束标志
这里注意:org 07c00h 是告诉编译器,这个程序将会被加载到0x7c00处,将代码中指令用到的地址偏移0x7c00,而不是使程序加载至0x7c00,即使没有这条指令程序依旧会加载到0x7c00处。
一些nasm编译器的语法:
$:指当前执行指令的地址。
$$:指当前指令所属段的段地址。
times x 指令:重复执行某指令x次。