diff options
author | Chris Lattner <sabre@nondot.org> | 2007-04-27 01:20:11 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-04-27 01:20:11 +0000 |
commit | 99f9a77c496e8dc65fa7d9f693de9bec9aa574e5 (patch) | |
tree | 6a22cdcc06eacb4981e3602cef8a37f74ee3736d /lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | |
parent | 6e21ff0b0a8e4f0878431afa5628bb1c2db0b8e1 (diff) |
improve EH global handling, patch by Duncan Sands.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36499 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp')
-rw-r--r-- | lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index db9bf0d0df..ac3eedfa3a 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -2610,14 +2610,18 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) { // MachineModuleInfo. std::vector<GlobalVariable *> TyInfo; for (unsigned i = 3, N = I.getNumOperands(); i < N; ++i) { - ConstantExpr *CE = dyn_cast<ConstantExpr>(I.getOperand(i)); - if (CE && CE->getOpcode() == Instruction::BitCast && - isa<GlobalVariable>(CE->getOperand(0))) { + Constant *C = cast<Constant>(I.getOperand(i)); + if (GlobalVariable *GV = dyn_cast<GlobalVariable>(C)) { + TyInfo.push_back(GV); + } else if (ConstantExpr *CE = dyn_cast<ConstantExpr>(C)) { + assert(CE->getOpcode() == Instruction::BitCast && + isa<GlobalVariable>(CE->getOperand(0)) + && "TypeInfo must be a global variable or NULL"); TyInfo.push_back(cast<GlobalVariable>(CE->getOperand(0))); } else { - ConstantInt *CI = dyn_cast<ConstantInt>(I.getOperand(i)); - assert(CI && CI->getZExtValue() == 0 && - "TypeInfo must be a global variable typeinfo or NULL"); + ConstantInt *CI = dyn_cast<ConstantInt>(C); + assert(CI && CI->isNullValue() && + "TypeInfo must be a global variable or NULL"); TyInfo.push_back(NULL); } } |