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 /llvm/lib/Transforms | |
| 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
Diffstat (limited to 'llvm/lib/Transforms')
| -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;      } | 

