如何解决wsl2、gdb 和交叉调试 32 位 i386 - 无法将地址映射到符号在 ?? () 中
我在尝试在 WSL2 主机上调试交叉编译的二进制文件时遇到问题,但最终只得到地址为 ?? (),欢迎任何有关验证和更改内容的提示!
file mybin
显示:
ELF 32 位 LSB 可执行文件,Intel 80386,版本 1 (SYSV),动态链接,解释器 /lib/ld-linux.so.2,用于 GNU/Linux 2.6.32,BuildID[sha1]=...,带 debug_info,未剥离
应用在 WSL2 中通过 qemu-i386 启动(基于 ps 的输出) 注意:我对此有点想知道,因为在我使用 vm-ware 和 ubuntu 18.04 的上一个开发环境中,我没有看到使用 qemu-i386,但基于 WSL2 问题没有考虑更多关于 32 位应用程序支持的问题,参考 qemu 和 binfmt解决它。
我正在运行 gdb-multiarch (GNU gdb (Ubuntu 9.2-0ubuntu1~20.04) 9.2)
使用 info functions <a_regex>
加载可执行文件和列表符号工作正常但是在附加和破坏时我得到这样的 bt(下面的注意输出取自 VSCode 并启用了一些日志记录标志,因此例如 -exec bt 的东西):
-exec bt
1: (777701) <-1183-interpreter-exec console "bt"
1: (777704) ->~"#0 0x000000000047a4ea in ?? ()\n"
1: (777707) ->~"#1 0x00007ffd2dcdb1c0 in ?? ()\n"
1: (777709) ->~"#2 0x0000000000467efc in ?? ()\n"
1: (777711) ->~"#3 0x0000000000000000 in ?? ()\n"
注意:附加时,我收到以下警告:
警告:所选架构 i386 与报告的目标架构 i386:x86-64 不兼容
将架构设置为 i386:x86-64 被 gdb 接受但没有区别
设置断点会出现以下错误:
1: (40020) ->&"Cannot insert breakpoint 1.\n"
1: (40020) ->&"Cannot access memory at address 0xbce346f\n"
1: (40020) ->&"\n"
1: (40023) ->^error,msg="Command aborted."
更新:已解决 以为安装 gcc-multilib 解决了它,但问题似乎更可能是因为 Docker Desktop 中的错误已在 v3.2.2 中修复。请参阅下面我自己的回答中的说明。
解决方法
qemu-i386 的问题困扰着我,所以我决定尝试用 -m32 标志编译一个简单的 .c 来检查它是否也会触发通过 qemu 运行,因为我缺少 gcc-multilib 而出错,所以我安装了它.
启动 buildt 二进制文件并注意到它没有通过 qemu-i386 运行。 再次启动我的原始应用程序,这次它也没有通过 qemu 启动。 启动 gdb-multiarch,加载 bin 并附加到进程,现在突然一切正常,得到了一个很好的正确回溯!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。