mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-07 12:28:24 +00:00
ARM: Clean up copyPhysReg() a bit.
No functional change, just cleaning things up for readability. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@193138 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -690,26 +690,47 @@ void ARMBaseInstrInfo::copyPhysReg(MachineBasicBlock &MBB,
|
||||
int Spacing = 1;
|
||||
|
||||
// Use VORRq when possible.
|
||||
if (ARM::QQPRRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VORRq, BeginIdx = ARM::qsub_0, SubRegs = 2;
|
||||
else if (ARM::QQQQPRRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VORRq, BeginIdx = ARM::qsub_0, SubRegs = 4;
|
||||
if (ARM::QQPRRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VORRq;
|
||||
BeginIdx = ARM::qsub_0;
|
||||
SubRegs = 2;
|
||||
} else if (ARM::QQQQPRRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VORRq;
|
||||
BeginIdx = ARM::qsub_0;
|
||||
SubRegs = 4;
|
||||
// Fall back to VMOVD.
|
||||
else if (ARM::DPairRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VMOVD, BeginIdx = ARM::dsub_0, SubRegs = 2;
|
||||
else if (ARM::DTripleRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VMOVD, BeginIdx = ARM::dsub_0, SubRegs = 3;
|
||||
else if (ARM::DQuadRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VMOVD, BeginIdx = ARM::dsub_0, SubRegs = 4;
|
||||
else if (ARM::GPRPairRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::MOVr, BeginIdx = ARM::gsub_0, SubRegs = 2;
|
||||
|
||||
else if (ARM::DPairSpcRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VMOVD, BeginIdx = ARM::dsub_0, SubRegs = 2, Spacing = 2;
|
||||
else if (ARM::DTripleSpcRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VMOVD, BeginIdx = ARM::dsub_0, SubRegs = 3, Spacing = 2;
|
||||
else if (ARM::DQuadSpcRegClass.contains(DestReg, SrcReg))
|
||||
Opc = ARM::VMOVD, BeginIdx = ARM::dsub_0, SubRegs = 4, Spacing = 2;
|
||||
} else if (ARM::DPairRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VMOVD;
|
||||
BeginIdx = ARM::dsub_0;
|
||||
SubRegs = 2;
|
||||
} else if (ARM::DTripleRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VMOVD;
|
||||
BeginIdx = ARM::dsub_0;
|
||||
SubRegs = 3;
|
||||
} else if (ARM::DQuadRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VMOVD;
|
||||
BeginIdx = ARM::dsub_0;
|
||||
SubRegs = 4;
|
||||
} else if (ARM::GPRPairRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::MOVr;
|
||||
BeginIdx = ARM::gsub_0;
|
||||
SubRegs = 2;
|
||||
} else if (ARM::DPairSpcRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VMOVD;
|
||||
BeginIdx = ARM::dsub_0;
|
||||
SubRegs = 2;
|
||||
Spacing = 2;
|
||||
} else if (ARM::DTripleSpcRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VMOVD;
|
||||
BeginIdx = ARM::dsub_0;
|
||||
SubRegs = 3;
|
||||
Spacing = 2;
|
||||
} else if (ARM::DQuadSpcRegClass.contains(DestReg, SrcReg)) {
|
||||
Opc = ARM::VMOVD;
|
||||
BeginIdx = ARM::dsub_0;
|
||||
SubRegs = 4;
|
||||
Spacing = 2;
|
||||
}
|
||||
|
||||
assert(Opc && "Impossible reg-to-reg copy");
|
||||
|
||||
@@ -732,8 +753,7 @@ void ARMBaseInstrInfo::copyPhysReg(MachineBasicBlock &MBB,
|
||||
assert(!DstRegs.count(Src) && "destructive vector copy");
|
||||
DstRegs.insert(Dst);
|
||||
#endif
|
||||
Mov = BuildMI(MBB, I, I->getDebugLoc(), get(Opc), Dst)
|
||||
.addReg(Src);
|
||||
Mov = BuildMI(MBB, I, I->getDebugLoc(), get(Opc), Dst).addReg(Src);
|
||||
// VORR takes two source operands.
|
||||
if (Opc == ARM::VORRq)
|
||||
Mov.addReg(Src);
|
||||
|
Reference in New Issue
Block a user