编写BIOS下的OS Loader的误区:
1、一定要用Big Real Mode
实际上并不需要Big Real Mode,可以用实模式和16位保护模式来回切换来解决,实模式可以用来调用BIOS,16位保护模式可以加载32位数据段来拷贝内存,这两个模式可以共享同一个16位代码段,并执行连续的16位C语言程序,可以实现一个汇编函数来回切换,而不改变执行流
在合适的时候可以跳到32位代码段执行32位程序,然后可以通过回调的方式切回16位保护模式执行16位代码,然后如果有必要可以切回实模式,最后再切回来,然后返回32位程序即可
这个方法实际上就是ntldr使用的方法——ntldr实际上是由实模式/16位保护模式程序startup.com和32位保护模式PE程序osloader.exe两部分组成的
2、一定要用8086汇编语言,或古老的C语言编译器编写16位程序
实际上,关键代码可以用386汇编语言编写,逻辑代码可以用gcc -m16编译,编译结果是一个使用32位栈帧的16位程序,链接时使用自定义linker script,将.text .rodata .data .bss等放进virtual address为0的节,其它节/DISCARD/即可
相关文章
- 10-07编写BIOS下的OS Loader的误区