mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
TwoAddressInstructionPass doesn't really know how to merge live intervals when
lowering REG_SEQUENCE instructions. Insert copies for REG_SEQUENCE sources not killed to avoid breaking later passes. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104146 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
139c9e1f85
commit
3437352887
@ -1275,9 +1275,10 @@ bool TwoAddressInstructionPass::EliminateRegSequences() {
|
|||||||
|
|
||||||
if (!Seen.insert(SrcReg) ||
|
if (!Seen.insert(SrcReg) ||
|
||||||
MI->getParent() != DefMI->getParent() ||
|
MI->getParent() != DefMI->getParent() ||
|
||||||
|
!MI->getOperand(i).isKill() ||
|
||||||
HasOtherRegSequenceUses(SrcReg, MI, MRI)) {
|
HasOtherRegSequenceUses(SrcReg, MI, MRI)) {
|
||||||
// REG_SEQUENCE cannot have duplicated operands, add a copy.
|
// REG_SEQUENCE cannot have duplicated operands, add a copy.
|
||||||
// Also add an copy if the source if live-in the block. We don't want
|
// Also add an copy if the source is live-in the block. We don't want
|
||||||
// to end up with a partial-redef of a livein, e.g.
|
// to end up with a partial-redef of a livein, e.g.
|
||||||
// BB0:
|
// BB0:
|
||||||
// reg1051:10<def> =
|
// reg1051:10<def> =
|
||||||
@ -1287,6 +1288,10 @@ bool TwoAddressInstructionPass::EliminateRegSequences() {
|
|||||||
// BB2:
|
// BB2:
|
||||||
// reg1051:9<def> =
|
// reg1051:9<def> =
|
||||||
// LiveIntervalAnalysis won't like it.
|
// LiveIntervalAnalysis won't like it.
|
||||||
|
//
|
||||||
|
// If the REG_SEQUENCE doesn't kill its source, keeping live variables
|
||||||
|
// correctly up to date becomes very difficult. Insert a copy.
|
||||||
|
//
|
||||||
const TargetRegisterClass *RC = MRI->getRegClass(SrcReg);
|
const TargetRegisterClass *RC = MRI->getRegClass(SrcReg);
|
||||||
unsigned NewReg = MRI->createVirtualRegister(RC);
|
unsigned NewReg = MRI->createVirtualRegister(RC);
|
||||||
MachineBasicBlock::iterator InsertLoc = MI;
|
MachineBasicBlock::iterator InsertLoc = MI;
|
||||||
|
@ -302,6 +302,23 @@ bb14: ; preds = %bb6
|
|||||||
ret i32 0
|
ret i32 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; This test crashes the coalescer because live variables were not updated properly.
|
||||||
|
define <8 x i8> @t11(i8* %A1, i8* %A2, i8* %A3, i8* %A4, i8* %A5, i8* %A6, i8* %A7, i8* %A8, i8* %B) nounwind {
|
||||||
|
%tmp1d = call %struct.__neon_int8x8x3_t @llvm.arm.neon.vld3.v8i8(i8* %A4) ; <%struct.__neon_int8x8x3_t> [#uses=1]
|
||||||
|
%tmp2d = extractvalue %struct.__neon_int8x8x3_t %tmp1d, 0 ; <<8 x i8>> [#uses=1]
|
||||||
|
%tmp1f = call %struct.__neon_int8x8x3_t @llvm.arm.neon.vld3.v8i8(i8* %A6) ; <%struct.__neon_int8x8x3_t> [#uses=1]
|
||||||
|
%tmp2f = extractvalue %struct.__neon_int8x8x3_t %tmp1f, 0 ; <<8 x i8>> [#uses=1]
|
||||||
|
%tmp2bd = add <8 x i8> zeroinitializer, %tmp2d ; <<8 x i8>> [#uses=1]
|
||||||
|
%tmp2abcd = mul <8 x i8> zeroinitializer, %tmp2bd ; <<8 x i8>> [#uses=1]
|
||||||
|
%tmp2ef = sub <8 x i8> zeroinitializer, %tmp2f ; <<8 x i8>> [#uses=1]
|
||||||
|
%tmp2efgh = mul <8 x i8> %tmp2ef, undef ; <<8 x i8>> [#uses=2]
|
||||||
|
call void @llvm.arm.neon.vst3.v8i8(i8* %A2, <8 x i8> undef, <8 x i8> undef, <8 x i8> %tmp2efgh)
|
||||||
|
%tmp2 = sub <8 x i8> %tmp2efgh, %tmp2abcd ; <<8 x i8>> [#uses=1]
|
||||||
|
%tmp7 = mul <8 x i8> undef, %tmp2 ; <<8 x i8>> [#uses=1]
|
||||||
|
tail call void @llvm.arm.neon.vst3.v8i8(i8* %B, <8 x i8> undef, <8 x i8> undef, <8 x i8> %tmp7)
|
||||||
|
ret <8 x i8> undef
|
||||||
|
}
|
||||||
|
|
||||||
declare <4 x i32> @llvm.arm.neon.vld1.v4i32(i8*) nounwind readonly
|
declare <4 x i32> @llvm.arm.neon.vld1.v4i32(i8*) nounwind readonly
|
||||||
|
|
||||||
declare <8 x i16> @llvm.arm.neon.vld1.v8i16(i8*) nounwind readonly
|
declare <8 x i16> @llvm.arm.neon.vld1.v8i16(i8*) nounwind readonly
|
||||||
|
Loading…
x
Reference in New Issue
Block a user