http://blog.chinaunix.net/uid-27033491-id-3260904.html
http://blog.chinaunix.net/uid-27033491-id-3274496.html
学习linux内核,调试内核是比不可少的环节,下面就介绍如何搭建调试环境。本文是傻瓜式地说明过程,
主要是为了供一些初学者参考。本人也是初学者,知道傻瓜式的东西就是好。
-----------------------------------------------------------
一,先总体说下,必备的环节有哪些?
1,安装virtualbox虚拟机。我用的主机环境是ubuntu11.04,虚拟机时ubuntu10.04.
2,开启virtualbox虚拟机的增强功能。(主要是为了设置共享文件夹)
3,设置虚拟机与主机之间共享文件夹。(因为后面需要在虚拟机中编译内核)
4,设置虚拟机和主机之间的串口通信。(两个OS之间需要通信)
-----------------------------------------------------------
二,安装virtualbox。
2.1,首先在virtualbox官网下载一个软件包
我下载的是:virtualbox-4.1_4.1.16-78094~Ubuntu~natty_i386.deb------------------------------------------------------------------------------------------------ 2.2,使用sudo dpkg -i virtualbox-4.1_4.1.16-78094~Ubuntu~natty_i386.deb安装。
安装过程出现需要一些依赖,见下图,这是我安装时出现的。
解决方法:sudo apt-get install -f
-------------------------------------------------------------------------------------------------------------------
三,设置virtualbox的增强功能及其共享文件夹。
参考:http://blog.chinaunix.net/uid-27033491-id-3267228.html
四,设置virtualbox和主机的串口通信。
参考:http://blog.chinaunix.net/uid-27033491-id-3267248.html
-------------------------------------------------------------------------------------------------------------------
三,设置virtualbox的增强功能及其共享文件夹。
参考:http://blog.chinaunix.net/uid-27033491-id-3267228.html
四,设置virtualbox和主机的串口通信。
参考:http://blog.chinaunix.net/uid-27033491-id-3267248.html
--------------------------------------------------------------------------------------------------------------------
在搭建好virtualbox之后开始如下工作。
1.在虚拟机virtualbox中编译新的内核。
新的内核要支持kgdb,必须要配置内核选项。执行make menuconfig后的配置选项参考如下:
<1>KGDB必须使能的内核选项:
- CONFIG_EXPERIMENTAL = y
- Location:
- -> General setup
- -> Promptfor development and/or incomplete code/drivers
- CONFIG_KGDB = y
- Location:
- -> Kernel hacking
- -> KGDB: kernel debugger
- CONFIG_KGDB_SERIAL_CONSOLE
= y (使用串口进行通信)
- Location:
- -> Kernel hacking
- -> KGDB: kernel debugger
- -> KGDB: use kgdb over the serial console
- CONFIG_DEBUG_RODATA = n
- 该选项是将内核的一些内存区域空间设置为只读,这样可能导致kgdb的
- 设置软断点功能失效。所以推荐将该选项关闭。
-
- Location:
- -> Kernel hacking
- CONFIG_KGDB_LOW_LEVEL_TRAP
= y
- 使能该选项可以kgdb不依赖notifier_call_chain()机制来获取断点异常,
- 这样就可以对notifier_call_chain()机制实现相关的函数进行单步调试。
- Depends on: KGDB[=y]&&
(X86 [=y]|| MIPS
[=MIPS])
- Location:
- -> Kernel hacking
- -> KGDB: kernel debugger(KGDB [=y])
- CONFIG_DEBUG_INFO = y
- 该选项可以使得编译的内核包含一些调试信息,使得调试更容易。
- Location:
- -> Kernel hacking
- CONFIG_FRAME_POINTER
= y
- 该选项将使得内核使用帧指针寄存器来维护堆栈,从而就可以正确地执行堆栈回溯,即函数调用栈信息。
- Location:
- -> Kernel hacking
- CONFIG_MAGIC_SYSRQ = y(如果你选择了KGDB_SERIAL_CONSOLE,这个选项将自动被选上)
- 激活"魔术 SysRq"键. 该选项对kgdboc调试非常有用,kgdb向其注册了‘g’魔术键来激活kgdb 。
-
- Location:
- -> Kernel hacking
2,编译内核。参考:http://blog.chinaunix.net/uid-27033491-id-3233389.html
编译内核完成后,将vmlinux文件通过共享文件夹copy到主机上,供gdb调试用.
---------------------------------------------------------------------------------------------------------------------------
3,编译好内核后,需要修改grub。(我编译使用的内核是2.6.39.4)
...
linux /boot/vmlinuz-2.6.39.4 root=UUID=3f02ad87-4327-4bc2-96bd-617d56bf8a68 ro kgdb=ttyS0,115200 kgdboc=ttyS0,115200 kgdbwait
...
内核启动时将会等待主机使用target remote...进行远程链接。见下图。
---------------------------------------------------------------------------------------------------------------------------
4.然后在主机上进行远程链接,这就需要使用串口了。
首先在主机执行如下命令。
$socat -d -d /tmp/vbox pty:
注意:/tmp/vbox是创建串口通信时的主机有名管道。
执行该命令后,进入死循环,记住远程链接的参数 /dev/pts/3 然后另开一终端,使用gdb进行远程
链接。
如上kgdb_breakpoint函数就是内核的第一个断点。接下来就可以调试了。
-----------------------------------------------------------------------------------------------------------------------
参考:http://www.kgdb.info/kgdb/use_kgdb/enable_kgdb_option/
http://fotis.loukos.me/blog/?cat=8§