获取 LLVM BasicBlock 的持久 ID

问题描述

我正在寻找一种方法——使用 LLVM API——来获取 BasicBlock 的标识符,我可以用它来查找(再次通过 API)同一个块。

无论这个 ID 是什么,我都需要它是“稳定的序列化”(在位码序列化/反序列化周期后保持有效并引用同一个块)。

块 ID 不一定是全局唯一的:如果 ID 对于函数是唯一的,我可以通过将块 ID 与函数的符号名称组合来创建一个全局唯一的对。

候选人:

  • 按迭代顺序的块索引(在父函数的块上)。但是迭代顺序是否已定义且稳定于序列化?
  • StringRef 返回的 Node->printAsOperand()。但是我可以使用它作为键来查询块的函数,还是必须进行大量字符串比较的搜索?这对序列化是否稳定?
  • 使用 Block::setName() 为每个块分配我自己的 ID。这会起作用,但会使位码膨胀。

谢谢。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...