如何开发自己的操作系统的引导程序
2006-09-28 16:38
573 查看
当你打开计算机时发生了什么?
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”然后挂起。
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”然后挂起。
相关文章推荐
- 如何开发自己的操作系统的引导程序?
- 开发自己的操作系统引导程序
- Tips: 如何让自己的应用程序,控制台程序,windows 服务收到操作系统注销或者重启的消息?
- 【discuzX2】如何二次开发自己的程序?
- IOS开发中如何判断程序第一次启动(根据判断结果决定是否显示新手操作引导)
- 开机自动运行自己开发的可执行程序,如何不弹窗口
- 【discuzX2】如何二次开发自己的程序?
- 如何让自己的应用程序,控制台程序,windows 服务收到操作系统注销或者重启的消息
- 自己动手写操作系统 将引导程序成功写入优盘启动电脑
- 如何在IBM PC上开发自己的操作系统
- 自己动手实现操作系统引导程序(OS bootloader)——借助QEMU/GDB/losetup/dd等工具
- 自己动手实现操作系统引导程序(OS bootloader)——借助QEMU/GDB/losetup/dd等工具
- zynq开发中如何向文件系统里添加自己的程序
- 用INNO SETUP做安装程序时,如何自动注册一个自己开发的DLL文件??
- 新人建站如何选择适合自己的开发语言或者开发程序?
- 自己动手编写操作系统_引导程序
- 如何讲解自己开发的程序
- 如何在IBM PC上开发自己的操作系统
- 在Symbian操作系统上开发的手机程序必须进行数字签名,才能在手机终端上安装成功。数字签名机制能够有效阻止恶意手机程序的传播,并保护软件开发商和手机用户的合法权益。那么,如何进行Symbian数字签
- 关于如何解锁你的WP7,以便安装自己开发的程序。