c++ - 如何将 strip 与 split-dwarf 结合使用?

标签 c++ debugging gcc gdb debug-symbols

我目前正在尝试使用 --gsplit-dwarf gcc 标志来自动创建调试符号并将其与构建库/可执行文件分开。 More info on DWARF Obj files .然而,我观察到的是 split-dwarf 仍然在剩余的 .o 文件中留下了很多不必要的信息。我想做的是使用 strip 删除该信息,但仍然可以使用 .dwo/.dwp 文件进行调试;但是,这似乎不起作用。我想剥离发布的可执行文件以节省空间并进一步混淆,并希望 split-dwarf 允许我这样做。

Additional reference

示例应用 app.cpp

 
int main()
{
  int a = 1;
  std::cout << "Split DWARF test" << std::endl;
 
  return 0;
}

编译:

g++ -c -gsplit-dwarf app.cpp -o app_dwarf.o

链接:

g++ app_dwarf.o -o app_dwarf -fuse-ld=gold -Wl,--gdb-index

检查构建工件:

readelf -wi app_dwarf
Contents of the .debug_info section:

  Compilation Unit @ offset 0x0:
   Length:        0x30 (32-bit)
   Version:       4
   Abbrev Offset: 0x0
   Pointer Size:  8
 <0><b>: Abbrev Number: 1 (DW_TAG_compile_unit)
    <c>   DW_AT_low_pc      : 0x8da
    <14>   DW_AT_high_pc     : 0x9c
    <1c>   DW_AT_stmt_list   : 0x0
    <20>   DW_AT_GNU_dwo_name: (indirect string, offset: 0x0): app_dwarf.dwo
    <24>   DW_AT_comp_dir    : (indirect string, offset: 0xe): /home/ross/Desktop/dwarf_test
    <28>   DW_AT_GNU_pubnames: 1
    <28>   DW_AT_GNU_addr_base: 0x0
    <2c>   DW_AT_GNU_dwo_id  : 0xdf705add23e14a0b

可以看到它引用了 dwo... 这在 GDB 中也有效,但在我删除 dwo 文件时不起作用。但是,如果我查看构建工件(可执行文件)的符号表,完整的符号表仍然存在。

如果我剥离可执行文件,表将被移除并且大小会减小,但它也会剥离引用 dwo 文件的 debug_info

另外,dwo文件中不应该包含符号表吗?

希望可以在这里提供一些指导,让我能够捕获工件本身之外的所有调试信息,以便稍后进行调试。

另一种方法是采用多阶段方法,我们可以这样做:

g++ -g -o app_dwarf app.cpp 
objcopy --only-keep-debug app_dwarf app_dwarf.debug
objcopy --add-gnu-debuglink=app_dwarf.debug app_dwarf
strip --strip-unneeded app_dwarf

但需要将其分为编译和链接步骤,以便构建时间和资源受到的影响较小。不过,我认为这就是单个 gsplit-dwarf 标志的全部意义。

最佳答案

If I strip the executable, the table is removed and the size is reduced, but it also strips away the debug_info that references the dwo file.

正确。

正确的方法是保留可执行文件和 .dwp 文件的未剥离拷贝,同时将剥离后的拷贝分发给最终用户。

I thought that was the whole point of the single gsplit-dwarf flag, though.

没有。

解释动机here .引用:“通过在编译时将调试信息分成两部分——一部分保留在 .o 文件中,另一部分写入并行 .dwo(“DWARF 对象”)文件——我们可以减少链接器处理的目标文件的总大小。”

如果链接器处理的目标文件的总大小对您来说不是问题(对于小于 1 GiB 的二进制文件来说很少是问题),那么您真的不需要裂变(尽管它可能仍会加快您的链接速度)。

关于c++ - 如何将 strip 与 split-dwarf 结合使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69368754/

相关文章:

c++ - hdf5中的并行读取

c++静态 vector 在DLL中丢失元素

javascript - 从 chrome 中删除所有断点

visual-studio - 在 Visual Studio 上调试时返回上一行

qt - 如何在Qt Creator中选择自定义编译器 "Tool chain"

c - 我怎样才能让 gcc 像数组访问一样对待开关中的字段访问?

C++11 正则表达式多次匹配捕获组

c++ - 如何定义一个可以拥有任意参数的模板类?

debugging - 是否可以使用gdb和qemu同时调试linux用户空间程序和内核空间?

c++ - 编译器检查未实例化的模板代码是什么?