mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-25 00:33:15 +00:00
Use TargetOpcode::COPY instead of X86-native register copy instructions when
lowering atomics. This will allow those copies to still be coalesced after TII::isMoveInstr is removed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@108385 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4bb327d03f
commit
b5378ea12e
@ -7999,7 +7999,6 @@ X86TargetLowering::EmitAtomicBitwiseWithCustomInserter(MachineInstr *bInstr,
|
|||||||
unsigned immOpc,
|
unsigned immOpc,
|
||||||
unsigned LoadOpc,
|
unsigned LoadOpc,
|
||||||
unsigned CXchgOpc,
|
unsigned CXchgOpc,
|
||||||
unsigned copyOpc,
|
|
||||||
unsigned notOpc,
|
unsigned notOpc,
|
||||||
unsigned EAXreg,
|
unsigned EAXreg,
|
||||||
TargetRegisterClass *RC,
|
TargetRegisterClass *RC,
|
||||||
@ -8076,7 +8075,7 @@ X86TargetLowering::EmitAtomicBitwiseWithCustomInserter(MachineInstr *bInstr,
|
|||||||
MIB.addReg(tt);
|
MIB.addReg(tt);
|
||||||
(*MIB).addOperand(*argOpers[valArgIndx]);
|
(*MIB).addOperand(*argOpers[valArgIndx]);
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), EAXreg);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), EAXreg);
|
||||||
MIB.addReg(t1);
|
MIB.addReg(t1);
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(CXchgOpc));
|
MIB = BuildMI(newMBB, dl, TII->get(CXchgOpc));
|
||||||
@ -8087,7 +8086,7 @@ X86TargetLowering::EmitAtomicBitwiseWithCustomInserter(MachineInstr *bInstr,
|
|||||||
(*MIB).setMemRefs(bInstr->memoperands_begin(),
|
(*MIB).setMemRefs(bInstr->memoperands_begin(),
|
||||||
bInstr->memoperands_end());
|
bInstr->memoperands_end());
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), destOper.getReg());
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), destOper.getReg());
|
||||||
MIB.addReg(EAXreg);
|
MIB.addReg(EAXreg);
|
||||||
|
|
||||||
// insert branch
|
// insert branch
|
||||||
@ -8123,7 +8122,6 @@ X86TargetLowering::EmitAtomicBit6432WithCustomInserter(MachineInstr *bInstr,
|
|||||||
|
|
||||||
const TargetRegisterClass *RC = X86::GR32RegisterClass;
|
const TargetRegisterClass *RC = X86::GR32RegisterClass;
|
||||||
const unsigned LoadOpc = X86::MOV32rm;
|
const unsigned LoadOpc = X86::MOV32rm;
|
||||||
const unsigned copyOpc = X86::MOV32rr;
|
|
||||||
const unsigned NotOpc = X86::NOT32r;
|
const unsigned NotOpc = X86::NOT32r;
|
||||||
const TargetInstrInfo *TII = getTargetMachine().getInstrInfo();
|
const TargetInstrInfo *TII = getTargetMachine().getInstrInfo();
|
||||||
const BasicBlock *LLVM_BB = MBB->getBasicBlock();
|
const BasicBlock *LLVM_BB = MBB->getBasicBlock();
|
||||||
@ -8233,14 +8231,14 @@ X86TargetLowering::EmitAtomicBit6432WithCustomInserter(MachineInstr *bInstr,
|
|||||||
MIB.addReg(t2);
|
MIB.addReg(t2);
|
||||||
(*MIB).addOperand(*argOpers[valArgIndx + 1]);
|
(*MIB).addOperand(*argOpers[valArgIndx + 1]);
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), X86::EAX);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), X86::EAX);
|
||||||
MIB.addReg(t1);
|
MIB.addReg(t1);
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), X86::EDX);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), X86::EDX);
|
||||||
MIB.addReg(t2);
|
MIB.addReg(t2);
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), X86::EBX);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), X86::EBX);
|
||||||
MIB.addReg(t5);
|
MIB.addReg(t5);
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), X86::ECX);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), X86::ECX);
|
||||||
MIB.addReg(t6);
|
MIB.addReg(t6);
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(X86::LCMPXCHG8B));
|
MIB = BuildMI(newMBB, dl, TII->get(X86::LCMPXCHG8B));
|
||||||
@ -8251,9 +8249,9 @@ X86TargetLowering::EmitAtomicBit6432WithCustomInserter(MachineInstr *bInstr,
|
|||||||
(*MIB).setMemRefs(bInstr->memoperands_begin(),
|
(*MIB).setMemRefs(bInstr->memoperands_begin(),
|
||||||
bInstr->memoperands_end());
|
bInstr->memoperands_end());
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), t3);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), t3);
|
||||||
MIB.addReg(X86::EAX);
|
MIB.addReg(X86::EAX);
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(copyOpc), t4);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), t4);
|
||||||
MIB.addReg(X86::EDX);
|
MIB.addReg(X86::EDX);
|
||||||
|
|
||||||
// insert branch
|
// insert branch
|
||||||
@ -8332,12 +8330,12 @@ X86TargetLowering::EmitAtomicMinMaxWithCustomInserter(MachineInstr *mInstr,
|
|||||||
|
|
||||||
unsigned t2 = F->getRegInfo().createVirtualRegister(X86::GR32RegisterClass);
|
unsigned t2 = F->getRegInfo().createVirtualRegister(X86::GR32RegisterClass);
|
||||||
if (argOpers[valArgIndx]->isReg())
|
if (argOpers[valArgIndx]->isReg())
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(X86::MOV32rr), t2);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), t2);
|
||||||
else
|
else
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(X86::MOV32rr), t2);
|
MIB = BuildMI(newMBB, dl, TII->get(X86::MOV32rr), t2);
|
||||||
(*MIB).addOperand(*argOpers[valArgIndx]);
|
(*MIB).addOperand(*argOpers[valArgIndx]);
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(X86::MOV32rr), X86::EAX);
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), X86::EAX);
|
||||||
MIB.addReg(t1);
|
MIB.addReg(t1);
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(X86::CMP32rr));
|
MIB = BuildMI(newMBB, dl, TII->get(X86::CMP32rr));
|
||||||
@ -8359,7 +8357,7 @@ X86TargetLowering::EmitAtomicMinMaxWithCustomInserter(MachineInstr *mInstr,
|
|||||||
(*MIB).setMemRefs(mInstr->memoperands_begin(),
|
(*MIB).setMemRefs(mInstr->memoperands_begin(),
|
||||||
mInstr->memoperands_end());
|
mInstr->memoperands_end());
|
||||||
|
|
||||||
MIB = BuildMI(newMBB, dl, TII->get(X86::MOV32rr), destOper.getReg());
|
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), destOper.getReg());
|
||||||
MIB.addReg(X86::EAX);
|
MIB.addReg(X86::EAX);
|
||||||
|
|
||||||
// insert branch
|
// insert branch
|
||||||
@ -8741,25 +8739,25 @@ X86TargetLowering::EmitInstrWithCustomInserter(MachineInstr *MI,
|
|||||||
case X86::ATOMAND32:
|
case X86::ATOMAND32:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND32rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND32rr,
|
||||||
X86::AND32ri, X86::MOV32rm,
|
X86::AND32ri, X86::MOV32rm,
|
||||||
X86::LCMPXCHG32, X86::MOV32rr,
|
X86::LCMPXCHG32,
|
||||||
X86::NOT32r, X86::EAX,
|
X86::NOT32r, X86::EAX,
|
||||||
X86::GR32RegisterClass);
|
X86::GR32RegisterClass);
|
||||||
case X86::ATOMOR32:
|
case X86::ATOMOR32:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR32rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR32rr,
|
||||||
X86::OR32ri, X86::MOV32rm,
|
X86::OR32ri, X86::MOV32rm,
|
||||||
X86::LCMPXCHG32, X86::MOV32rr,
|
X86::LCMPXCHG32,
|
||||||
X86::NOT32r, X86::EAX,
|
X86::NOT32r, X86::EAX,
|
||||||
X86::GR32RegisterClass);
|
X86::GR32RegisterClass);
|
||||||
case X86::ATOMXOR32:
|
case X86::ATOMXOR32:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR32rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR32rr,
|
||||||
X86::XOR32ri, X86::MOV32rm,
|
X86::XOR32ri, X86::MOV32rm,
|
||||||
X86::LCMPXCHG32, X86::MOV32rr,
|
X86::LCMPXCHG32,
|
||||||
X86::NOT32r, X86::EAX,
|
X86::NOT32r, X86::EAX,
|
||||||
X86::GR32RegisterClass);
|
X86::GR32RegisterClass);
|
||||||
case X86::ATOMNAND32:
|
case X86::ATOMNAND32:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND32rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND32rr,
|
||||||
X86::AND32ri, X86::MOV32rm,
|
X86::AND32ri, X86::MOV32rm,
|
||||||
X86::LCMPXCHG32, X86::MOV32rr,
|
X86::LCMPXCHG32,
|
||||||
X86::NOT32r, X86::EAX,
|
X86::NOT32r, X86::EAX,
|
||||||
X86::GR32RegisterClass, true);
|
X86::GR32RegisterClass, true);
|
||||||
case X86::ATOMMIN32:
|
case X86::ATOMMIN32:
|
||||||
@ -8774,25 +8772,25 @@ X86TargetLowering::EmitInstrWithCustomInserter(MachineInstr *MI,
|
|||||||
case X86::ATOMAND16:
|
case X86::ATOMAND16:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND16rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND16rr,
|
||||||
X86::AND16ri, X86::MOV16rm,
|
X86::AND16ri, X86::MOV16rm,
|
||||||
X86::LCMPXCHG16, X86::MOV16rr,
|
X86::LCMPXCHG16,
|
||||||
X86::NOT16r, X86::AX,
|
X86::NOT16r, X86::AX,
|
||||||
X86::GR16RegisterClass);
|
X86::GR16RegisterClass);
|
||||||
case X86::ATOMOR16:
|
case X86::ATOMOR16:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR16rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR16rr,
|
||||||
X86::OR16ri, X86::MOV16rm,
|
X86::OR16ri, X86::MOV16rm,
|
||||||
X86::LCMPXCHG16, X86::MOV16rr,
|
X86::LCMPXCHG16,
|
||||||
X86::NOT16r, X86::AX,
|
X86::NOT16r, X86::AX,
|
||||||
X86::GR16RegisterClass);
|
X86::GR16RegisterClass);
|
||||||
case X86::ATOMXOR16:
|
case X86::ATOMXOR16:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR16rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR16rr,
|
||||||
X86::XOR16ri, X86::MOV16rm,
|
X86::XOR16ri, X86::MOV16rm,
|
||||||
X86::LCMPXCHG16, X86::MOV16rr,
|
X86::LCMPXCHG16,
|
||||||
X86::NOT16r, X86::AX,
|
X86::NOT16r, X86::AX,
|
||||||
X86::GR16RegisterClass);
|
X86::GR16RegisterClass);
|
||||||
case X86::ATOMNAND16:
|
case X86::ATOMNAND16:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND16rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND16rr,
|
||||||
X86::AND16ri, X86::MOV16rm,
|
X86::AND16ri, X86::MOV16rm,
|
||||||
X86::LCMPXCHG16, X86::MOV16rr,
|
X86::LCMPXCHG16,
|
||||||
X86::NOT16r, X86::AX,
|
X86::NOT16r, X86::AX,
|
||||||
X86::GR16RegisterClass, true);
|
X86::GR16RegisterClass, true);
|
||||||
case X86::ATOMMIN16:
|
case X86::ATOMMIN16:
|
||||||
@ -8807,25 +8805,25 @@ X86TargetLowering::EmitInstrWithCustomInserter(MachineInstr *MI,
|
|||||||
case X86::ATOMAND8:
|
case X86::ATOMAND8:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND8rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND8rr,
|
||||||
X86::AND8ri, X86::MOV8rm,
|
X86::AND8ri, X86::MOV8rm,
|
||||||
X86::LCMPXCHG8, X86::MOV8rr,
|
X86::LCMPXCHG8,
|
||||||
X86::NOT8r, X86::AL,
|
X86::NOT8r, X86::AL,
|
||||||
X86::GR8RegisterClass);
|
X86::GR8RegisterClass);
|
||||||
case X86::ATOMOR8:
|
case X86::ATOMOR8:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR8rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR8rr,
|
||||||
X86::OR8ri, X86::MOV8rm,
|
X86::OR8ri, X86::MOV8rm,
|
||||||
X86::LCMPXCHG8, X86::MOV8rr,
|
X86::LCMPXCHG8,
|
||||||
X86::NOT8r, X86::AL,
|
X86::NOT8r, X86::AL,
|
||||||
X86::GR8RegisterClass);
|
X86::GR8RegisterClass);
|
||||||
case X86::ATOMXOR8:
|
case X86::ATOMXOR8:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR8rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR8rr,
|
||||||
X86::XOR8ri, X86::MOV8rm,
|
X86::XOR8ri, X86::MOV8rm,
|
||||||
X86::LCMPXCHG8, X86::MOV8rr,
|
X86::LCMPXCHG8,
|
||||||
X86::NOT8r, X86::AL,
|
X86::NOT8r, X86::AL,
|
||||||
X86::GR8RegisterClass);
|
X86::GR8RegisterClass);
|
||||||
case X86::ATOMNAND8:
|
case X86::ATOMNAND8:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND8rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND8rr,
|
||||||
X86::AND8ri, X86::MOV8rm,
|
X86::AND8ri, X86::MOV8rm,
|
||||||
X86::LCMPXCHG8, X86::MOV8rr,
|
X86::LCMPXCHG8,
|
||||||
X86::NOT8r, X86::AL,
|
X86::NOT8r, X86::AL,
|
||||||
X86::GR8RegisterClass, true);
|
X86::GR8RegisterClass, true);
|
||||||
// FIXME: There are no CMOV8 instructions; MIN/MAX need some other way.
|
// FIXME: There are no CMOV8 instructions; MIN/MAX need some other way.
|
||||||
@ -8833,25 +8831,25 @@ X86TargetLowering::EmitInstrWithCustomInserter(MachineInstr *MI,
|
|||||||
case X86::ATOMAND64:
|
case X86::ATOMAND64:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND64rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND64rr,
|
||||||
X86::AND64ri32, X86::MOV64rm,
|
X86::AND64ri32, X86::MOV64rm,
|
||||||
X86::LCMPXCHG64, X86::MOV64rr,
|
X86::LCMPXCHG64,
|
||||||
X86::NOT64r, X86::RAX,
|
X86::NOT64r, X86::RAX,
|
||||||
X86::GR64RegisterClass);
|
X86::GR64RegisterClass);
|
||||||
case X86::ATOMOR64:
|
case X86::ATOMOR64:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR64rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::OR64rr,
|
||||||
X86::OR64ri32, X86::MOV64rm,
|
X86::OR64ri32, X86::MOV64rm,
|
||||||
X86::LCMPXCHG64, X86::MOV64rr,
|
X86::LCMPXCHG64,
|
||||||
X86::NOT64r, X86::RAX,
|
X86::NOT64r, X86::RAX,
|
||||||
X86::GR64RegisterClass);
|
X86::GR64RegisterClass);
|
||||||
case X86::ATOMXOR64:
|
case X86::ATOMXOR64:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR64rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::XOR64rr,
|
||||||
X86::XOR64ri32, X86::MOV64rm,
|
X86::XOR64ri32, X86::MOV64rm,
|
||||||
X86::LCMPXCHG64, X86::MOV64rr,
|
X86::LCMPXCHG64,
|
||||||
X86::NOT64r, X86::RAX,
|
X86::NOT64r, X86::RAX,
|
||||||
X86::GR64RegisterClass);
|
X86::GR64RegisterClass);
|
||||||
case X86::ATOMNAND64:
|
case X86::ATOMNAND64:
|
||||||
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND64rr,
|
return EmitAtomicBitwiseWithCustomInserter(MI, BB, X86::AND64rr,
|
||||||
X86::AND64ri32, X86::MOV64rm,
|
X86::AND64ri32, X86::MOV64rm,
|
||||||
X86::LCMPXCHG64, X86::MOV64rr,
|
X86::LCMPXCHG64,
|
||||||
X86::NOT64r, X86::RAX,
|
X86::NOT64r, X86::RAX,
|
||||||
X86::GR64RegisterClass, true);
|
X86::GR64RegisterClass, true);
|
||||||
case X86::ATOMMIN64:
|
case X86::ATOMMIN64:
|
||||||
|
@ -764,7 +764,6 @@ namespace llvm {
|
|||||||
unsigned immOpc,
|
unsigned immOpc,
|
||||||
unsigned loadOpc,
|
unsigned loadOpc,
|
||||||
unsigned cxchgOpc,
|
unsigned cxchgOpc,
|
||||||
unsigned copyOpc,
|
|
||||||
unsigned notOpc,
|
unsigned notOpc,
|
||||||
unsigned EAXreg,
|
unsigned EAXreg,
|
||||||
TargetRegisterClass *RC,
|
TargetRegisterClass *RC,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user