diff options
| author | Robert Bocchino <bocchino@illinois.edu> | 2006-01-19 23:53:23 +0000 |
|---|---|---|
| committer | Robert Bocchino <bocchino@illinois.edu> | 2006-01-19 23:53:23 +0000 |
| commit | 027c18da98ed3a03f159d25d63f75cd2f2092762 (patch) | |
| tree | 10303239f7d980cc5a68ff6072598bd5cbd8d607 | |
| parent | 9c30bd5e2566b8be68c0211d01651886a2ad6255 (diff) | |
| download | bcm5719-llvm-027c18da98ed3a03f159d25d63f75cd2f2092762.tar.gz bcm5719-llvm-027c18da98ed3a03f159d25d63f75cd2f2092762.zip | |
ConstantFoldLoadThroughGEPConstantExpr wasn't handling pointers to
packed types correctly.
llvm-svn: 25470
| -rw-r--r-- | llvm/lib/Transforms/Utils/Local.cpp | 31 |
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; } |

