summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorRobert Bocchino <bocchino@illinois.edu>2006-01-19 23:53:23 +0000
committerRobert Bocchino <bocchino@illinois.edu>2006-01-19 23:53:23 +0000
commit027c18da98ed3a03f159d25d63f75cd2f2092762 (patch)
tree10303239f7d980cc5a68ff6072598bd5cbd8d607 /llvm/lib/Transforms
parent9c30bd5e2566b8be68c0211d01651886a2ad6255 (diff)
downloadbcm5719-llvm-027c18da98ed3a03f159d25d63f75cd2f2092762.tar.gz
bcm5719-llvm-027c18da98ed3a03f159d25d63f75cd2f2092762.zip
ConstantFoldLoadThroughGEPConstantExpr wasn't handling pointers to
packed types correctly. llvm-svn: 25470
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/Utils/Local.cpp31
1 files changed, 22 insertions, 9 deletions
diff --git a/llvm/lib/Transforms/Utils/Local.cpp b/llvm/lib/Transforms/Utils/Local.cpp
index f2598c16ce4..9685e94cc19 100644
--- a/llvm/lib/Transforms/Utils/Local.cpp
+++ b/llvm/lib/Transforms/Utils/Local.cpp
@@ -267,16 +267,29 @@ Constant *llvm::ConstantFoldLoadThroughGEPConstantExpr(Constant *C,
return 0;
}
} else if (ConstantInt *CI = dyn_cast<ConstantInt>(I.getOperand())) {
- const ArrayType *ATy = cast<ArrayType>(*I);
- if ((uint64_t)CI->getRawValue() >= ATy->getNumElements()) return 0;
- if (ConstantArray *CA = dyn_cast<ConstantArray>(C))
- C = CA->getOperand((unsigned)CI->getRawValue());
- else if (isa<ConstantAggregateZero>(C))
- C = Constant::getNullValue(ATy->getElementType());
- else if (isa<UndefValue>(C))
- C = UndefValue::get(ATy->getElementType());
- else
+ if (const ArrayType *ATy = dyn_cast<ArrayType>(*I)) {
+ if ((uint64_t)CI->getRawValue() >= ATy->getNumElements()) return 0;
+ if (ConstantArray *CA = dyn_cast<ConstantArray>(C))
+ C = CA->getOperand((unsigned)CI->getRawValue());
+ else if (isa<ConstantAggregateZero>(C))
+ C = Constant::getNullValue(ATy->getElementType());
+ else if (isa<UndefValue>(C))
+ C = UndefValue::get(ATy->getElementType());
+ else
+ return 0;
+ } else if (const PackedType *PTy = dyn_cast<PackedType>(*I)) {
+ if ((uint64_t)CI->getRawValue() >= PTy->getNumElements()) return 0;
+ if (ConstantPacked *CP = dyn_cast<ConstantPacked>(C))
+ C = CP->getOperand((unsigned)CI->getRawValue());
+ else if (isa<ConstantAggregateZero>(C))
+ C = Constant::getNullValue(PTy->getElementType());
+ else if (isa<UndefValue>(C))
+ C = UndefValue::get(PTy->getElementType());
+ else
+ return 0;
+ } else {
return 0;
+ }
} else {
return 0;
}
OpenPOWER on IntegriCloud