VMware内核调试
一、配置虚拟机串口
两台Linux虚拟机Host与Target,关闭状态下设置串口为使用命名管道,Ubuntu下串口2实际对应设备/dev/ttyS1。
测试:
Target:sudo cat < /dev/ttyS1
Host:duso echo Helloworld > /dev/ttyS1
在Target端可以看到"Helloworld"即证明串口通信正常。
二、下载指定版本Linux源码并编译
在http://www.kernel.org网址下载想要调试的Linux源码。
1.解压
2.进入解压目录,执行sudo make menuconfig,开启KGDB和KGDB_SERIAL_CONSOLE选项(Kernel hacking)
3.编译,sudo make
4.安装内核模块,sudo make modules_install,模块会安装到/libg/modules/xxx
5.安装内核映像文件,sudo make install,在/boot目录下生成config文件、initrd.img文件系统、vmlinux内核映像文件、System.map符号表。
三、实现串口调试
修改Target启动项,在handoff后增添kgdbwait kgdboc=ttyS1,9600(设为115200没有尝试),重启后会发现系统等待在kdb>下。
将编译后的源码复制到Host虚拟机,进入源码目录,执行:
sudo gdb vmlinux
set serial baud 9600
target remote /dev/ttyS1
若想让目标机进入调试状态,在root状态下执行:echo g>/proc/sysrq-trigger
四、未编译调试
在没有编译内核的情况下,还可以直接通过修改虚拟机的启动文件.vmx,添加:
debugStub.listen.guest32 = "TRUE"
然后在调试机器中通过:target remote ip:8832(8864)来调试,ip为真实机器的IP