本来内核是在bochs中运行是没有问题的,但是放到qemu中出现了几个问题。
主要是在引导阶段,qemu在引导时需要关掉中断,否则屏幕会一直刷新。
第二个问题是在把内核文件从硬盘读取到内存时,本来应该是连续的,结果在读取完一块后,间隔若干个‘00’, 然后才是第二个盘块的数据,后面也都是许多这种情况,可能是因为qemu读取时不是以512字节为单位,但是没有找到相关的参数,这个可能应该不是很大,因为这个空洞(一堆0)的大小,每次运行还都不一样,可能是qemu的问题。
最终解决方法是,一块一块地读,就没有问题了。
刚开始使用qemu,以前用的是bochs,感觉qemu更严格,但是试起来(gdb)比较麻烦,可能有更好的调试方法。bochs调试起来比较方便(直接在bochs里调试,搭配magic_break), 但是qemu网络配置好像比较简单,这也是改用qemu的主要原因。