- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Apples GCC 在哪里/如何在可执行文件中存储 DWARF?
我通过 gcc -gdwarf-2
编译了一个二进制文件(苹果海湾合作委员会)。然而,objdump -g
也不是 objdump -h
确实向我展示了任何调试信息。
此外,libbfd 没有找到任何调试信息。 (我在 binutils-mailinglist 上询问了它 here 。)
但是,我可以通过 dsymutil
提取调试信息(变成一个 dSYM)。 libbfd 也能够读取这些调试信息。
最佳答案
在 Mac OS X 上,决定使用链接器 id
链接程序时不处理所有调试信息。调试信息经常是10x
程序可执行文件的大小,因此让链接器处理所有调试信息并将其包含在可执行二进制文件中是对链接时间的严重损害。对于迭代开发——编译、链接、编译、链接、调试、编译链接——这是一个真正的成功。
相反,编译器生成 DWARF
.s 文件中的调试信息,汇编器将其输出到 .o 文件中,链接器在可执行二进制文件中包含一个“调试映射”,它告诉调试信息用户所有符号在链接过程中重新定位的位置。
消费者(进行 .o 文件调试)从可执行文件加载调试映射,并根据需要处理 .o 文件中的所有 DWARF,根据调试映射的说明重新映射符号。dsymutil
可以被认为是调试信息链接器。它执行相同的过程——读取调试映射,从 .o 文件加载 DWARF,重新定位所有地址——然后在最终链接地址处输出所有 DWARF 的单个二进制文件。这是 dSYM 包。
一旦你有了一个 dSYM 包,你就拥有了任何 dwarf 读取工具(可以处理 Mach-O 二进制文件)可以处理的普通旧标准 DWARF。
还有一个额外的改进使所有这些工作,Mach-O 二进制文件中包含的 UUID。每次链接器创建二进制文件时,它都会在 LC_UUID 加载命令(v. otool -hlv
或 dwarfdump --uuid
)中发出一个 128 位 UUID。这唯一标识该二进制文件。当dsymutil
创建 dSYM,它包含该 UUID。如果 dSYM 和可执行文件具有匹配的 UUID,调试器只会将它们关联起来——没有狡猾的文件 mod 时间戳或类似的东西。
我们还可以使用 UUID 来定位二进制文件的 dSYM。它们出现在崩溃报告中,我们包含一个 Spotlight 导入器,您可以使用它来搜索它们,例如
mdfind "com_apple_xcode_dsym_uuids == E21A4165-29D5-35DC-D08D-368476F85EE1"
如果 dSYM 位于 Spotlight 索引位置。您甚至可以为您的公司拥有一个 dSYM 存储库,以及一个可以在给定 UUID 的情况下检索正确 dSYM 的程序 - 可能是一个小的 mysql 数据库或类似的东西 - 这样您就可以在随机可执行文件上运行调试器,然后立即进行所有调试该可执行文件的信息。您可以使用 UUID 做一些非常巧妙的事情。
但无论如何,要回答您的原始问题:未剥离的二进制文件具有调试映射,.o 文件具有 DWARF,以及何时 dsymutil
运行这些组合以创建 dSYM 包。
如果您想查看调试映射条目,请执行 nm -pa executable
他们都在那里。它们采用旧刺的形式nlist
记录 - 链接器已经知道如何处理 stabs,因此使用它们是最容易的 - 但是你会很容易地看到它是如何工作的,如果你不确定,可以引用一些 stabs 文档。
关于macos - Apples GCC 在哪里/如何在可执行文件中存储 DWARF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10044697/
谁能帮我写一个程序,它可以读取 DWARF 文件并给我文件名、行号和函数名的详细信息。 最佳答案 DWARF-2 和 DWARF-3 的规范在这里: http://dwarfstd.org/dwarf
XCode 支持此build设置的这 2 个值: build设置 > 构建选项 > 调试信息格式。 谁能解释一下区别? 最佳答案 不同之处在于,对于带有 dSYM 文件的 DWARF,您的存档 app
我想知道使用属性 DW_AT_location 进行调试。它是 dwarf 指定用于调试的属性之一,但无法真正理解它到底代表什么。以及当我们编译代码时应该什么时候发出这个属性。 最佳答案 来自 DWA
好的,我已经使用 Linux Dwarf ldw 库将 backtrace_symbols 输出转换为源代码和行号,但遇到了障碍。 backtrace_symbols 给出内存中的偏移量,在用作 Dw
考虑以下矮人代码示例 - : Abbrev Number: 1 (DW_TAG_compile_unit) DW_AT_producer : (indirect string, o
warning: invalid DWARF generated by the compiler: DIE 0x000629bb has multiple AT_decl_line attribute
我玩Dwarf Fortress游戏。对我来说主要的挑战是有效地设计堡垒的布局。这意味着,每个行业流应尽可能密集,以尽量减少行进距离。 食品行业就是一个例子 .每个灰色椭圆代表一座建筑物。每个白色矩形
对于 C/C++ 源文件中的任何元素,我希望能够在其编译的可执行文件中确定相应的内存位置。通过调试进行编译并使用生成的 DWARF 信息对实现这一目标大有帮助,但离我的目标还差得很远。 GCC 生成的
所有, 有没有工具可以检查文件的 DWARF 版本?像这样的东西: $ dwarf_tool binary_name 4 最佳答案 在Linux环境下?如果你安装了 GCC,你应该有 readelf可
我有一个通过内存跟踪程序执行的应用程序。我尝试使用 readelf --debug-dump=decodedline获取内存地址/行号信息,但我看到的内存地址通常与该转储给出的内存地址不匹配。我写了一
GCC 在其 DWARF 调试信息(使用 -g 编译时)中包含用于生成目标文件的源文件的路径。 然而,GDB的search rules意味着我必须使用鲜为人知的 set subsitute-path如
我试图将我对“DWARF”与“DWARF with dSYM file”调试信息格式的理解映射到我在不同 iOS 构建配置的崩溃信息中看到的内容。 我试图解决一个问题,即默认情况下不会对使用调试配置的
如何通过 DWARF 的引用获取我的变量地址? 例如我们有下一个结构: struct sub_struct { int a, b; sub_struct(int a, int b) :
我有一个 ARM 二进制文件,我需要准确找到其函数序言结束和尾声开始的地址。换句话说,我需要函数体的边界。例如,如果我有一个函数,其程序集类似于: 0x00000320 : push {r
有没有一种简单的方法可以让 Linux 进程访问它自己的 DWARF 调试信息?我有一个进程想要将一个特定编译单元的 DWARF 信息转储到日志文件中。 这是为了简化一些物流。我有包含原始 C 结构的
尝试构建时,我在 Xcode 4 中遇到以下错误: libIOSCoreSDK.a(Logging.o) object file doesn't contain DWARF debug informa
例如: : Abbrev Number: 1 (DW_TAG_compile_unit) DW_AT_producer : (indirect string, offset: 0
有没有办法将调试信息从 binutils 的 DWARF 格式(例如,由 Cygwin 上的 GCC 发出)转换为 Microsoft PDB(由 Visual Studio 使用)? 最佳答案 cv
在 perf record --call-graph dwarf 生成的回溯中由 perf script 打印,我一直在为大约 5% 的调用堆栈获取错误的地址,即展开失败。一个例子是 my_bin 7
我正在尝试从 DWARF 信息中获取有关调用约定的信息。更具体地说,我想了解哪些寄存器/堆栈位置用于将参数传递给函数。我的问题是,在某些情况下,我从 DWARF 转储中获得了某种错误的信息。我使用的示
我是一名优秀的程序员,十分优秀!