[llvm-commits] [llvm] r71224 - in /llvm/trunk: lib/Transforms/Scalar/ScalarReplAggregates.cpp test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll
Chris Lattner
sabre at nondot.org
Fri May 8 08:54:54 PDT 2009
Author: lattner
Date: Fri May 8 10:54:41 2009
New Revision: 71224
URL: http://llvm.org/viewvc/llvm-project?rev=71224&view=rev
Log:
fix RewriteStoreUserOfWholeAlloca to use the correct type size
method, fixing a crash on PR4146. While the store will
ultimately overwrite the "padded size" number of bits in memory,
the stored value may be a subset of this size. This function
only wants to handle the case where all bits are stored.
Added:
llvm/trunk/test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll
Modified:
llvm/trunk/lib/Transforms/Scalar/ScalarReplAggregates.cpp
Modified: llvm/trunk/lib/Transforms/Scalar/ScalarReplAggregates.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/ScalarReplAggregates.cpp?rev=71224&r1=71223&r2=71224&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/ScalarReplAggregates.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/ScalarReplAggregates.cpp Fri May 8 10:54:41 2009
@@ -903,9 +903,10 @@
// If this isn't a store of an integer to the whole alloca, it may be a store
// to the first element. Just ignore the store in this case and normal SROA
- // will handle it.
+ // will handle it. We don't handle types here that have tail padding, like
+ // an alloca of type {i1}.
if (!isa<IntegerType>(SrcVal->getType()) ||
- TD->getTypePaddedSizeInBits(SrcVal->getType()) != AllocaSizeBits)
+ TD->getTypeSizeInBits(SrcVal->getType()) != AllocaSizeBits)
return;
DOUT << "PROMOTING STORE TO WHOLE ALLOCA: " << *AI << *SI;
@@ -1015,9 +1016,10 @@
// If this isn't a load of the whole alloca to an integer, it may be a load
// of the first element. Just ignore the load in this case and normal SROA
- // will handle it.
+ // will handle it. We don't handle types here that have tail padding, like
+ // an alloca of type {i1}.
if (!isa<IntegerType>(LI->getType()) ||
- TD->getTypePaddedSizeInBits(LI->getType()) != AllocaSizeBits)
+ TD->getTypeSizeInBits(LI->getType()) != AllocaSizeBits)
return;
DOUT << "PROMOTING LOAD OF WHOLE ALLOCA: " << *AI << *LI;
Added: llvm/trunk/test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll?rev=71224&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll (added)
+++ llvm/trunk/test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll Fri May 8 10:54:41 2009
@@ -0,0 +1,12 @@
+; RUN: llvm-as < %s | opt -scalarrepl | llvm-dis
+; PR4146
+
+ %wrapper = type { i1 }
+
+define void @f() {
+entry:
+ %w = alloca %wrapper, align 8 ; <%wrapper*> [#uses=1]
+ %0 = getelementptr %wrapper* %w, i64 0, i32 0 ; <i1*>
+ store i1 true, i1* %0
+ ret void
+}
More information about the llvm-commits
mailing list