我需要在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);
有人可以帮助我,因为我有一些缺失的部分,如ClonedCodeInfo
和ValueMapTypeRemapper
?
如果你能给我一个例子来更好地理解
由于
答案 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。