summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/DataStructure
diff options
context:
space:
mode:
authorAndrew Lenharth <andrewl@lenharth.org>2006-04-13 19:31:49 +0000
committerAndrew Lenharth <andrewl@lenharth.org>2006-04-13 19:31:49 +0000
commit4aa300162537baf27cb233b32f6f87b3128ee47c (patch)
tree6f5af50efc13b5ea75c4ee0198043afe758b00fc /llvm/lib/Analysis/DataStructure
parent709eaacb36e36affddf020b60459778be8299c65 (diff)
downloadbcm5719-llvm-4aa300162537baf27cb233b32f6f87b3128ee47c.tar.gz
bcm5719-llvm-4aa300162537baf27cb233b32f6f87b3128ee47c.zip
Handle some kernel code than ends in [0 x sbyte]. I think this is safe
llvm-svn: 27672
Diffstat (limited to 'llvm/lib/Analysis/DataStructure')
-rw-r--r--llvm/lib/Analysis/DataStructure/Local.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/llvm/lib/Analysis/DataStructure/Local.cpp b/llvm/lib/Analysis/DataStructure/Local.cpp
index 72eee24964e..f191bb3159b 100644
--- a/llvm/lib/Analysis/DataStructure/Local.cpp
+++ b/llvm/lib/Analysis/DataStructure/Local.cpp
@@ -1116,8 +1116,17 @@ void GraphBuilder::MergeConstantInitIntoNode(DSNodeHandle &NH, Constant *C) {
const StructLayout *SL = TD.getStructLayout(CS->getType());
for (unsigned i = 0, e = CS->getNumOperands(); i != e; ++i) {
DSNode *NHN = NH.getNode();
- DSNodeHandle NewNH(NHN, NH.getOffset()+(unsigned)SL->MemberOffsets[i]);
- MergeConstantInitIntoNode(NewNH, cast<Constant>(CS->getOperand(i)));
+ //Some programmers think ending a structure with a [0 x sbyte] is cute
+ //This should be ok as the allocation type should grow this type when
+ //it is merged in if it is bigger.
+ if (SL->MemberOffsets[i] < SL->StructSize) {
+ DSNodeHandle NewNH(NHN, NH.getOffset()+(unsigned)SL->MemberOffsets[i]);
+ MergeConstantInitIntoNode(NewNH, cast<Constant>(CS->getOperand(i)));
+ } else if (SL->MemberOffsets[i] == SL->StructSize) {
+ DEBUG(std::cerr << "Zero size element at end of struct\n");
+ } else {
+ assert(0 && "type was smaller than offsets of of struct layout indicate");
+ }
}
} else if (isa<ConstantAggregateZero>(C) || isa<UndefValue>(C)) {
// Noop
OpenPOWER on IntegriCloud