使用llvm的CloneFunctionInto()

时间:2013-05-28 12:41:02

标签: llvm llvm-3.0

我需要在LLVM函数传递中通过CloneFunctionInto将函数克隆到另一个函数中,以保持原始控制流图不受我在第一个中所做的任何更改。

http://llvm.org/docs/doxygen/html/Cloning_8h_source.html

void CloneFunctionInto(Function *NewFunc, const Function *OldFunc, ValueToValueMapTy &VMap, bool ModuleLevelChanges, SmallVectorImpl<ReturnInst*> &Returns, const char *NameSuffix = "", ClonedCodeInfo *CodeInfo = 0, ValueMapTypeRemapper *TypeMapper = 0);

有人可以帮助我,因为我有一些缺失的部分,如ClonedCodeInfoValueMapTypeRemapper

如果你能给我一个例子来更好地理解

由于

1 个答案:

答案 0 :(得分:1)

doxygen拉取,ClonedCodeInfo类可用于获取有关您刚刚克隆的函数的信息,即函数是否包含调用或动态alloca指令。

ValueMapTypeRemapper的{​​{3}}告诉我们它是一个抽象基类,需要任何子类实现其remapType()方法。顾名思义,这可以用来将函数中的某些类型替换为其他类型。

以下是一些示例代码:

class MessageUpdater: public ValueMapTypeRemapper
{
public:
    Type *remapType(Type *SrcTy)
    {
        std::map<Type *, Type *>::iterator i, e;
        for (i = foo.begin(), e = foo.end(); i != e; ++i) {
            if (SrcTy == i->first) {
                return i->second;
            }
        }

        assert(0 && "Type not found in map!");
        return 0;
    }
    std::map<Type *, Type *> foo;
};

你可以这样称呼它:

MessageUpdater foobar;

foobar.foo.insert(std::make_pair(fromStruct, toStruct));
foobar.foo.insert(std::make_pair(fromStructPtr, toStructPtr));
foobar.foo.insert(std::make_pair(fromStructPtrPtr, toStructPtrPtr));

for (inst_iterator I = inst_begin(f), E = inst_end(f); I != E; ++I) {
    foobar.foo.insert(std::make_pair(I->getType(), I->getType()));
}

std::map<Type *, Type *>::iterator i, e;
for (i = foobar.foo.begin(), e = foobar.foo.end(); i != e; ++i) {
    errs() << *i->first << " maps to " << *i->second << "\n";
}

CloneFunctionInto(newFun, f, vmap, false, Returns, "", 0, &foobar);

您会注意到您不需要将ClonedCodeInfo对象传递给此函数,因此我只需传入0。