mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-01 15:11:24 +00:00
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. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@71224 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4b7f7a6e1f
commit
ef554846f0
@ -903,9 +903,10 @@ void SROA::RewriteStoreUserOfWholeAlloca(StoreInst *SI,
|
||||
|
||||
// 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 @@ void SROA::RewriteLoadUserOfWholeAlloca(LoadInst *LI, AllocationInst *AI,
|
||||
|
||||
// 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;
|
||||
|
12
test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll
Normal file
12
test/Transforms/ScalarRepl/2009-05-08-I1Crash.ll
Normal file
@ -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
|
||||
}
|
Loading…
Reference in New Issue
Block a user