对特定部分中的所有符号进行迭代,并获得它们的签名
Iterate over all symbols in a specific section and obtain their signatures
目标
我想解析链接到二进制文件特定部分(而不是共享库)的所有符号的签名。
我所做的
在汇编中,您可以定义section .example
(NASM语法),然后使用将其链接到二进制文件中的特定位置
exampleStart = .;
*(.example)
exampleEnd = .;
这允许我使用exampleStart
和exampleEnd
迭代所有符号,只要我知道它们是什么。例如,如果我知道所有符号都是不需要参数也不返回任何内容的方法,那么我可以将它们强制转换为void(*)()
并将它们作为方法调用。
问题
- 有没有一种方法可以在C++中定义节,类似于NASM中的
.section
语法 - 我可以告诉链接器创建一个类似符号表的东西吗?它还包含方法的签名
示例
在下面我想展示一个我想要实现的小例子(伪C++):
SECTION example
void somePrefix_myFunction() {
// ...
}
int somePrefix_anotherFunction(int a, int b) {
return a + b;
}
ENDSECTION
在其他地方,我希望能够迭代本节中的符号,并获得符号的位置和签名。
假设说一个二进制是指一个可执行文件,通常不能从linux上的可执行文件加载符号1-C++代码必须作为(共享)库编写或重构。然后,您将能够调用dlopen
和dlsym
来加载相关符号。
剩下的问题是如何定位这些符号?当您从汇编转移到C++,并且您的问题被标记为C++时,您将把对作为汇编标签的符号编码的大部分控制权交给编译器和链接器。例如,您将不得不考虑诸如C++名称篡改之类的事情。枚举名称的最佳方法是调用nm
列出所有符号,并解析输出以提取您感兴趣的符号名称——据我所知,nm
调用的linux API中没有您自己也可以调用的。有太多特定的文件格式知识,否则你必须考虑,在linux上枚举不同版本的链接器和可执行文件的符号。
编辑您表示nm
不是一个选项。鉴于此限制,我认为您将不得不手动维护符号列表。否则,您将看到do_lookup
在glibc中遍历链接映射时所做的基本工作的复制。
此外,请注意,您可能必须使用extern "C"
标记符号,以避免名称混乱,并能够理智地维护所讨论的符号列表。
1除了PIE可执行文件的特殊情况
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 迭代从 SWIG 绑定返回的 python 中的 vector<pair<int,int>>
- python+libclang;来回迭代:将字段注释绑定到字段
- 递归到迭代而不重新绑定引用
- 前向迭代器与多个绑定相结合的迭代速度太快
- 在字符串上迭代,但将定界器保持在子字符串中,包括其他规则
- 在迭代矢量的同时,不在绑定中
- 映射/设置迭代器未解除可绑定运行时错误
- 在使用 boost::fusion 迭代时将漂亮的打印机绑定到 boost::p hoenix actor
- 在Release模式(c++)下对迭代器进行绑定检查
- 映射插入迭代器绑定