diff options
author | Duncan Sands <baldrick@free.fr> | 2012-03-15 20:14:42 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2012-03-15 20:14:42 +0000 |
commit | bd415dec4efcad127760755a138d65bea350c76a (patch) | |
tree | bc3c2c25e0ac6beb6098fb5d4de60b2369ee0e98 | |
parent | f232bb421a6e2524c4f4e059a8344300d6c8e96d (diff) | |
download | bcm5719-llvm-bd415dec4efcad127760755a138d65bea350c76a.tar.gz bcm5719-llvm-bd415dec4efcad127760755a138d65bea350c76a.zip |
Type sizes and fields offsets inside structs are unsigned. This is a highly
theoretical fix since it only matters for types with >= 2^63 bits (!) and also
only matters if pointers have more than 64 bits, which is not supported anyway.
llvm-svn: 152831
-rw-r--r-- | llvm/lib/Analysis/InstructionSimplify.cpp | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/llvm/lib/Analysis/InstructionSimplify.cpp b/llvm/lib/Analysis/InstructionSimplify.cpp index b095bc42726..f8d159dc438 100644 --- a/llvm/lib/Analysis/InstructionSimplify.cpp +++ b/llvm/lib/Analysis/InstructionSimplify.cpp @@ -673,13 +673,11 @@ static bool accumulateGEPOffset(const TargetData &TD, GEPOperator *GEP, if (StructType *STy = dyn_cast<StructType>(*GTI)) { unsigned ElementIdx = OpC->getZExtValue(); const StructLayout *SL = TD.getStructLayout(STy); - Offset += APInt(IntPtrWidth, SL->getElementOffset(ElementIdx), - /*isSigned=*/true); + Offset += APInt(IntPtrWidth, SL->getElementOffset(ElementIdx)); continue; } - APInt TypeSize(IntPtrWidth, TD.getTypeAllocSize(GTI.getIndexedType()), - /*isSigned=*/true); + APInt TypeSize(IntPtrWidth, TD.getTypeAllocSize(GTI.getIndexedType())); Offset += OpC->getValue().sextOrTrunc(IntPtrWidth) * TypeSize; } return true; |