博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用gdb调试linux内核
阅读量:4030 次
发布时间:2019-05-24

本文共 1112 字,大约阅读时间需要 3 分钟。

http://blog.csdn.net/heli007/article/details/7187586 

使用Gdb+qemu调试内核:

我们调试内核需要一个叫qemu的虚拟机,qemu虚拟的一个好处便是可以让cpu处于冻结状态,从而让操作系统处于暂停状态,这样我们才能很方便的调试内核。
首先使用qemu安装一个操作系统,再将该操作系统的内核换成我们要调试的。

安装qemu:

在ubuntu10.10下用# sudo apt-get install qemu下载最新的qemu版本

从已经装好的操作系统ubuntu9.10_32.img的硬盘启动,测试qemu是否可以运行:

# qemu –hadubuntu9.10_32.img

基本安装结束后,开始进入调试阶段:

下载linux2.6内核,本实验使用编译的内核为linux2.6.30

# cd/Downloads

#wget  

# tar –jxvf  linux2.6.30.tar.bz2

# cdlinux-2.6.30

下面我们需要编译自己的内核,产生image文件bzImage和内核ELF文件vmlinux,具体的编译过程参考技术博客:

# make menuconfig

# make

编译后会在./arch/x86/boot/ 下生成bzImage文件:

注:编译时间很长,由于我没有对内核进行裁剪,以后编译时可以参考:

来对配置文件进行裁剪,对不需要的模块要进行裁剪,可以采用先剪裁几个模块后进行编译,没有错误后再进行裁剪编译,最大程度上上保持内核配置的正确性,在这方面必须要加强,不能拿来个内核全都编译,这样时间和空间都是种浪费。

运行qemu,启动调试模式:

# qemu –S–kernel arch/x86/boot/bzImage –had ubuntu9.10_32.img –append “root=dev/had”


在命令中使用S参数,是freeze CPU ata startup。

系统跳出一个黑显示界面,无任何内容,此时通过ctrl+alt+1与ctrl+alt+2可以切换,ctrl+alt+2是qemu控制台,ctrl+alt+1是屏幕输出。

现在我切换到qemu控制台(ctrl+alt+2)

(qemu)gdbserver 1234

此时需要另打开一个终端,进入linux2.6.30源码目录下:

# gdbvmlinux

(gdb)target remote localhost:1234


这时就可以正常使用gdb编译内核了

设置断点break start_kernel,停在linux内核的第一个c程序之上:


你可能感兴趣的文章
c++模板与泛型编程
查看>>
STL::deque以及由其实现的queue和stack
查看>>
CS4344驱动
查看>>
WAV文件解析
查看>>
DAC输出音乐2-解决pu pu 声
查看>>
WPF中PATH使用AI导出SVG的方法
查看>>
WPF UI&控件免费开源库
查看>>
QT打开项目提示no valid settings file could be found
查看>>
Win10+VS+ESP32环境搭建
查看>>
Ubuntu+win10远程桌面
查看>>
flutter-实现圆角带边框的view(android无效)
查看>>
flutter-实现一个下拉刷新上拉加载的列表
查看>>
android 代码实现圆角
查看>>
postman调试webservice接口
查看>>
flutter-解析json
查看>>
android中shader的使用
查看>>
java LinkedList与ArrayList迭代器遍历和for遍历对比
查看>>
Android DataBinding使用2-Recycleview
查看>>
drat中构造方法
查看>>
JavaScript的一些基础-数据类型
查看>>