Fix bug: FunctionResolve/2003-05-31-FuncPointerResolve.ll

llvm-svn: 6479
This commit is contained in:
Chris Lattner 2003-05-31 20:33:31 +00:00
parent 9c6e99cae6
commit 5ef98de61c
1 changed files with 3 additions and 11 deletions

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;