開發自己的操作系統引導程序 轉
開發自己的操作系統引導程序當你打開計算機時發生了什么?
1.電源打開;2.BIOS開始執行;3.引導程序開始執行。
引導程序的規定:你要有一個普通的二進制文件(COM 格式);大小是512個字節;最后兩個字節一定是0AA55h;它能被載入到內存地址0x7C00。
工具:
NASM——是一個免費的匯編工具(有DOS/windows/Linux三種版本)
PARTCOPY2.0——DOS下可自由往磁盤拷貝數據的軟件
舉例:
1.Just hang……
這個簡單的引導程序只能掛起:
hang:
jmp hang
times 512-($-$$)-2 db 0
dw 0AA55h
連接這個引導程序:
nasm -f bin -o hang.bin hang.asm
現在你需要一張格式化磁盤,傳送hang.bin到磁盤的引導扇區
partcopy hang.bin 0 200 -f0
“0”的意思是指從hang.bin文件的頂端開始傳送
“200”的意思是指拷貝200個字節
插入磁盤和重新啟動機器,測試這個引導程序。
2.一個實模式下的引導程序
上面的程序非常簡單,下面介紹一個稍微復雜一點的程序。
bits 16
org 0x7C00
start:
cli;關中斷
mov ax,0x9000;設置堆棧址:0x90000
mov ss,ax
mov sp,0
sti;開中斷
l1:push ds
mov dl,0;
重新設置磁盤控制器
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;讀磁盤扇區
mov al,5;讀入5個扇區
mov cx,2;柱面號=0,扇區號=2
mov dx, 0;磁頭號=0,驅動器號=0
int 13h;ES:BX=來自磁盤上的數據
pop es
jc l1
mov ax,0x10000;設置段寄器
mov es,ax
mov ds,ax
push ax
mov ax,0
push ax
retf
fail:
jmp fail
times 512-($-$$)-2 db 0
dw 0AA55h
連接這個引導程序:
nasm -f bin -o boot.bin boot.asm
傳送boot.bin到磁盤的引導扇區
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中最后一個參數“200”意思是指磁盤的偏移地址插入磁盤和重新啟動機器,你會看到“JIPPIKAYE”然后掛起。
本文轉自
http://www.woos.cn/bbs/read.php?tid=72
posted on 2008-01-07 16:11 旅途 閱讀(823) 評論(0) 編輯 收藏 引用 所屬分類: 一步一步操作系統