mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
Merge getStoreRegOpcode and getLoadRegOpcode.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105900 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9c57c29921
commit
21d238fdba
@ -2057,71 +2057,87 @@ bool X86InstrInfo::copyRegToReg(MachineBasicBlock &MBB,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static unsigned getLoadStoreRegOpcode(unsigned Reg,
|
||||||
|
const TargetRegisterClass *RC,
|
||||||
|
bool isStackAligned,
|
||||||
|
const TargetMachine &TM,
|
||||||
|
bool load) {
|
||||||
|
if (RC == &X86::GR64RegClass || RC == &X86::GR64_NOSPRegClass) {
|
||||||
|
return load ? X86::MOV64rm : X86::MOV64mr;
|
||||||
|
} else if (RC == &X86::GR32RegClass || RC == &X86::GR32_NOSPRegClass) {
|
||||||
|
return load ? X86::MOV32rm : X86::MOV32mr;
|
||||||
|
} else if (RC == &X86::GR16RegClass) {
|
||||||
|
return load ? X86::MOV16rm : X86::MOV16mr;
|
||||||
|
} else if (RC == &X86::GR8RegClass) {
|
||||||
|
// Copying to or from a physical H register on x86-64 requires a NOREX
|
||||||
|
// move. Otherwise use a normal move.
|
||||||
|
if (isHReg(Reg) &&
|
||||||
|
TM.getSubtarget<X86Subtarget>().is64Bit())
|
||||||
|
return load ? X86::MOV8rm_NOREX : X86::MOV8mr_NOREX;
|
||||||
|
else
|
||||||
|
return load ? X86::MOV8rm : X86::MOV8mr;
|
||||||
|
} else if (RC == &X86::GR64_ABCDRegClass) {
|
||||||
|
return load ? X86::MOV64rm : X86::MOV64mr;
|
||||||
|
} else if (RC == &X86::GR32_ABCDRegClass) {
|
||||||
|
return load ? X86::MOV32rm : X86::MOV32mr;
|
||||||
|
} else if (RC == &X86::GR16_ABCDRegClass) {
|
||||||
|
return load ? X86::MOV16rm : X86::MOV16mr;
|
||||||
|
} else if (RC == &X86::GR8_ABCD_LRegClass) {
|
||||||
|
return load ? X86::MOV8rm :X86::MOV8mr;
|
||||||
|
} else if (RC == &X86::GR8_ABCD_HRegClass) {
|
||||||
|
if (TM.getSubtarget<X86Subtarget>().is64Bit())
|
||||||
|
return load ? X86::MOV8rm_NOREX : X86::MOV8mr_NOREX;
|
||||||
|
else
|
||||||
|
return load ? X86::MOV8rm : X86::MOV8mr;
|
||||||
|
} else if (RC == &X86::GR64_NOREXRegClass ||
|
||||||
|
RC == &X86::GR64_NOREX_NOSPRegClass) {
|
||||||
|
return load ? X86::MOV64rm : X86::MOV64mr;
|
||||||
|
} else if (RC == &X86::GR32_NOREXRegClass) {
|
||||||
|
return load ? X86::MOV32rm : X86::MOV32mr;
|
||||||
|
} else if (RC == &X86::GR16_NOREXRegClass) {
|
||||||
|
return load ? X86::MOV16rm : X86::MOV16mr;
|
||||||
|
} else if (RC == &X86::GR8_NOREXRegClass) {
|
||||||
|
return load ? X86::MOV8rm : X86::MOV8mr;
|
||||||
|
} else if (RC == &X86::GR64_TCRegClass) {
|
||||||
|
return load ? X86::MOV64rm_TC : X86::MOV64mr_TC;
|
||||||
|
} else if (RC == &X86::GR32_TCRegClass) {
|
||||||
|
return load ? X86::MOV32rm_TC : X86::MOV32mr_TC;
|
||||||
|
} else if (RC == &X86::RFP80RegClass) {
|
||||||
|
return load ? X86::LD_Fp80m : X86::ST_FpP80m;
|
||||||
|
} else if (RC == &X86::RFP64RegClass) {
|
||||||
|
return load ? X86::LD_Fp64m : X86::ST_Fp64m;
|
||||||
|
} else if (RC == &X86::RFP32RegClass) {
|
||||||
|
return load ? X86::LD_Fp32m : X86::ST_Fp32m;
|
||||||
|
} else if (RC == &X86::FR32RegClass) {
|
||||||
|
return load ? X86::MOVSSrm : X86::MOVSSmr;
|
||||||
|
} else if (RC == &X86::FR64RegClass) {
|
||||||
|
return load ? X86::MOVSDrm : X86::MOVSDmr;
|
||||||
|
} else if (RC == &X86::VR128RegClass) {
|
||||||
|
// If stack is realigned we can use aligned stores.
|
||||||
|
if (isStackAligned)
|
||||||
|
return load ? X86::MOVAPSrm : X86::MOVAPSmr;
|
||||||
|
else
|
||||||
|
return load ? X86::MOVUPSrm : X86::MOVUPSmr;
|
||||||
|
} else if (RC == &X86::VR64RegClass) {
|
||||||
|
return load ? X86::MMX_MOVQ64rm : X86::MMX_MOVQ64mr;
|
||||||
|
} else {
|
||||||
|
llvm_unreachable("Unknown regclass");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static unsigned getStoreRegOpcode(unsigned SrcReg,
|
static unsigned getStoreRegOpcode(unsigned SrcReg,
|
||||||
const TargetRegisterClass *RC,
|
const TargetRegisterClass *RC,
|
||||||
bool isStackAligned,
|
bool isStackAligned,
|
||||||
TargetMachine &TM) {
|
TargetMachine &TM) {
|
||||||
unsigned Opc = 0;
|
return getLoadStoreRegOpcode(SrcReg, RC, isStackAligned, TM, false);
|
||||||
if (RC == &X86::GR64RegClass || RC == &X86::GR64_NOSPRegClass) {
|
|
||||||
Opc = X86::MOV64mr;
|
|
||||||
} else if (RC == &X86::GR32RegClass || RC == &X86::GR32_NOSPRegClass) {
|
|
||||||
Opc = X86::MOV32mr;
|
|
||||||
} else if (RC == &X86::GR16RegClass) {
|
|
||||||
Opc = X86::MOV16mr;
|
|
||||||
} else if (RC == &X86::GR8RegClass) {
|
|
||||||
// Copying to or from a physical H register on x86-64 requires a NOREX
|
|
||||||
// move. Otherwise use a normal move.
|
|
||||||
if (isHReg(SrcReg) &&
|
|
||||||
TM.getSubtarget<X86Subtarget>().is64Bit())
|
|
||||||
Opc = X86::MOV8mr_NOREX;
|
|
||||||
else
|
|
||||||
Opc = X86::MOV8mr;
|
|
||||||
} else if (RC == &X86::GR64_ABCDRegClass) {
|
|
||||||
Opc = X86::MOV64mr;
|
|
||||||
} else if (RC == &X86::GR32_ABCDRegClass) {
|
|
||||||
Opc = X86::MOV32mr;
|
|
||||||
} else if (RC == &X86::GR16_ABCDRegClass) {
|
|
||||||
Opc = X86::MOV16mr;
|
|
||||||
} else if (RC == &X86::GR8_ABCD_LRegClass) {
|
|
||||||
Opc = X86::MOV8mr;
|
|
||||||
} else if (RC == &X86::GR8_ABCD_HRegClass) {
|
|
||||||
if (TM.getSubtarget<X86Subtarget>().is64Bit())
|
|
||||||
Opc = X86::MOV8mr_NOREX;
|
|
||||||
else
|
|
||||||
Opc = X86::MOV8mr;
|
|
||||||
} else if (RC == &X86::GR64_NOREXRegClass ||
|
|
||||||
RC == &X86::GR64_NOREX_NOSPRegClass) {
|
|
||||||
Opc = X86::MOV64mr;
|
|
||||||
} else if (RC == &X86::GR32_NOREXRegClass) {
|
|
||||||
Opc = X86::MOV32mr;
|
|
||||||
} else if (RC == &X86::GR16_NOREXRegClass) {
|
|
||||||
Opc = X86::MOV16mr;
|
|
||||||
} else if (RC == &X86::GR8_NOREXRegClass) {
|
|
||||||
Opc = X86::MOV8mr;
|
|
||||||
} else if (RC == &X86::GR64_TCRegClass) {
|
|
||||||
Opc = X86::MOV64mr_TC;
|
|
||||||
} else if (RC == &X86::GR32_TCRegClass) {
|
|
||||||
Opc = X86::MOV32mr_TC;
|
|
||||||
} else if (RC == &X86::RFP80RegClass) {
|
|
||||||
Opc = X86::ST_FpP80m; // pops
|
|
||||||
} else if (RC == &X86::RFP64RegClass) {
|
|
||||||
Opc = X86::ST_Fp64m;
|
|
||||||
} else if (RC == &X86::RFP32RegClass) {
|
|
||||||
Opc = X86::ST_Fp32m;
|
|
||||||
} else if (RC == &X86::FR32RegClass) {
|
|
||||||
Opc = X86::MOVSSmr;
|
|
||||||
} else if (RC == &X86::FR64RegClass) {
|
|
||||||
Opc = X86::MOVSDmr;
|
|
||||||
} else if (RC == &X86::VR128RegClass) {
|
|
||||||
// If stack is realigned we can use aligned stores.
|
|
||||||
Opc = isStackAligned ? X86::MOVAPSmr : X86::MOVUPSmr;
|
|
||||||
} else if (RC == &X86::VR64RegClass) {
|
|
||||||
Opc = X86::MMX_MOVQ64mr;
|
|
||||||
} else {
|
|
||||||
llvm_unreachable("Unknown regclass");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return Opc;
|
|
||||||
|
static unsigned getLoadRegOpcode(unsigned DestReg,
|
||||||
|
const TargetRegisterClass *RC,
|
||||||
|
bool isStackAligned,
|
||||||
|
const TargetMachine &TM) {
|
||||||
|
return getLoadStoreRegOpcode(DestReg, RC, isStackAligned, TM, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void X86InstrInfo::storeRegToStackSlot(MachineBasicBlock &MBB,
|
void X86InstrInfo::storeRegToStackSlot(MachineBasicBlock &MBB,
|
||||||
@ -2155,72 +2171,6 @@ void X86InstrInfo::storeRegToAddr(MachineFunction &MF, unsigned SrcReg,
|
|||||||
NewMIs.push_back(MIB);
|
NewMIs.push_back(MIB);
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned getLoadRegOpcode(unsigned DestReg,
|
|
||||||
const TargetRegisterClass *RC,
|
|
||||||
bool isStackAligned,
|
|
||||||
const TargetMachine &TM) {
|
|
||||||
unsigned Opc = 0;
|
|
||||||
if (RC == &X86::GR64RegClass || RC == &X86::GR64_NOSPRegClass) {
|
|
||||||
Opc = X86::MOV64rm;
|
|
||||||
} else if (RC == &X86::GR32RegClass || RC == &X86::GR32_NOSPRegClass) {
|
|
||||||
Opc = X86::MOV32rm;
|
|
||||||
} else if (RC == &X86::GR16RegClass) {
|
|
||||||
Opc = X86::MOV16rm;
|
|
||||||
} else if (RC == &X86::GR8RegClass) {
|
|
||||||
// Copying to or from a physical H register on x86-64 requires a NOREX
|
|
||||||
// move. Otherwise use a normal move.
|
|
||||||
if (isHReg(DestReg) &&
|
|
||||||
TM.getSubtarget<X86Subtarget>().is64Bit())
|
|
||||||
Opc = X86::MOV8rm_NOREX;
|
|
||||||
else
|
|
||||||
Opc = X86::MOV8rm;
|
|
||||||
} else if (RC == &X86::GR64_ABCDRegClass) {
|
|
||||||
Opc = X86::MOV64rm;
|
|
||||||
} else if (RC == &X86::GR32_ABCDRegClass) {
|
|
||||||
Opc = X86::MOV32rm;
|
|
||||||
} else if (RC == &X86::GR16_ABCDRegClass) {
|
|
||||||
Opc = X86::MOV16rm;
|
|
||||||
} else if (RC == &X86::GR8_ABCD_LRegClass) {
|
|
||||||
Opc = X86::MOV8rm;
|
|
||||||
} else if (RC == &X86::GR8_ABCD_HRegClass) {
|
|
||||||
if (TM.getSubtarget<X86Subtarget>().is64Bit())
|
|
||||||
Opc = X86::MOV8rm_NOREX;
|
|
||||||
else
|
|
||||||
Opc = X86::MOV8rm;
|
|
||||||
} else if (RC == &X86::GR64_NOREXRegClass ||
|
|
||||||
RC == &X86::GR64_NOREX_NOSPRegClass) {
|
|
||||||
Opc = X86::MOV64rm;
|
|
||||||
} else if (RC == &X86::GR32_NOREXRegClass) {
|
|
||||||
Opc = X86::MOV32rm;
|
|
||||||
} else if (RC == &X86::GR16_NOREXRegClass) {
|
|
||||||
Opc = X86::MOV16rm;
|
|
||||||
} else if (RC == &X86::GR8_NOREXRegClass) {
|
|
||||||
Opc = X86::MOV8rm;
|
|
||||||
} else if (RC == &X86::GR64_TCRegClass) {
|
|
||||||
Opc = X86::MOV64rm_TC;
|
|
||||||
} else if (RC == &X86::GR32_TCRegClass) {
|
|
||||||
Opc = X86::MOV32rm_TC;
|
|
||||||
} else if (RC == &X86::RFP80RegClass) {
|
|
||||||
Opc = X86::LD_Fp80m;
|
|
||||||
} else if (RC == &X86::RFP64RegClass) {
|
|
||||||
Opc = X86::LD_Fp64m;
|
|
||||||
} else if (RC == &X86::RFP32RegClass) {
|
|
||||||
Opc = X86::LD_Fp32m;
|
|
||||||
} else if (RC == &X86::FR32RegClass) {
|
|
||||||
Opc = X86::MOVSSrm;
|
|
||||||
} else if (RC == &X86::FR64RegClass) {
|
|
||||||
Opc = X86::MOVSDrm;
|
|
||||||
} else if (RC == &X86::VR128RegClass) {
|
|
||||||
// If stack is realigned we can use aligned loads.
|
|
||||||
Opc = isStackAligned ? X86::MOVAPSrm : X86::MOVUPSrm;
|
|
||||||
} else if (RC == &X86::VR64RegClass) {
|
|
||||||
Opc = X86::MMX_MOVQ64rm;
|
|
||||||
} else {
|
|
||||||
llvm_unreachable("Unknown regclass");
|
|
||||||
}
|
|
||||||
|
|
||||||
return Opc;
|
|
||||||
}
|
|
||||||
|
|
||||||
void X86InstrInfo::loadRegFromStackSlot(MachineBasicBlock &MBB,
|
void X86InstrInfo::loadRegFromStackSlot(MachineBasicBlock &MBB,
|
||||||
MachineBasicBlock::iterator MI,
|
MachineBasicBlock::iterator MI,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user