From 8198fcfc5dfcf4df50d30f9ceafcaf7c93a7c827 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 11 Aug 2004 06:55:12 +0000 Subject: [PATCH] This file is long dead git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@15656 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/X86/X86InstrSelInfo.td | 241 ------------------------------ 1 file changed, 241 deletions(-) delete mode 100644 lib/Target/X86/X86InstrSelInfo.td diff --git a/lib/Target/X86/X86InstrSelInfo.td b/lib/Target/X86/X86InstrSelInfo.td deleted file mode 100644 index f4935fcb8c9..00000000000 --- a/lib/Target/X86/X86InstrSelInfo.td +++ /dev/null @@ -1,241 +0,0 @@ - -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 -- 2.34.1