llvm/lib/Target/X86/X86InstrSelInfo.td
2004-04-06 19:34:00 +00:00

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