https://www.kernel.org/pub/linux/kernel/v2.6/ 下载linux-2.6.24.tar.gz 或者其他
由于我是在虚机(14.04ubuntu)中进行开发,可能2.6的kernel有点儿老,编译的时候不通过,make bzImage也问题多多,
后来改用linux 3.18版本通过
1. make defconfig
2. apt-get install libncurses5-dev
3. make menuconfig
进入顶级选项Kernel hacking选项,先取消再选中kernel debugging,之后再次选中Compile kernel with debug info选项,选择以后出来并保存
4.make bzImage时报错
gcc: error: elf_x86_64: No such file or directory
gcc: error: unrecognized command line option ‘-m’在arch/x86/vdso/Makefile中修改 “-m elf_x86_64” 为 “-m64”
5. 参照mark link中的步骤配置eclipse,需要注意的是:“Debug As ..” >> “Debug Configurations” Double Click on “C/C++ Remote Application”(按照red link所说)
http://www.sw-at.com/blog/2011/02/11/linux-kernel-development-and-debugging-using-eclipse-cdt/
http://blog.youkuaiyun.com/linuxarmsummary/article/details/41596579, 感觉这个人写的比较靠谱,我也出现了相同的问题
6. 关于bzImage,zImage,vmlinuz,vmlinux分别是什么可以参考, 写的很详细,
http://blog.youkuaiyun.com/muge0913/article/details/7285009
7. 注意在步骤5中遇到“packet reply too long”的问题时要下载gdb,按照red link修改,重新编译之后,在eclipse中重新配置方可。
mark一下我的命令:qemu-system-x86_64 -s -S -kernel arch/x86/boot/bzImage -hda sid.ext3 -append "root=/dev/sda"
按照上面的步骤做完之后,断点成功的停在了start_kernel处,可以开始调试了!!
对linux kernel进行debug是个比较复杂的事情,尤其没有从事kernel 相关的开发,必须要要看一些linux kernel相关的书籍,从门电路到寄存器,到
内存管理,进程管理,VFS等要有理解,对SMP,NUMA,KVM,CGROUP在linux kernel中如如何实现的要大概有个了解,对用户态,核心态之间的
切换要有概念,即便这些,在看kernel源码时,还是力不从心,还需要对汇编,编译,链接有知识背景,对C不陌生。
这里的调试是从start_kernel开始的,运行完成之后切换到保护模式,开始有分页,而在这之前,从BIOS到boot loader,从boot loader 加载kernel 代码,
的过程并不涉及,那将又是另外一个故事,有实模式,中断re-mapping等等,并非一朝一夕就能明白的,现代linux kernel代码量已经非常惊人了,看一遍基本是不可能
的,从很早期的linux kernel看起,比如0.11或者0.95版,那时整个linux kernel代码量比较少,进程调度算法很简单,也没有多核代码的复杂性,
即便这样,要想完全弄明白也是很不容易的了,加油吧!