aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Laskey <jlaskey@mac.com>2007-02-22 16:10:05 +0000
committerJim Laskey <jlaskey@mac.com>2007-02-22 16:10:05 +0000
commitcbfdb7b871ddb383c9b323d4b9fba112ad500214 (patch)
treed04aee41f1ef74b88a12abf1cc607443ea03c438
parent735b6f8cc3abe3d6939d44a39d2e512c32716538 (diff)
Tighten up error checking of args.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34493 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp40
1 files changed, 23 insertions, 17 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
index 8fb41027a0..5f1c942e96 100644
--- a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
+++ b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
@@ -2104,25 +2104,26 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) {
if (MMI) {
// Inform the MachineModuleInfo of the personality for this landing pad.
- if (ConstantExpr *CE = dyn_cast<ConstantExpr>(I.getOperand(2))) {
- if (CE->getOpcode() == Instruction::BitCast) {
- MMI->addPersonality(CurMBB,
- cast<Function>(CE->getOperand(0)));
- }
- }
+ ConstantExpr *CE = dyn_cast<ConstantExpr>(I.getOperand(2));
+ assert(CE && CE->getOpcode() == Instruction::BitCast &&
+ isa<Function>(CE->getOperand(0)) &&
+ "Personality should be a function");
+ MMI->addPersonality(CurMBB, cast<Function>(CE->getOperand(0)));
// Gather all the type infos for this landing pad and pass them along to
// MachineModuleInfo.
std::vector<GlobalVariable *> TyInfo;
for (unsigned i = 3, N = I.getNumOperands(); i < N; ++i) {
- if (ConstantExpr *CE = dyn_cast<ConstantExpr>(I.getOperand(i))) {
- if (CE->getOpcode() == Instruction::BitCast) {
- TyInfo.push_back(cast<GlobalVariable>(CE->getOperand(0)));
- continue;
- }
+ ConstantExpr *CE = dyn_cast<ConstantExpr>(I.getOperand(i));
+ if (CE && CE->getOpcode() == Instruction::BitCast &&
+ isa<GlobalVariable>(CE->getOperand(0))) {
+ 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");
+ TyInfo.push_back(NULL);
}
-
- TyInfo.push_back(NULL);
}
MMI->addCatchTypeInfo(CurMBB, TyInfo);
@@ -2149,10 +2150,15 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) {
if (MMI) {
// Find the type id for the given typeinfo.
GlobalVariable *GV = NULL;
- if (ConstantExpr *CE = dyn_cast<ConstantExpr>(I.getOperand(1))) {
- if (CE->getOpcode() == Instruction::BitCast) {
- GV = cast<GlobalVariable>(CE->getOperand(0));
- }
+ ConstantExpr *CE = dyn_cast<ConstantExpr>(I.getOperand(1));
+ if (CE && CE->getOpcode() == Instruction::BitCast &&
+ isa<GlobalVariable>(CE->getOperand(0))) {
+ GV = cast<GlobalVariable>(CE->getOperand(0));
+ } else {
+ ConstantInt *CI = dyn_cast<ConstantInt>(I.getOperand(1));
+ assert(CI && CI->getZExtValue() == 0 &&
+ "TypeInfo must be a global variable typeinfo or NULL");
+ GV = NULL;
}
unsigned TypeID = MMI->getTypeIDFor(GV);