diff options
| author | Chris Lattner <sabre@nondot.org> | 2002-08-20 19:35:11 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2002-08-20 19:35:11 +0000 |
| commit | 325398c6a4dc50d89096bfc141db19fdd13fc3d7 (patch) | |
| tree | 9fe19ce082b1ba5f29eee4247b452a08c00e4513 /llvm/lib/Transforms | |
| parent | a2d5b4d68ccc4dc400cbb6daa4d75cf46bd991cf (diff) | |
| download | bcm5719-llvm-325398c6a4dc50d89096bfc141db19fdd13fc3d7.tar.gz bcm5719-llvm-325398c6a4dc50d89096bfc141db19fdd13fc3d7.zip | |
fixed bug: test/Regression/Linker/2002-08-20-ConstantExpr.ll
llvm-svn: 3412
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/Utils/Linker.cpp | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/llvm/lib/Transforms/Utils/Linker.cpp b/llvm/lib/Transforms/Utils/Linker.cpp index 21e25b444a1..beab3d5a847 100644 --- a/llvm/lib/Transforms/Utils/Linker.cpp +++ b/llvm/lib/Transforms/Utils/Linker.cpp @@ -118,7 +118,16 @@ static Value *RemapOperand(const Value *In, map<const Value*, Value*> &LocalMap, Value *V = RemapOperand(CPR->getValue(), LocalMap, GlobalMap); Result = ConstantPointerRef::get(cast<GlobalValue>(V)); } else if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(CPV)) { - if (CE->getNumOperands() == 1) { + if (CE->getOpcode() == Instruction::GetElementPtr) { + Value *Ptr = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap); + std::vector<Constant*> Indices; + Indices.reserve(CE->getNumOperands()-1); + for (unsigned i = 1, e = CE->getNumOperands(); i != e; ++i) + Indices.push_back(cast<Constant>(RemapOperand(CE->getOperand(i), + LocalMap, GlobalMap))); + + Result = ConstantExpr::getGetElementPtr(cast<Constant>(Ptr), Indices); + } else if (CE->getNumOperands() == 1) { // Cast instruction assert(CE->getOpcode() == Instruction::Cast); Value *V = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap); @@ -131,16 +140,7 @@ static Value *RemapOperand(const Value *In, map<const Value*, Value*> &LocalMap, Result = ConstantExpr::get(CE->getOpcode(), cast<Constant>(V1), cast<Constant>(V2)); } else { - // GetElementPtr Expression - assert(CE->getOpcode() == Instruction::GetElementPtr); - Value *Ptr = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap); - std::vector<Constant*> Indices; - Indices.reserve(CE->getNumOperands()-1); - for (unsigned i = 1, e = CE->getNumOperands(); i != e; ++i) - Indices.push_back(cast<Constant>(RemapOperand(CE->getOperand(i), - LocalMap, GlobalMap))); - - Result = ConstantExpr::getGetElementPtr(cast<Constant>(Ptr), Indices); + assert(0 && "Unknown constant expr type!"); } } else { |

