開發(fā)自己的操作系統(tǒng)引導(dǎo)程序
當(dāng)你打開計算機(jī)時發(fā)生了什么?
1.電源打開;2.BIOS開始執(zhí)行;3.引導(dǎo)程序開始執(zhí)行。
引導(dǎo)程序的規(guī)定:你要有一個普通的二進(jìn)制文件(COM 格式);大小是512個字節(jié);最后兩個字節(jié)一定是0AA55h;它能被載入到內(nèi)存地址0x7C00。
工具:
NASM——是一個免費的匯編工具(有DOS/windows/Linux三種版本)
PARTCOPY2.0——DOS下可自由往磁盤拷貝數(shù)據(jù)的軟件
舉例:
1.Just hang……
這個簡單的引導(dǎo)程序只能掛起:
hang:
jmp hang
times 512-($-$$)-2 db 0
dw 0AA55h
連接這個引導(dǎo)程序:
nasm -f bin -o hang.bin hang.asm
現(xiàn)在你需要一張格式化磁盤,傳送hang.bin到磁盤的引導(dǎo)扇區(qū)
partcopy hang.bin 0 200 -f0
“0”的意思是指從hang.bin文件的頂端開始傳送
“200”的意思是指拷貝200個字節(jié)
插入磁盤和重新啟動機(jī)器,測試這個引導(dǎo)程序。
2.一個實模式下的引導(dǎo)程序
上面的程序非常簡單,下面介紹一個稍微復(fù)雜一點的程序。
bits 16
org 0x7C00
start:
cli;關(guān)中斷
mov ax,0x9000;設(shè)置堆棧址:0x90000
mov ss,ax
mov sp,0
sti;開中斷
l1:push ds
mov dl,0;
重新設(shè)置磁盤控制器
mov ax,0
int 13h
pop ds
jc fail
push es
mov ax,0x1000;ES:BX=10000
mov es,ax
mov bx,0
mov ah,2;讀磁盤扇區(qū)
mov al,5;讀入5個扇區(qū)
mov cx,2;柱面號=0,扇區(qū)號=2
mov dx, 0;磁頭號=0,驅(qū)動器號=0
int 13h;ES:BX=來自磁盤上的數(shù)據(jù)
pop es
jc l1
mov ax,0x10000;設(shè)置段寄器
mov es,ax
mov ds,ax
push ax
mov ax,0
push ax
retf
fail:
jmp fail
times 512-($-$$)-2 db 0
dw 0AA55h
連接這個引導(dǎo)程序:
nasm -f bin -o boot.bin boot.asm
傳送boot.bin到磁盤的引導(dǎo)扇區(qū)
partcopy boot.bin 0 200 -f0
為了使程序可以看到,在編譯下面程序
mov ax,1000h;修改段寄存器
mov ds,ax
mov es,ax
mov si,msg;打印 "JIPPIKAYE!"
call putstr
hang:;掛起
jmp hang
putstr:
lodsb
or al,al
jz short putstrd
mov ah,0x0E
mov bx,0x0007
int 0x10
jmp putstr
putstrd:
retn
msg db 'JIPPIKAYE!',13,10,0
連接和傳送:
nasm -f bin -o boot.bin boot.asm
partcopy boot.bin 0 200 -f0 200
在partcopy中最后一個參數(shù)“200”意思是指磁盤的偏移地址插入磁盤和重新啟動機(jī)器,你會看到“JIPPIKAYE”然后掛起。
本文轉(zhuǎn)自
http://www.woos.cn/bbs/read.php?tid=72