在LLVM中查找基本块的后继列表 [英] Finding the list of successors of a basic block in LLVM

查看:40
本文介绍了在LLVM中查找基本块的后继列表的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在LLVM中,BasicBlock具有属性getSinglePredecessor()和getSingleSuccessor(),但我需要获取基本块的后继者和前置者的完整列表。如何在llvm中实现这一点?

我的代码是

        virtual bool runOnFunction(Function &F) {

        for (Function::iterator b = F.begin(), be = F.end(); b != be; ++b) { 
        //Here I need to get the predecessor and successsor of the basic block b 
    }
}

推荐答案

我同意BasicBlock没有直接属性。相反,您可以对基本块执行get the terminator instruction,然后迭代其successors

或者,基于将source code读取到BasicBlock类,您可以从BasicBlock实例创建一个pred_iterator和ucc_iterator。例如:

for (Function::iterator b = F.begin(), be = F.end(); b != be; ++b)
{
    BasicBlock* bb = dyn_cast<BasicBlock>(&*b);
    for (pred_iterator pit = pred_begin(bb), pet = pred_end(bb); pit != pet; ++pit)

这篇关于在LLVM中查找基本块的后继列表的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆