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占用的,然后bios又重新设定了他的初始地址。操作系统最底层的编写,就是通过中断与bios进行交互了。



猜你喜欢

转载自blog.csdn.net/port23/article/details/80722911