怎样用insight 调试跟踪qemu源代码

本文介绍如何在Windows环境下使用Cygwin及GDB调试QEMU虚拟机程序,包括设置断点、查看源文件及跟踪源代码等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我在windows端用的cygwin环境来进行操作,首先,启动cygwin,进入insight,选中菜单view中的console项,然后再命令行输入,

 

 

gdb>file qemu.exe

 

通过nm 可以查看到main入口地址,然后在该地址打断点,比如qemu-0.12.3入口地址_main在0x5592e0,用list 查找该地址位于源码具体文件,位置。

gdb>list *0x5592e0

 

Error: no source file for address 0x5592e0

 

发现该地址没有对应的源文件,于是又查找_qemu_main的地址00405d50,

gdb>list *405d50

0x405d50 is in qemu_main (C:/msys/1.0/home/liu/qemu-0.12.3/vl.c:4850).
4845     index++;
4846     return 0;
4847 }
4848 
4849 int main(int argc, char **argv, char **envp)
4850 {
4851     const char *gdbstub_dev = NULL;
4852     uint32_t boot_devices_bitmap = 0;
4853     int i;
4854     int snapshot, linux_boot, net_boot;

 

于是在vl.c:4850 打断点:

 

gdb>b 4850

Note: breakpoint 1 also set at pc 0x405d50.
Breakpoint 3 at 0x405d50: file C:/msys/1.0/home/liu/qemu-0.12.3/vl.c, line 4850.

 

然后设定启动参数:

 

gdb>set args  -L . -m 256 -hda hdc.img -boot -c

最后启动qemu

 

gdb>r

Starting program: /cygdrive/c/program files/qemu/qemu.exe -L . -m 256 -hda hdc.img -boot -c
[New thread 3376.0x914]

Breakpoint 1, qemu_main (argc=9, argv=0x13f4d18, envp=0x0) at C:/msys/1.0/home/liu/qemu-0.12.3/vl.c:4850

这时就会在设定断点处停下来,就可以跟踪源代码了

 

补充:

info b : 查看断点。

info line : 查看当前源文件

 

操作系统任务描述 本关任务:修改 Linux 0.11 内核程序,将系统启动时显示的字符串由原来的Partition table ok.变为Hello, world!。 通过本关任务,可以熟悉 Linux 0.11 内核实验环境,掌握内核程序的编辑、编译和测试方法。 相关知识 为了完成本关任务,你需要: 1.了解实验环境; 2.测试内核是否正常; 3.查看内核源码; 4.修改内核源码; 5.重新编译内核; 6.测试新内核是否正常。 1.了解实验环境 本课程将会在 Ubuntu 16.04 下进行学习,Ubuntu 属于Linux衍生出来的以桌面应用为主的Linux操作系统,Linux操作系统的使用与Windows基本上不同,所以最初会觉得无法理解,但是本质上还是差不多的。 本实验将使用 Bochs 模拟硬件环境,在完成对代码的修改或编译之后将使用run去启动新的虚拟机,环境都是准备好,可以直接使用的,只需要使用脚本去启动就行了。 本实验中已经给出了完整的linux 0.11内核文件放在/root/os/linux-0.11-lab/0/linux中,可以直接使用。 本课程的实验在目录~/os/linux-0.11-lab下进行,此目录下的内容如下: 其中各目录和文件的含义是: 脚本文件run*:以不同模式运行虚拟机,脚本 run 采用正常模式,脚本 rundbg 采用 bochs 调试模式(汇编级),脚本 rungdb 采用 gdb 调试模式( C 语句级),这三个模式都用于内核测试。 用于启动虚拟机的内核映像文件是cur/linux/目录下的Image; 虚拟机的根文件系统是images文件夹下的rootimage-0.11; 目录0:存放有 Linux 0.11 内核的源代码及其 Source-Insight 工程文件,本实训中使用 VSCode 代替 Source-Insight ,不需要使用到 Source-Insight ,只需要使用到linux文件夹中的源码; 目录conf:存放有虚拟机的配置文件,这些配置文件描述了虚拟机的硬盘、软盘、内存大小等参数; 目录images:包含虚拟机的硬盘(根文件系统)和软盘的映像文件; 其中映像文件hdimage-devel用作应用开发模式的硬盘,里面包含应用程序编译所需的 gcc 等软件。脚本run、rundbg和rungdb用软盘作为启动盘,对应的软盘映像文件是cur/linux/Image。 cur是一个符号链接,指向当前分析的内核目录,现在指向目录0,可以当作是一个快捷方式。 2.测试内核是否正常 运行run脚本就会使用在~/os/linux-0.11-lab目录下的内核映像cur/linux/Image启动 Linux 0.11 。 虽然这个虚拟机的硬盘容量只有 1 MB ,但它目前可以满足内核分析的需要。 3.查看内核源程序 关闭虚拟机,然后使用 VSCode 打开源码所在文件夹,选择 File ,然后选择 Open Folder ; 找到linux文件夹,然后确认打开; 可以看到文件夹下所有的源码都已经被导入了,可以在这里开始对源码进行修改了。 4.修改内核源码 在源码中可以修改很多东西,例如修改开机画面中的字符串Loading system ...,将其修改为Loading linux 0.11,这里需要注意一点,不能太长而影响生成的目标文件的大小。 使用搜索功能,搜索关键词Loading,在结果中找到Loading system ...,将其修改为Loading linux 0.11。 如果知道文件的具体位置,也可以在命令行中使用vim对配置文件进行修改,只需要找到文件中对应的地方进行修改,和在 VSCod 里面修改结果都是一样的。 修改完毕之后点击 File 然后选择 Save All ,保存所有修改即可。 5.重新编译内核 在内核源码目录~/os/linux-0.11-lab/0/linux中使用make命令重新编译内核; 下图是编译输出的结果,可以看到被修改的文件bootsect.s已经重新编译成功,这是只编译修改过的文件,有时为了可靠也可以完全编译; 完全编译需要将旧的编译文件清除,使用make clean命令清除编译文件,然后重新使用make命令编译,只不过完全编译的时间相对较长; 上图是编译之后的结果,Image 即为生成的完整内核映像,包含引导代码;tools 目录下有内核的主体可执行文件 system ,其符号文件是 System.map ,包含变量和函数的地址,其链接时的详细布局信息在文件 System.map.2
最新发布
03-10
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值