在qemu中使用GDB调试Linux内核无法命中函数或给定地址
我试图在qemu环境中使用GDB逐步了解内核启动顺序.
以下是我的设置: 在一个终端即时运行 ~/Qemu_arm/bin/qemu-system-arm -M vexpress-a9 -dtb ./arch/arm/boot/dts/vexpress-v2p-ca9.dtb -kernel ./arch/arm/boot/zImage -append "root=/dev/mmcblk0 console=ttyAMA0" -sd ../Images/RootFS.ext3 -serial stdio -s -S 在其他终端 arm-none-linux-gnueabi-gdb vmlinux Reading symbols from vmlinux...done. (gdb) target remote :1234 Remote debugging using :1234 0x60000000 in ?? () 我的问题是如何在/ arch / arm / boot / compressed / *文件中设置代码的断点. 例如,我试图为misc.c中定义的decompress_kernel设置断点. 情况1: (gdb) b decompress_kernel Function "decompress_kernel" not defined. Make breakpoint pending on future shared library load? (y or [n]) y Breakpoint 2 (decompress_kernel) pending. (gdb) c Continuing. 上面的一个是无法启动qemu启动的功能. 案例2: (gdb) b *0x80008000 Breakpoint 1 at 0x80008000: file arch/arm/kernel/head.S,line 89. (gdb) c Continuing. 在这种情况下它也无法击中qemu启动. 案例3: (gdb) b start_kernel Breakpoint 1 at 0x8064d8d8: file init/main.c,line 498. (gdb) c Continuing. Breakpoint 1,start_kernel () at init/main.c:498 498 { (gdb) 在这种情况下功能正在击中,我可以逐步调试. 注意:我已启用调试,早期printk并尝试了hbreak 所以我的查询是: >为什么有些功能无法达到突破点? 解决方法
您无法在start_kernel之前的任何函数上放置断点,因为您没有为它们加载符号.实际上,您正在使用内核的zImage启动qemu,但是从vmlinux加载符号.它们不一样:zImage基本上是作为数据有效负载压缩的vmlinux,然后附加到存根,该存根在内存中解压缩然后跳转到start_kernel.
start_kernel是vmlinux的入口点,它之前的任何函数,包括decompress_kernel,都是stub的一部分,不存在于vmlinux中. 我不知道做“arm-none-linux-gnueabi-gdb zImage”是否允许你调试存根,我总是在真实硬件上使用JTAG调试器对ARM内核进行早期调试,并且从未使用过qemu,抱歉 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |