c - 从 ELF 文件生成完整上下文符号表

标签 c gdb symbol-table

我正在尝试想出一种从编译的二进制文件生成符号表的巧妙方法。

尽管我愿意使用系统,但我通常使用功能齐全的 GNU 工具链进行嵌入式工作 实用程序(最好是 Windows/MSYS2/Cygwin)来提供帮助。我选择的脚本语言是 python,因为这是 我工作的公司内普遍使用的语言。

作为引用,以下大约 4 年前的帖子几乎正是我正在寻找的内容,而且我当时正在寻找 希望鉴于已经过去了很长一段时间,必须有一种更简单的方法来实现这一目标。

Extract detailed symbol information (struct members) from elf file compiled with ARM-GCC

我对gdb相当熟悉,习惯使用info变量p &nameptype name等。 最终需要的是如下所示的输入/输出。我需要支持所有结构、 union 、 枚举和类型的深度嵌套(结构内的结构内的结构)。我同意脱光一切 其他装饰,如静态、 volatile 、原子等。我还不确定我想用指针做什么,但是 我想最好在下面的 CSV 输出中的类型后附加一个星号。

示例代码

uint64_t myU64;
int64_t my64;

typedef struct {
    uint8_t aaa;
    int8_t bbb;
} myStruct2_t;

struct {
    uint32_t a;
    int32_t b;
    float c;
    enum {
        E_ONE = 100,
        E_TWO = 200,
        E_THREE = 300
    } myEnum;
    union {
        uint16_t aa;
        int16_t bb;
    } myUnion;
    myStruct2_t myStruct2[3];
    uint32_t myArr[2];
} myStruct;

期望的输出

myU64, 0x8001918, uint64_t
my64, 0x800191C, int64_t
myStruct.a, 0x8001920, uint32_t
myStruct.b, 0x8001924, int32_t
myStruct.c, 0x8001928, float
myStruct.myEnum, 0x800192C, int16_t <-- Requires deeper digging for enum
myStruct.myUnion.aa, 0x800192E, uint16_t
myStruct.myUnion.bb, 0x800192E, int16_t
myStruct.myStruct2[0].aaa, 0x8001930, uint8_t
myStruct.myStruct2[0].bbb, 0x8001931, int8_t
myStruct.myStruct2[1].aaa, 0x8001932, uint8_t
myStruct.myStruct2[1].bbb, 0x8001933, int8_t
myStruct.myStruct2[2].aaa, 0x8001934, uint8_t
myStruct.myStruct2[2].bbb, 0x8001935, int8_t
myStruct.myArr[0], 0x8001938, uint32_t
myStruct.myArr[1], 0x800193C, uint32_t

使用上面列出的 gdb 命令示例,我可以获得所有这些信息,但这需要我 编写一个极其复杂的字符串解析器。有任何想法吗?现有的工具或自动化的简单方法? 我同意必须创建一个工具,但到目前为止我的想法需要一个字符串解析怪物。我看过 简要介绍了 python/gdb API,但还没有看到非常适用的示例,但也许这是一条路线 我也可以。

此外,虽然我的重点是使用 gdb,但我对任何其他可以提供帮助的工具持开放态度。

谢谢!

最佳答案

slick way of generating a symbol table from my compiled binary.

您编译的二进制文件已经有一个符号表,而您尝试生成的内容与通常的符号表无关,从而造成不必要的困惑。

您正在寻找的是非标准格式的调试信息描述(标准格式是 DWARF,GDB 读取该格式以从 ptype 生成输出)。

要以编程方式读取 DWARF 调试信息,请使用 libdwarf .

关于c - 从 ELF 文件生成完整上下文符号表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53949702/

相关文章:

debugging - 硬件观察点是否仅适用于某些内存地址?

linux - 如何从停止的程序中获取核心转储 (linux)

c++ - (.eh) 在 nm 输出中意味着什么?

java - 在 Java 中创建符号表时在编译时考虑未知变量值

c - 在 C/C++ 中,是否可以导出结构内偏移量的链接器符号?

c - Macro中struct的问题定义

android - 如何在 ANDROID NDK 中从 C 文件调用 CPP 文件中的函数,反之亦然?

debugging - 你如何使用 gdb 来调试你的代码?

c - 显示 C 中头文件的更改定义

c - 使用回调和嵌套列表的 C 前缀表达式计算器