mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-19 19:03:50 +00:00
Fix bug: FunctionResolve/2003-05-31-FuncPointerResolve.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6479 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
87a09562d5
commit
567cceea49
@ -188,17 +188,9 @@ static bool ResolveFunctions(Module &M, std::vector<GlobalValue*> &Globals,
|
||||
++i;
|
||||
}
|
||||
} else if (ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(U)) {
|
||||
if (CPR->use_size() == 1 && isa<ConstantExpr>(CPR->use_back()) &&
|
||||
cast<ConstantExpr>(CPR->use_back())->getOpcode() ==
|
||||
Instruction::Cast) {
|
||||
ConstantExpr *CE = cast<ConstantExpr>(CPR->use_back());
|
||||
Constant *NewCPR = ConstantPointerRef::get(Concrete);
|
||||
CE->replaceAllUsesWith(ConstantExpr::getCast(NewCPR,CE->getType()));
|
||||
CPR->destroyConstant();
|
||||
} else {
|
||||
std::cerr << "Cannot convert use of function: " << CPR << "\n";
|
||||
++i;
|
||||
}
|
||||
Constant *NewCPR = ConstantPointerRef::get(Concrete);
|
||||
CPR->replaceAllUsesWith(ConstantExpr::getCast(NewCPR,CPR->getType()));
|
||||
CPR->destroyConstant();
|
||||
} else {
|
||||
std::cerr << "Cannot convert use of function: " << U << "\n";
|
||||
++i;
|
||||
|
Loading…
x
Reference in New Issue
Block a user