aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-09-11 21:43:16 +0000
committerChris Lattner <sabre@nondot.org>2006-09-11 21:43:16 +0000
commit63d3220dae7e28116327f419c9b38b541eac1f32 (patch)
tree48c5f5046b2c4f579d98821de749f07e0b95c509
parentc42354904eb588cc62f1f1b76e44c71b951cd2f3 (diff)
Fix PR905 and InstCombine/2006-09-11-EmptyStructCrash.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30266 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Transforms/Scalar/InstructionCombining.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp
index 0e6c1b1f2d..6961806bcb 100644
--- a/lib/Transforms/Scalar/InstructionCombining.cpp
+++ b/lib/Transforms/Scalar/InstructionCombining.cpp
@@ -5187,7 +5187,8 @@ Instruction *InstCombiner::visitCastInst(CastInst &CI) {
Constant *ZeroUInt = Constant::getNullValue(Type::UIntTy);
unsigned NumZeros = 0;
while (SrcTy != DstTy &&
- isa<CompositeType>(SrcTy) && !isa<PointerType>(SrcTy)) {
+ isa<CompositeType>(SrcTy) && !isa<PointerType>(SrcTy) &&
+ SrcTy->getNumContainedTypes() /* not "{}" */) {
SrcTy = cast<CompositeType>(SrcTy)->getTypeAtIndex(ZeroUInt);
++NumZeros;
}