如何在LLVM中从BasicBlock中识别后台
How can I identify a backedge from a BasicBlock in LLVM
我正在编写一个LLVM过程,该过程分析并修改生成的IR代码。有没有一种方法可以识别后边缘,我的意思是知道BasicBlock的继任者是否真的在路径上的某个位置。
是的,有.
首先,请注意,您需要区分"通往BB的每条路径都必须经过A"answers"从A到BB有一些路径"。
我认为你正在寻找第一种情况——告诉基本块BB的后继A是否是执行必须通过才能到达B的基本块。
当这种情况发生时,我们说"A支配B"。检查优势的接口是通过DominatorTree类(在pass的getAnalysisUsage函数中添加。有关示例,请参阅编写llvm pass)。
相关文章:
- 提升 ASIO 无法识别计时器对象
- 从udp接收帧对于人脸识别来说太慢
- 模板类无法识别友元运算符
- std::visit无法识别类型
- 无法识别模板功能
- 我有两个类需要在同一 cpp 文件中相互引用,但第一个类无法识别第二个类类型的对象
- 如何在LLVM中dyn_cast以识别StoreInst?
- 从不同的附加依赖项中识别等同命名的函数
- C++出现控制台错误.我无法识别源代码的问题
- VSCode IntelliSense无法识别SDL框架的SDL_image扩展库
- Qt:"Q3DScatter"即使包含在内也无法识别
- 使用指针的类识别
- 如何静态识别动态堆分配?
- 为什么C++无法识别我的对象实例化?
- C++ 无法识别创建进程'telnet'
- 识别 2D 矢量C++中的位置
- 如何识别项目是 QT 中的文件还是文件夹
- ESP32 无法识别任何设备已连接到其接入点
- 如何在LLVM中从BasicBlock中识别后台
- 识别后台进程并在 C++ WIN32 中置于前台