一个i386架构的简单内核,借鉴了《30天自制操作系统》、《一个orange操作系统的实现》和《linux内核设计的艺术》相关代码,但是设计思路属于自创,多处初始化流程不在按照经典的启动流程来,采用较为简单的内核启动方式来完善DeeppinOS。
- 编译环境:ubuntu16.04 64位
- 编译器:gcc-5.4.0
- 汇编器:nasm
- 链接器:ld
- 仿真器:bochs
- 其他工具:objcopy
最开始,打算按照《30天自制操作系统》一书再次慢慢研究操作系统的设计知识,最后由于将开发环境换成ubuntu,使用gcc和nasm编译整个内核,开始此计划时,内核相关知识有但是还缺少实验,再加上对gcc和nasm编译一个x86文件感觉不太可能,参考了许多大牛写的简单内核,最终确定可以修改原来的Makefile文件,使用gcc和nasm。
使用gcc和nasm断断续续修改Makefile,最终完全解决和达到最初在windows下的效果,大概花了十多天时间,中间遇到许多问题,也不单单是gcc和nasm命令的问题,尤其是是否在第一个汇编文件boot.asm里就进入保护模式。。。。。还是放在kernel.asm里边。。。。
哎呀西八,TMD就是这花了我七八天时间,本来是将进入保护模式的程序放在kernel.asm里边
但是发现不成功,然后我怀疑是不是gcc和nasm的问题,还是代码对齐的问题-----最后没有
这么干,但是发现了问题,是生成的kernel.bin文件前有elf头(大概0x1000),其本质就是
在boot.asm里边跳转地址不对(这都是采用第二种方法后debug出来的)
还一个说明,就是在保护模式下的跳转(jmp)不能跟原来一样了,,例如:
jmp 0x08:_start;(_start在第二个文件开头,使用这个指令不知道jmp到什么地方去了)
可以采用的跳转:
MOV EAX,0x9000
JMP EAX
感觉如果使用汇编不精通,写的代码啥都有可能发生,解决办法就一个:慢慢使用bochs慢慢单步调试,这些问题都能发现。
boot-------------------------------------------------------------
|-------boot.asm
drivers----------------------------------------------------------
|-------timer.c
|-------keyboard.c
include----------------------------------------------------------
|-------console.h
|-------string.h
|-------vargs.h
|-------debug.h
|-------descriptor.h
|-------interrupt.h
|-------timer.h
|-------pmm.h
|-------keyboard.h
|-------keymap.h
init---------------------------------------------------------------
|-------kernel.asm
|-------start.c
|-------console.c
|-------interrupt.c
|-------pmm.c
kernel-----------------------------------------------------------
|-------prink.c
scripts----------------------------------------------------------
|-------kernel.ld
doc----------------------------------------------------------
|-------help.md
bochsout.txt--------------bochs调试输出(基本没用)
bochsrc-------------------bochs调试配置文件(使用指令:make bochs即可)
Makefile------------------make--->make qemu/make bochs
deeppink.img--------------最终生成的镜像文件
README.md-----------------帮助文档(遇到的相关bug和设计步骤)