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:
Chris Lattner 2003-05-31 20:33:31 +00:00
parent 87a09562d5
commit 567cceea49

View File

@ -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;