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

posted @ 2016-04-11 11:50  大魔王Faker  阅读(1420)  评论(0编辑  收藏  举报