mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-26 21:32:10 +00:00
The Thumb tADDrSPi instruction is not valid when the destination is SP.
Check for that and try narrowing it to tADDspi instead. Radar 8724703. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@120892 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7f76218720
commit
c24130bade
@ -58,7 +58,7 @@ namespace {
|
||||
{ ARM::t2ADDri, ARM::tADDi3, ARM::tADDi8, 3, 8, 1, 1, 0,0, 0 },
|
||||
{ ARM::t2ADDrr, ARM::tADDrr, ARM::tADDhirr, 0, 0, 1, 0, 0,1, 0 },
|
||||
// Note: immediate scale is 4.
|
||||
{ ARM::t2ADDrSPi,ARM::tADDrSPi,0, 8, 0, 1, 0, 1,0, 0 },
|
||||
{ ARM::t2ADDrSPi,ARM::tADDrSPi,0, 8, 0, 1, 0, 1,0, 1 },
|
||||
{ ARM::t2ADDSri,ARM::tADDi3, ARM::tADDi8, 3, 8, 1, 1, 2,2, 1 },
|
||||
{ ARM::t2ADDSrr,ARM::tADDrr, 0, 0, 0, 1, 0, 2,0, 1 },
|
||||
{ ARM::t2ANDrr, 0, ARM::tAND, 0, 0, 0, 1, 0,0, 0 },
|
||||
@ -469,6 +469,13 @@ Thumb2SizeReduce::ReduceSpecial(MachineBasicBlock &MBB, MachineInstr *MI,
|
||||
return true;
|
||||
return ReduceToNarrow(MBB, MI, Entry, LiveCPSR);
|
||||
}
|
||||
case ARM::t2ADDrSPi: {
|
||||
static const ReduceEntry NarrowEntry =
|
||||
{ ARM::t2ADDrSPi,ARM::tADDspi, 0, 7, 0, 1, 0, 1, 0, 1 };
|
||||
if (MI->getOperand(0).getReg() == ARM::SP)
|
||||
return ReduceToNarrow(MBB, MI, NarrowEntry, LiveCPSR);
|
||||
return ReduceToNarrow(MBB, MI, Entry, LiveCPSR);
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
11
test/CodeGen/Thumb2/2010-12-03-AddSPNarrowing.ll
Normal file
11
test/CodeGen/Thumb2/2010-12-03-AddSPNarrowing.ll
Normal file
@ -0,0 +1,11 @@
|
||||
; RUN: llc < %s -mtriple=thumbv7-apple-darwin | FileCheck %s
|
||||
; Radar 8724703: Make sure that a t2ADDrSPi instruction with SP as the
|
||||
; destination register is narrowed to tADDspi instead of tADDrSPi.
|
||||
|
||||
define void @test() nounwind {
|
||||
entry:
|
||||
; CHECK: sub.w
|
||||
; CHECK: add.w
|
||||
%Buffer.i = alloca [512 x i8], align 4
|
||||
ret void
|
||||
}
|
Loading…
Reference in New Issue
Block a user