orange's一个操作系统的实现--学习过程 第一章:杂记

--------------------实模式下没有保护机制,自己写的汇编程序可以随意跳转地址,

可以跳到开机初始CPU ip地址,实现不停的开机的效果

--jmp.asm

org 07c00h ; 告诉编译器程序加载到7c00处
BaseOfLoader  equ 0xf000 ;  ----  段地址
OffsetOfLoader equ 0xfff0 ;  ---- 偏移地址
mov ax, cs
mov ds, ax
mov es, ax
call DispStr ; 调用显示字符串例程
  jmp BaseOfLoader:OffsetOfLoader ; 调回bios地址  完成不停的执行bios程序 不停的读取软盘程序执行
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 ; 结束标志


nasm  jmp.asm  -o  jmp.bin 
dd  if=jmp.bin  of=a.img  bs=512  count=1  conv=notrunc
把a.img放到bochs下,即可看到虚拟机不停的开机。

 

 

 

--boot.asm里面
int 10 后面为什么需要   ret 指令     因为使用的call指令,必须使用ret返回,并且call没有压栈参数 


反编译, 反编译最恶心的就是 把数据也会当做指令反编译回来,反编译成没有意义的指令
ndisasm -o 0x7c00 boot.bin >> disboot.asm


--OS操作系统编写理解

cpu初始的地址是被bios占用的,即开机以后CPU执行权就交给了BIOS程序,BIOS程序会进行开机自检、构建中断向量表、BIOS数据区、BIOS中断服务程序等等;然后bios读取启动设备的引导扇区存放在指定内存地址,即BIOS设定了OS操作系统的初始地址。OS操作系统最底层的编写,就是通过调用bios程序实现一些基本功能。

 

你可能感兴趣的:(orang's)