summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDuncan Sands <baldrick@free.fr>2012-03-15 20:14:42 +0000
committerDuncan Sands <baldrick@free.fr>2012-03-15 20:14:42 +0000
commitbd415dec4efcad127760755a138d65bea350c76a (patch)
treebc3c2c25e0ac6beb6098fb5d4de60b2369ee0e98
parentf232bb421a6e2524c4f4e059a8344300d6c8e96d (diff)
downloadbcm5719-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.cpp6
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;
OpenPOWER on IntegriCloud