mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-16 11:30:51 +00:00
242 lines
13 KiB
TableGen
242 lines
13 KiB
TableGen
|
|
||
|
let Namespace = "X86" in {
|
||
|
|
||
|
// def PHI : TargInstr<"PHI", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def NOOP : TargInstr<"NOOP", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def ADJCALLSTACKDOWN : TargInstr<"ADJCALLSTACKDOWN", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def ADJCALLSTACKUP : TargInstr<"ADJCALLSTACKUP", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def IMPLICIT_USE : TargInstr<"IMPLICIT_USE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def IMPLICIT_DEF : TargInstr<"IMPLICIT_DEF", 0, []>;
|
||
|
|
||
|
def RET : TargInstr<"RET", 0, []>;
|
||
|
def JMP : TargInstr<"JMP", 1, [MBI_PCDisp]>;
|
||
|
// def JB : TargInstr<"JB", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JAE : TargInstr<"JAE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JE : TargInstr<"JE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JNE : TargInstr<"JNE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JBE : TargInstr<"JBE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JA : TargInstr<"JA", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JS : TargInstr<"JS", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JNS : TargInstr<"JNS", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JL : TargInstr<"JL", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JGE : TargInstr<"JGE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JLE : TargInstr<"JLE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def JG : TargInstr<"JG", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def LEAVE : TargInstr<"LEAVE", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def BSWAPr32 : TargInstr<"BSWAPr32", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def XCHGrr8 : TargInstr<"XCHGrr8", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def XCHGrr16 : TargInstr<"XCHGrr16", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def XCHGrr32 : TargInstr<"XCHGrr32", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def LEAr16 : TargInstr<"LEAr16", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def LEAr32 : TargInstr<"LEAr32", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def MOVrr8 : TargInstr<"MOV8rr", 1, [MBI_Reg]>;
|
||
|
def MOVrr16 : TargInstr<"MOV16rr", 1, [MBI_Reg]>;
|
||
|
def MOVrr32 : TargInstr<"MOV32rr", 1, [MBI_Reg]>;
|
||
|
def MOVir8 : TargInstr<"MOV8ir", 1, [MBI_ZImm]>;
|
||
|
def MOVir16 : TargInstr<"MOV16ir", 1, [MBI_ZImm]>;
|
||
|
def MOVir32 : TargInstr<"MOV32ir", 1, [MBI_ZImm]>;
|
||
|
// def MOVim8 : TargInstr<"MOVim8", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
// def MOVim16 : TargInstr<"MOVim16", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
// def MOVim32 : TargInstr<"MOVim32", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def MOVmr8 : TargInstr<"MOV8mr", 4, [MBI_FrameRef]>;
|
||
|
def MOVmr16 : TargInstr<"MOV16mr", 4, [MBI_FrameRef]>;
|
||
|
def MOVmr32 : TargInstr<"MOV32mr", 4, [MBI_FrameRef]>;
|
||
|
def MOVrm8 : TargInstr<"MOV8rm", 5, [MBI_FrameRef, MBI_Reg]>; // 5 Operands?, stores to NULL
|
||
|
def MOVrm16 : TargInstr<"MOV16rm", 5, [MBI_FrameRef, MBI_Reg]>; // 5 Operands?, stores to NULL
|
||
|
def MOVrm32 : TargInstr<"MOV32rm", 5, [MBI_FrameRef, MBI_Reg]>; // 5 Operands?, stores to NULL
|
||
|
def MULr8 : TargInstr<"MUL8r", 1, [MBI_Reg]>;
|
||
|
// def MULr16 : TargInstr<"MULr16", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def MULr32 : TargInstr<"MULr32", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def DIVr8 : TargInstr<"DIV8r", 1, [MBI_Reg]>; // "DestReg" as arg, "1" as the dest
|
||
|
def DIVr16 : TargInstr<"DIV16r", 1, [MBI_Reg]>;
|
||
|
def DIVr32 : TargInstr<"DIV32r", 1, [MBI_Reg]>;
|
||
|
def IDIVr8 : TargInstr<"IDIV8r", 1, [MBI_Reg]>;
|
||
|
def IDIVr16 : TargInstr<"IDIV16r", 1, [MBI_Reg]>;
|
||
|
def IDIVr32 : TargInstr<"IDIV32r", 1, [MBI_Reg]>;
|
||
|
// def CBW : TargInstr<"CBW", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def CWD : TargInstr<"CWD", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def CDQ : TargInstr<"CDQ", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
|
||
|
def NEGr8 : TargInstr<"NEG8r", 1, [MBI_Reg]>;
|
||
|
def NEGr16 : TargInstr<"NEG16r", 1, [MBI_Reg]>;
|
||
|
def NEGr32 : TargInstr<"NEG32r", 1, [MBI_Reg]>;
|
||
|
def NOTr8 : TargInstr<"NOT8r", 1, [MBI_Reg]>;
|
||
|
def NOTr16 : TargInstr<"NOT16r", 1, [MBI_Reg]>;
|
||
|
def NOTr32 : TargInstr<"NOT32r", 1, [MBI_Reg]>;
|
||
|
def INCr8 : TargInstr<"INC8r", 1, [MBI_Reg]>;
|
||
|
def INCr16 : TargInstr<"INC16r", 1, [MBI_Reg]>;
|
||
|
def INCr32 : TargInstr<"INC32r", 1, [MBI_Reg]>;
|
||
|
def DECr8 : TargInstr<"DEC8r", 1, [MBI_Reg]>;
|
||
|
def DECr16 : TargInstr<"DEC16r", 1, [MBI_Reg]>;
|
||
|
def DECr32 : TargInstr<"DEC32r", 1, [MBI_Reg]>;
|
||
|
|
||
|
def ADDrr8 : TargInstr<"ADD8rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ADDrr16 : TargInstr<"ADD16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ADDrr32 : TargInstr<"ADD32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ADDri8 : TargInstr<"ADD8ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ADDri16 : TargInstr<"ADD16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ADDri32 : TargInstr<"ADD32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ADDri16b : TargInstr<"ADD16bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ADDri32b : TargInstr<"ADD32bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ADCrr32 : TargInstr<"ADC32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def SUBrr8 : TargInstr<"SUB8rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def SUBrr16 : TargInstr<"SUB16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def SUBrr32 : TargInstr<"SUB32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def SUBri8 : TargInstr<"SUB8ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SUBri16 : TargInstr<"SUB16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SUBri32 : TargInstr<"SUB32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SUBri16b : TargInstr<"SUB16bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SUBri32b : TargInstr<"SUB32bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SBBrr32 : TargInstr<"SBB32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def IMULrr16 : TargInstr<"IMUL16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def IMULrr32 : TargInstr<"IMUL32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def IMULri16 : TargInstr<"IMUL16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def IMULri32 : TargInstr<"IMUL32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def IMULri16b : TargInstr<"IMUL16bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def IMULri32b : TargInstr<"IMUL32bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
|
||
|
def ANDrr8 : TargInstr<"AND8rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ANDrr16 : TargInstr<"AND16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ANDrr32 : TargInstr<"AND32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ANDri8 : TargInstr<"AND8ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ANDri16 : TargInstr<"AND16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ANDri32 : TargInstr<"AND32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ANDri16b : TargInstr<"AND16bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ANDri32b : TargInstr<"AND32bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ORrr8 : TargInstr<"OR8rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ORrr16 : TargInstr<"OR16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ORrr32 : TargInstr<"OR32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def ORri8 : TargInstr<"OR8ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ORri16 : TargInstr<"OR16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ORri32 : TargInstr<"OR32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ORri16b : TargInstr<"OR16bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def ORri32b : TargInstr<"OR32bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def XORrr8 : TargInstr<"XOR8rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def XORrr16 : TargInstr<"XOR16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def XORrr32 : TargInstr<"XOR32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def XORri8 : TargInstr<"XOR8ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def XORri16 : TargInstr<"XOR16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def XORri32 : TargInstr<"XOR32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def XORri16b : TargInstr<"XOR16bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def XORri32b : TargInstr<"XOR32bri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
|
||
|
def TESTrr8 : TargInstr<"TEST8rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def TESTrr16 : TargInstr<"TEST16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def TESTrr32 : TargInstr<"TEST32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def TESTri8 : TargInstr<"TEST8ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def TESTri16 : TargInstr<"TEST16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def TESTri32 : TargInstr<"TEST32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
|
||
|
def SHLrr8 : TargInstr<"SHL8rr", 1, [MBI_Reg]>;
|
||
|
def SHLrr16 : TargInstr<"SHL16rr", 1, [MBI_Reg]>;
|
||
|
def SHLrr32 : TargInstr<"SHL32rr", 1, [MBI_Reg]>;
|
||
|
def SHLir8 : TargInstr<"SHL8ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SHLir16 : TargInstr<"SHL16ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SHLir32 : TargInstr<"SHL32ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SHRrr8 : TargInstr<"SHR8rr", 1, [MBI_Reg]>;
|
||
|
def SHRrr16 : TargInstr<"SHR16rr", 1, [MBI_Reg]>;
|
||
|
def SHRrr32 : TargInstr<"SHR32rr", 1, [MBI_Reg]>;
|
||
|
def SHRir8 : TargInstr<"SHR8ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SHRir16 : TargInstr<"SHR16ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SHRir32 : TargInstr<"SHR32ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SARrr8 : TargInstr<"SAR8rr", 1, [MBI_Reg]>;
|
||
|
def SARrr16 : TargInstr<"SAR16rr", 1, [MBI_Reg]>;
|
||
|
def SARrr32 : TargInstr<"SAR32rr", 1, [MBI_Reg]>;
|
||
|
def SARir8 : TargInstr<"SAR8ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SARir16 : TargInstr<"SAR16ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def SARir32 : TargInstr<"SAR32ir", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
|
||
|
def SHLDrr32 : TargInstr<"SHLD32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def SHLDir32 : TargInstr<"SHLD32ir", 3, [MBI_Reg, MBI_Reg, MBI_ZImm]>;
|
||
|
def SHRDrr32 : TargInstr<"SHRD32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def SHRDir32 : TargInstr<"SHRD32ir", 3, [MBI_Reg, MBI_Reg, MBI_ZImm]>;
|
||
|
|
||
|
def SAHF : TargInstr<"SAHF", 0, []>; // store in "1" ?
|
||
|
// def SETBr : TargInstr<"SETBr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETAEr : TargInstr<"SETAEr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETEr : TargInstr<"SETEr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def SETNEr : TargInstr<"SETNEr", 0, []>;
|
||
|
// def SETBEr : TargInstr<"SETBEr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETAr : TargInstr<"SETAr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETSr : TargInstr<"SETSr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETNSr : TargInstr<"SETNSr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETLr : TargInstr<"SETLr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETGEr : TargInstr<"SETGEr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETLEr : TargInstr<"SETLEr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def SETGr : TargInstr<"SETGr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def CMOVErr16 : TargInstr<"CMOVE16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def CMOVNErr32: TargInstr<"CMOVNE32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
|
||
|
def CMPrr8 : TargInstr<"CMP8rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def CMPrr16 : TargInstr<"CMP16rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def CMPrr32 : TargInstr<"CMP32rr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def CMPri8 : TargInstr<"CMP8ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def CMPri16 : TargInstr<"CMP16ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
def CMPri32 : TargInstr<"CMP32ri", 2, [MBI_Reg, MBI_ZImm]>;
|
||
|
|
||
|
def MOVSXr16r8 : TargInstr<"MOVSX16rr8", 1, [MBI_Reg]>;
|
||
|
def MOVSXr32r8 : TargInstr<"MOVSX32rr8", 1, [MBI_Reg]>;
|
||
|
def MOVSXr32r16: TargInstr<"MOVSX32rr16", 1, [MBI_Reg]>;
|
||
|
def MOVZXr16r8 : TargInstr<"MOVZX16rr8", 1, [MBI_Reg]>;
|
||
|
def MOVZXr32r8 : TargInstr<"MOVZX32rr8", 1, [MBI_Reg]>;
|
||
|
def MOVZXr32r16: TargInstr<"MOVZX32rr16", 1, [MBI_Reg]>;
|
||
|
|
||
|
def FP_REG_KILL : TargInstr<"FP_REG_KILL",0, []>;
|
||
|
|
||
|
def FpMOV : TargInstr<"FpMOV", 1, [MBI_Reg]>;
|
||
|
def FpADD : TargInstr<"FpADD", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FpSUB : TargInstr<"FpSUB", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FpMUL : TargInstr<"FpMUL", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FpDIV : TargInstr<"FpDIV", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FpUCOM : TargInstr<"FpUCOM", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FpGETRESULT : TargInstr<"FpGETRESULT", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FpSETRESULT : TargInstr<"FpSETRESULT", 1, [MBI_Reg]>;
|
||
|
// def FLDrr : TargInstr<"FLDrr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FLDr32 : TargInstr<"FLD32r", 1, [MBI_ConstPoolRef]>; // MBI_FrameRef also? instructions can be passed different operands
|
||
|
def FLDr64 : TargInstr<"FLD64r", 1, [MBI_ConstPoolRef]>;
|
||
|
// def FLDr80 : TargInstr<"FLDr80", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FILDr16 : TargInstr<"FILD16r", 5, [MBI_FrameRef]>;
|
||
|
def FILDr32 : TargInstr<"FILD32r", 5, [MBI_FrameRef]>;
|
||
|
def FILDr64 : TargInstr<"FILD64r", 5, [MBI_FrameRef]>;
|
||
|
def FSTr32 : TargInstr<"FST32r", 5, [MBI_FrameRef, MBI_Reg]>; // ?
|
||
|
// def FSTr64 : TargInstr<"FST64r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSTPr32 : TargInstr<"FSTP32r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSTPr64 : TargInstr<"FSTP64r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSTPr80 : TargInstr<"FSTP80r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSTrr : TargInstr<"FSTrr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSTPrr : TargInstr<"FSTPrr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FISTr16 : TargInstr<"FIST16r", 5, [MBI_FrameRef, MBI_Reg]>;
|
||
|
def FISTr32 : TargInstr<"FIST32r", 5, [MBI_FrameRef, MBI_Reg]>;
|
||
|
// def FISTPr16 : TargInstr<"FISTP16r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FISTPr32 : TargInstr<"FISTP32r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FISTPr64 : TargInstr<"FISTP64r", 5, [MBI_FrameRef, MBI_Reg]>;
|
||
|
// def FXCH : TargInstr<"FXCH", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FLD0 : TargInstr<"FLD0", 0, []>;
|
||
|
def FLD1 : TargInstr<"FLD1", 0, []>;
|
||
|
// def FADDST0r : TargInstr<"FADDST0r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FADDrST0 : TargInstr<"FADDrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FADDPrST0 : TargInstr<"FADDPrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSUBRST0r : TargInstr<"FSUBRST0r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSUBrST0 : TargInstr<"FSUBrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSUBPrST0 : TargInstr<"FSUBPrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSUBST0r : TargInstr<"FSUBST0r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSUBRrST0 : TargInstr<"FSUBRrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FSUBRPrST0 : TargInstr<"FSUBRPrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FMULST0r : TargInstr<"FMULST0r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FMULrST0 : TargInstr<"FMULrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FMULPrST0 : TargInstr<"FMULPrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FDIVRST0r : TargInstr<"FDIVRST0r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FDIVrST0 : TargInstr<"FDIVrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FDIVPrST0 : TargInstr<"FDIVPrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FDIVST0r : TargInstr<"FDIVST0r", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FDIVRrST0 : TargInstr<"FDIVRrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FDIVRPrST0 : TargInstr<"FDIVRPrST0", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FUCOMr : TargInstr<"FUCOMr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FUCOMPr : TargInstr<"FUCOMPr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
// def FUCOMPPr : TargInstr<"FUCOMPPr", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FNSTSWr8 : TargInstr<"FNSTSWr8", 0, []>; // store in "0" ?
|
||
|
// def FNSTCWm16 : TargInstr<"FNSTCWm16", 2, [MBI_Reg, MBI_Reg]>;
|
||
|
def FLDCWm16 : TargInstr<"FLDCWm16", 4, [MBI_FrameRef]>;
|
||
|
|
||
|
} //namespace
|