diff options
| author | Simon Pilgrim <llvm-dev@redking.me.uk> | 2018-04-12 10:27:37 +0000 |
|---|---|---|
| committer | Simon Pilgrim <llvm-dev@redking.me.uk> | 2018-04-12 10:27:37 +0000 |
| commit | 32d368147f2deb94ff4a3be9908225437adb2aa4 (patch) | |
| tree | a0643d2418b0a3d815f20be73cab67a53916d492 /llvm | |
| parent | 34812c0d0dd52b3d00919a3bd3303716b8d7034b (diff) | |
| download | bcm5719-llvm-32d368147f2deb94ff4a3be9908225437adb2aa4.tar.gz bcm5719-llvm-32d368147f2deb94ff4a3be9908225437adb2aa4.zip | |
[X86] Remove X87 schedule itineraries (PR37093)
First of a number of commits to remove x86 schedule itineraries entirely - approved off-line with @craig.topper
llvm-svn: 329893
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrFPStack.td | 222 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrFormats.td | 10 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86Schedule.td | 41 |
3 files changed, 101 insertions, 172 deletions
diff --git a/llvm/lib/Target/X86/X86InstrFPStack.td b/llvm/lib/Target/X86/X86InstrFPStack.td index 18071c6baa1..23f986d2dee 100644 --- a/llvm/lib/Target/X86/X86InstrFPStack.td +++ b/llvm/lib/Target/X86/X86InstrFPStack.td @@ -118,12 +118,10 @@ let usesCustomInserter = 1, hasNoSchedulingInfo = 1 in { // f32 instructions can use SSE1 and are predicated on FPStackf32 == !SSE1. // f64 instructions can use SSE2 and are predicated on FPStackf64 == !SSE2. // f80 instructions cannot use SSE and use neither of these. -class FpIf32<dag outs, dag ins, FPFormat fp, list<dag> pattern, - InstrItinClass itin = NoItinerary> : - FpI_<outs, ins, fp, pattern, itin>, Requires<[FPStackf32]>; -class FpIf64<dag outs, dag ins, FPFormat fp, list<dag> pattern, - InstrItinClass itin = NoItinerary> : - FpI_<outs, ins, fp, pattern, itin>, Requires<[FPStackf64]>; +class FpIf32<dag outs, dag ins, FPFormat fp, list<dag> pattern> : + FpI_<outs, ins, fp, pattern>, Requires<[FPStackf32]>; +class FpIf64<dag outs, dag ins, FPFormat fp, list<dag> pattern> : + FpI_<outs, ins, fp, pattern>, Requires<[FPStackf64]>; // Factoring for arithmetic. multiclass FPBinary_rr<SDNode OpNode> { @@ -297,30 +295,29 @@ def DIVR_FPrST0 : FPrST0PInst<MRM6r, "fdiv{|r}p\t$op">; } // SchedRW // Unary operations. -multiclass FPUnary<SDNode OpNode, Format fp, string asmstring, - InstrItinClass itin> { +multiclass FPUnary<SDNode OpNode, Format fp, string asmstring> { def _Fp32 : FpIf32<(outs RFP32:$dst), (ins RFP32:$src), OneArgFPRW, - [(set RFP32:$dst, (OpNode RFP32:$src))], itin>; + [(set RFP32:$dst, (OpNode RFP32:$src))]>; def _Fp64 : FpIf64<(outs RFP64:$dst), (ins RFP64:$src), OneArgFPRW, - [(set RFP64:$dst, (OpNode RFP64:$src))], itin>; + [(set RFP64:$dst, (OpNode RFP64:$src))]>; def _Fp80 : FpI_<(outs RFP80:$dst), (ins RFP80:$src), OneArgFPRW, - [(set RFP80:$dst, (OpNode RFP80:$src))], itin>; -def _F : FPI<0xD9, fp, (outs), (ins), asmstring, itin>; + [(set RFP80:$dst, (OpNode RFP80:$src))]>; +def _F : FPI<0xD9, fp, (outs), (ins), asmstring>; } let Defs = [FPSW] in { let SchedRW = [WriteVecLogic] in { -defm CHS : FPUnary<fneg, MRM_E0, "fchs", IIC_FSIGN>; -defm ABS : FPUnary<fabs, MRM_E1, "fabs", IIC_FSIGN>; +defm CHS : FPUnary<fneg, MRM_E0, "fchs">; +defm ABS : FPUnary<fabs, MRM_E1, "fabs">; } let SchedRW = [WriteFSqrt] in -defm SQRT: FPUnary<fsqrt,MRM_FA, "fsqrt", IIC_FSQRT>; +defm SQRT: FPUnary<fsqrt,MRM_FA, "fsqrt">; let SchedRW = [WriteMicrocoded] in { -defm SIN : FPUnary<fsin, MRM_FE, "fsin", IIC_FSINCOS>; -defm COS : FPUnary<fcos, MRM_FF, "fcos", IIC_FSINCOS>; +defm SIN : FPUnary<fsin, MRM_FE, "fsin">; +defm COS : FPUnary<fcos, MRM_FF, "fcos">; } let SchedRW = [WriteFAdd] in { @@ -330,7 +327,7 @@ def TST_Fp64 : FpIf64<(outs), (ins RFP64:$src), OneArgFP, []>; def TST_Fp80 : FpI_<(outs), (ins RFP80:$src), OneArgFP, []>; } // hasSideEffects -def TST_F : FPI<0xD9, MRM_E4, (outs), (ins), "ftst", IIC_FCOMI>; +def TST_F : FPI<0xD9, MRM_E4, (outs), (ins), "ftst">; } // SchedRW } // Defs = [FPSW] @@ -363,26 +360,24 @@ def FBSTPm : FPI<0xDF, MRM6m, (outs), (ins f80mem:$dst), "fbstp\t$dst">; } // SchedRW // Floating point cmovs. -class FpIf32CMov<dag outs, dag ins, FPFormat fp, list<dag> pattern, - InstrItinClass itin> : - FpI_<outs, ins, fp, pattern, itin>, Requires<[FPStackf32, HasCMov]>; -class FpIf64CMov<dag outs, dag ins, FPFormat fp, list<dag> pattern, - InstrItinClass itin> : - FpI_<outs, ins, fp, pattern, itin>, Requires<[FPStackf64, HasCMov]>; +class FpIf32CMov<dag outs, dag ins, FPFormat fp, list<dag> pattern> : + FpI_<outs, ins, fp, pattern>, Requires<[FPStackf32, HasCMov]>; +class FpIf64CMov<dag outs, dag ins, FPFormat fp, list<dag> pattern> : + FpI_<outs, ins, fp, pattern>, Requires<[FPStackf64, HasCMov]>; multiclass FPCMov<PatLeaf cc> { def _Fp32 : FpIf32CMov<(outs RFP32:$dst), (ins RFP32:$src1, RFP32:$src2), CondMovFP, [(set RFP32:$dst, (X86cmov RFP32:$src1, RFP32:$src2, - cc, EFLAGS))], IIC_FCMOV>; + cc, EFLAGS))]>; def _Fp64 : FpIf64CMov<(outs RFP64:$dst), (ins RFP64:$src1, RFP64:$src2), CondMovFP, [(set RFP64:$dst, (X86cmov RFP64:$src1, RFP64:$src2, - cc, EFLAGS))], IIC_FCMOV>; + cc, EFLAGS))]>; def _Fp80 : FpI_<(outs RFP80:$dst), (ins RFP80:$src1, RFP80:$src2), CondMovFP, [(set RFP80:$dst, (X86cmov RFP80:$src1, RFP80:$src2, - cc, EFLAGS))], IIC_FCMOV>, + cc, EFLAGS))]>, Requires<[HasCMov]>; } @@ -402,21 +397,21 @@ defm CMOVNP : FPCMov<X86_COND_NP>; let Predicates = [HasCMov] in { // These are not factored because there's no clean way to pass DA/DB. def CMOVB_F : FPI<0xDA, MRM0r, (outs), (ins RST:$op), - "fcmovb\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmovb\t{$op, %st(0)|st(0), $op}">; def CMOVBE_F : FPI<0xDA, MRM2r, (outs), (ins RST:$op), - "fcmovbe\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmovbe\t{$op, %st(0)|st(0), $op}">; def CMOVE_F : FPI<0xDA, MRM1r, (outs), (ins RST:$op), - "fcmove\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmove\t{$op, %st(0)|st(0), $op}">; def CMOVP_F : FPI<0xDA, MRM3r, (outs), (ins RST:$op), - "fcmovu\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmovu\t{$op, %st(0)|st(0), $op}">; def CMOVNB_F : FPI<0xDB, MRM0r, (outs), (ins RST:$op), - "fcmovnb\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmovnb\t{$op, %st(0)|st(0), $op}">; def CMOVNBE_F: FPI<0xDB, MRM2r, (outs), (ins RST:$op), - "fcmovnbe\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmovnbe\t{$op, %st(0)|st(0), $op}">; def CMOVNE_F : FPI<0xDB, MRM1r, (outs), (ins RST:$op), - "fcmovne\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmovne\t{$op, %st(0)|st(0), $op}">; def CMOVNP_F : FPI<0xDB, MRM3r, (outs), (ins RST:$op), - "fcmovnu\t{$op, %st(0)|st(0), $op}", IIC_FCMOV>; + "fcmovnu\t{$op, %st(0)|st(0), $op}">; } // Predicates = [HasCMov] } // SchedRW @@ -495,40 +490,24 @@ def IST_Fp64m80 : FpI_<(outs), (ins i64mem:$op, RFP80:$src), OneArgFP, []>; } // SchedRW let mayLoad = 1, SchedRW = [WriteLoad] in { -def LD_F32m : FPI<0xD9, MRM0m, (outs), (ins f32mem:$src), "fld{s}\t$src", - IIC_FLD>; -def LD_F64m : FPI<0xDD, MRM0m, (outs), (ins f64mem:$src), "fld{l}\t$src", - IIC_FLD>; -def LD_F80m : FPI<0xDB, MRM5m, (outs), (ins f80mem:$src), "fld{t}\t$src", - IIC_FLD80>; -def ILD_F16m : FPI<0xDF, MRM0m, (outs), (ins i16mem:$src), "fild{s}\t$src", - IIC_FILD>; -def ILD_F32m : FPI<0xDB, MRM0m, (outs), (ins i32mem:$src), "fild{l}\t$src", - IIC_FILD>; -def ILD_F64m : FPI<0xDF, MRM5m, (outs), (ins i64mem:$src), "fild{ll}\t$src", - IIC_FILD>; +def LD_F32m : FPI<0xD9, MRM0m, (outs), (ins f32mem:$src), "fld{s}\t$src">; +def LD_F64m : FPI<0xDD, MRM0m, (outs), (ins f64mem:$src), "fld{l}\t$src">; +def LD_F80m : FPI<0xDB, MRM5m, (outs), (ins f80mem:$src), "fld{t}\t$src">; +def ILD_F16m : FPI<0xDF, MRM0m, (outs), (ins i16mem:$src), "fild{s}\t$src">; +def ILD_F32m : FPI<0xDB, MRM0m, (outs), (ins i32mem:$src), "fild{l}\t$src">; +def ILD_F64m : FPI<0xDF, MRM5m, (outs), (ins i64mem:$src), "fild{ll}\t$src">; } let mayStore = 1, SchedRW = [WriteStore] in { -def ST_F32m : FPI<0xD9, MRM2m, (outs), (ins f32mem:$dst), "fst{s}\t$dst", - IIC_FST>; -def ST_F64m : FPI<0xDD, MRM2m, (outs), (ins f64mem:$dst), "fst{l}\t$dst", - IIC_FST>; -def ST_FP32m : FPI<0xD9, MRM3m, (outs), (ins f32mem:$dst), "fstp{s}\t$dst", - IIC_FST>; -def ST_FP64m : FPI<0xDD, MRM3m, (outs), (ins f64mem:$dst), "fstp{l}\t$dst", - IIC_FST>; -def ST_FP80m : FPI<0xDB, MRM7m, (outs), (ins f80mem:$dst), "fstp{t}\t$dst", - IIC_FST80>; -def IST_F16m : FPI<0xDF, MRM2m, (outs), (ins i16mem:$dst), "fist{s}\t$dst", - IIC_FIST>; -def IST_F32m : FPI<0xDB, MRM2m, (outs), (ins i32mem:$dst), "fist{l}\t$dst", - IIC_FIST>; -def IST_FP16m : FPI<0xDF, MRM3m, (outs), (ins i16mem:$dst), "fistp{s}\t$dst", - IIC_FIST>; -def IST_FP32m : FPI<0xDB, MRM3m, (outs), (ins i32mem:$dst), "fistp{l}\t$dst", - IIC_FIST>; -def IST_FP64m : FPI<0xDF, MRM7m, (outs), (ins i64mem:$dst), "fistp{ll}\t$dst", - IIC_FIST>; +def ST_F32m : FPI<0xD9, MRM2m, (outs), (ins f32mem:$dst), "fst{s}\t$dst">; +def ST_F64m : FPI<0xDD, MRM2m, (outs), (ins f64mem:$dst), "fst{l}\t$dst">; +def ST_FP32m : FPI<0xD9, MRM3m, (outs), (ins f32mem:$dst), "fstp{s}\t$dst">; +def ST_FP64m : FPI<0xDD, MRM3m, (outs), (ins f64mem:$dst), "fstp{l}\t$dst">; +def ST_FP80m : FPI<0xDB, MRM7m, (outs), (ins f80mem:$dst), "fstp{t}\t$dst">; +def IST_F16m : FPI<0xDF, MRM2m, (outs), (ins i16mem:$dst), "fist{s}\t$dst">; +def IST_F32m : FPI<0xDB, MRM2m, (outs), (ins i32mem:$dst), "fist{l}\t$dst">; +def IST_FP16m : FPI<0xDF, MRM3m, (outs), (ins i16mem:$dst), "fistp{s}\t$dst">; +def IST_FP32m : FPI<0xDB, MRM3m, (outs), (ins i32mem:$dst), "fistp{l}\t$dst">; +def IST_FP64m : FPI<0xDF, MRM7m, (outs), (ins i64mem:$dst), "fistp{ll}\t$dst">; } // FISTTP requires SSE3 even though it's a FPStack op. @@ -554,20 +533,17 @@ def ISTT_Fp64m80 : FpI_<(outs), (ins i64mem:$op, RFP80:$src), OneArgFP, } // Predicates = [HasSSE3] let mayStore = 1, SchedRW = [WriteStore] in { -def ISTT_FP16m : FPI<0xDF, MRM1m, (outs), (ins i16mem:$dst), "fisttp{s}\t$dst", - IIC_FST>; -def ISTT_FP32m : FPI<0xDB, MRM1m, (outs), (ins i32mem:$dst), "fisttp{l}\t$dst", - IIC_FST>; -def ISTT_FP64m : FPI<0xDD, MRM1m, (outs), (ins i64mem:$dst), - "fisttp{ll}\t$dst", IIC_FST>; +def ISTT_FP16m : FPI<0xDF, MRM1m, (outs), (ins i16mem:$dst), "fisttp{s}\t$dst">; +def ISTT_FP32m : FPI<0xDB, MRM1m, (outs), (ins i32mem:$dst), "fisttp{l}\t$dst">; +def ISTT_FP64m : FPI<0xDD, MRM1m, (outs), (ins i64mem:$dst), "fisttp{ll}\t$dst">; } // FP Stack manipulation instructions. let SchedRW = [WriteMove] in { -def LD_Frr : FPI<0xD9, MRM0r, (outs), (ins RST:$op), "fld\t$op", IIC_FLD>; -def ST_Frr : FPI<0xDD, MRM2r, (outs), (ins RST:$op), "fst\t$op", IIC_FST>; -def ST_FPrr : FPI<0xDD, MRM3r, (outs), (ins RST:$op), "fstp\t$op", IIC_FST>; -def XCH_F : FPI<0xD9, MRM1r, (outs), (ins RST:$op), "fxch\t$op", IIC_FXCH>; +def LD_Frr : FPI<0xD9, MRM0r, (outs), (ins RST:$op), "fld\t$op">; +def ST_Frr : FPI<0xDD, MRM2r, (outs), (ins RST:$op), "fst\t$op">; +def ST_FPrr : FPI<0xDD, MRM3r, (outs), (ins RST:$op), "fstp\t$op">; +def XCH_F : FPI<0xD9, MRM1r, (outs), (ins RST:$op), "fxch\t$op">; } // Floating point constant loads. @@ -587,8 +563,8 @@ def LD_Fp180 : FpI_<(outs RFP80:$dst), (ins), ZeroArgFP, } let SchedRW = [WriteZero] in { -def LD_F0 : FPI<0xD9, MRM_EE, (outs), (ins), "fldz", IIC_FLDZ>; -def LD_F1 : FPI<0xD9, MRM_E8, (outs), (ins), "fld1", IIC_FIST>; +def LD_F0 : FPI<0xD9, MRM_EE, (outs), (ins), "fldz">; +def LD_F1 : FPI<0xD9, MRM_E8, (outs), (ins), "fld1">; } // Floating point compares. @@ -615,25 +591,23 @@ def UCOM_FpIr80: FpI_<(outs), (ins RFP80:$lhs, RFP80:$rhs), CompareFP, let Defs = [FPSW], Uses = [ST0] in { def UCOM_Fr : FPI<0xDD, MRM4r, // FPSW = cmp ST(0) with ST(i) - (outs), (ins RST:$reg), "fucom\t$reg", IIC_FUCOM>; + (outs), (ins RST:$reg), "fucom\t$reg">; def UCOM_FPr : FPI<0xDD, MRM5r, // FPSW = cmp ST(0) with ST(i), pop - (outs), (ins RST:$reg), "fucomp\t$reg", IIC_FUCOM>; + (outs), (ins RST:$reg), "fucomp\t$reg">; def UCOM_FPPr : FPI<0xDA, MRM_E9, // cmp ST(0) with ST(1), pop, pop - (outs), (ins), "fucompp", IIC_FUCOM>; + (outs), (ins), "fucompp">; } let Defs = [EFLAGS, FPSW], Uses = [ST0] in { def UCOM_FIr : FPI<0xDB, MRM5r, // CC = cmp ST(0) with ST(i) - (outs), (ins RST:$reg), "fucomi\t$reg", IIC_FUCOMI>; + (outs), (ins RST:$reg), "fucomi\t$reg">; def UCOM_FIPr : FPI<0xDF, MRM5r, // CC = cmp ST(0) with ST(i), pop - (outs), (ins RST:$reg), "fucompi\t$reg", IIC_FUCOMI>; + (outs), (ins RST:$reg), "fucompi\t$reg">; } let Defs = [EFLAGS, FPSW] in { -def COM_FIr : FPI<0xDB, MRM6r, (outs), (ins RST:$reg), - "fcomi\t$reg", IIC_FCOMI>; -def COM_FIPr : FPI<0xDF, MRM6r, (outs), (ins RST:$reg), - "fcompi\t$reg", IIC_FCOMI>; +def COM_FIr : FPI<0xDB, MRM6r, (outs), (ins RST:$reg), "fcomi\t$reg">; +def COM_FIPr : FPI<0xDF, MRM6r, (outs), (ins RST:$reg), "fcompi\t$reg">; } } // SchedRW @@ -642,71 +616,69 @@ let SchedRW = [WriteALU] in { let Defs = [AX], Uses = [FPSW] in def FNSTSW16r : I<0xDF, MRM_E0, // AX = fp flags (outs), (ins), "fnstsw\t{%ax|ax}", - [(set AX, (X86fp_stsw FPSW))], IIC_FNSTSW>; + [(set AX, (X86fp_stsw FPSW))]>; let Defs = [FPSW] in def FNSTCW16m : I<0xD9, MRM7m, // [mem16] = X87 control world (outs), (ins i16mem:$dst), "fnstcw\t$dst", - [(X86fp_cwd_get16 addr:$dst)], IIC_FNSTCW>; + [(X86fp_cwd_get16 addr:$dst)]>; } // SchedRW let Defs = [FPSW], mayLoad = 1 in def FLDCW16m : I<0xD9, MRM5m, // X87 control world = [mem16] - (outs), (ins i16mem:$dst), "fldcw\t$dst", [], IIC_FLDCW>, + (outs), (ins i16mem:$dst), "fldcw\t$dst", []>, Sched<[WriteLoad]>; // FPU control instructions let SchedRW = [WriteMicrocoded] in { let Defs = [FPSW] in { -def FNINIT : I<0xDB, MRM_E3, (outs), (ins), "fninit", [], IIC_FNINIT>; -def FFREE : FPI<0xDD, MRM0r, (outs), (ins RST:$reg), - "ffree\t$reg", IIC_FFREE>; -def FFREEP : FPI<0xDF, MRM0r, (outs), (ins RST:$reg), - "ffreep\t$reg", IIC_FFREE>; +def FNINIT : I<0xDB, MRM_E3, (outs), (ins), "fninit", []>; +def FFREE : FPI<0xDD, MRM0r, (outs), (ins RST:$reg), "ffree\t$reg">; +def FFREEP : FPI<0xDF, MRM0r, (outs), (ins RST:$reg), "ffreep\t$reg">; // Clear exceptions -def FNCLEX : I<0xDB, MRM_E2, (outs), (ins), "fnclex", [], IIC_FNCLEX>; +def FNCLEX : I<0xDB, MRM_E2, (outs), (ins), "fnclex", []>; } // Defs = [FPSW] } // SchedRW // Operand-less floating-point instructions for the disassembler. -def FNOP : I<0xD9, MRM_D0, (outs), (ins), "fnop", [], IIC_FNOP>, Sched<[WriteNop]>; +def FNOP : I<0xD9, MRM_D0, (outs), (ins), "fnop", []>, Sched<[WriteNop]>; let SchedRW = [WriteMicrocoded] in { let Defs = [FPSW] in { -def WAIT : I<0x9B, RawFrm, (outs), (ins), "wait", [], IIC_WAIT>; -def FXAM : I<0xD9, MRM_E5, (outs), (ins), "fxam", [], IIC_FXAM>; -def FLDL2T : I<0xD9, MRM_E9, (outs), (ins), "fldl2t", [], IIC_FLDL>; -def FLDL2E : I<0xD9, MRM_EA, (outs), (ins), "fldl2e", [], IIC_FLDL>; -def FLDPI : I<0xD9, MRM_EB, (outs), (ins), "fldpi", [], IIC_FLDL>; -def FLDLG2 : I<0xD9, MRM_EC, (outs), (ins), "fldlg2", [], IIC_FLDL>; -def FLDLN2 : I<0xD9, MRM_ED, (outs), (ins), "fldln2", [], IIC_FLDL>; -def F2XM1 : I<0xD9, MRM_F0, (outs), (ins), "f2xm1", [], IIC_F2XM1>; -def FYL2X : I<0xD9, MRM_F1, (outs), (ins), "fyl2x", [], IIC_FYL2X>; -def FPTAN : I<0xD9, MRM_F2, (outs), (ins), "fptan", [], IIC_FPTAN>; -def FPATAN : I<0xD9, MRM_F3, (outs), (ins), "fpatan", [], IIC_FPATAN>; -def FXTRACT : I<0xD9, MRM_F4, (outs), (ins), "fxtract", [], IIC_FXTRACT>; -def FPREM1 : I<0xD9, MRM_F5, (outs), (ins), "fprem1", [], IIC_FPREM1>; -def FDECSTP : I<0xD9, MRM_F6, (outs), (ins), "fdecstp", [], IIC_FPSTP>; -def FINCSTP : I<0xD9, MRM_F7, (outs), (ins), "fincstp", [], IIC_FPSTP>; -def FPREM : I<0xD9, MRM_F8, (outs), (ins), "fprem", [], IIC_FPREM>; -def FYL2XP1 : I<0xD9, MRM_F9, (outs), (ins), "fyl2xp1", [], IIC_FYL2XP1>; -def FSINCOS : I<0xD9, MRM_FB, (outs), (ins), "fsincos", [], IIC_FSINCOS>; -def FRNDINT : I<0xD9, MRM_FC, (outs), (ins), "frndint", [], IIC_FRNDINT>; -def FSCALE : I<0xD9, MRM_FD, (outs), (ins), "fscale", [], IIC_FSCALE>; -def FCOMPP : I<0xDE, MRM_D9, (outs), (ins), "fcompp", [], IIC_FCOMPP>; +def WAIT : I<0x9B, RawFrm, (outs), (ins), "wait", []>; +def FXAM : I<0xD9, MRM_E5, (outs), (ins), "fxam", []>; +def FLDL2T : I<0xD9, MRM_E9, (outs), (ins), "fldl2t", []>; +def FLDL2E : I<0xD9, MRM_EA, (outs), (ins), "fldl2e", []>; +def FLDPI : I<0xD9, MRM_EB, (outs), (ins), "fldpi", []>; +def FLDLG2 : I<0xD9, MRM_EC, (outs), (ins), "fldlg2", []>; +def FLDLN2 : I<0xD9, MRM_ED, (outs), (ins), "fldln2", []>; +def F2XM1 : I<0xD9, MRM_F0, (outs), (ins), "f2xm1", []>; +def FYL2X : I<0xD9, MRM_F1, (outs), (ins), "fyl2x", []>; +def FPTAN : I<0xD9, MRM_F2, (outs), (ins), "fptan", []>; +def FPATAN : I<0xD9, MRM_F3, (outs), (ins), "fpatan", []>; +def FXTRACT : I<0xD9, MRM_F4, (outs), (ins), "fxtract", []>; +def FPREM1 : I<0xD9, MRM_F5, (outs), (ins), "fprem1", []>; +def FDECSTP : I<0xD9, MRM_F6, (outs), (ins), "fdecstp", []>; +def FINCSTP : I<0xD9, MRM_F7, (outs), (ins), "fincstp", []>; +def FPREM : I<0xD9, MRM_F8, (outs), (ins), "fprem", []>; +def FYL2XP1 : I<0xD9, MRM_F9, (outs), (ins), "fyl2xp1", []>; +def FSINCOS : I<0xD9, MRM_FB, (outs), (ins), "fsincos", []>; +def FRNDINT : I<0xD9, MRM_FC, (outs), (ins), "frndint", []>; +def FSCALE : I<0xD9, MRM_FD, (outs), (ins), "fscale", []>; +def FCOMPP : I<0xDE, MRM_D9, (outs), (ins), "fcompp", []>; } // Defs = [FPSW] def FXSAVE : I<0xAE, MRM0m, (outs), (ins opaque512mem:$dst), - "fxsave\t$dst", [(int_x86_fxsave addr:$dst)], IIC_FXSAVE>, TB, + "fxsave\t$dst", [(int_x86_fxsave addr:$dst)]>, TB, Requires<[HasFXSR]>; def FXSAVE64 : RI<0xAE, MRM0m, (outs), (ins opaque512mem:$dst), - "fxsave64\t$dst", [(int_x86_fxsave64 addr:$dst)], - IIC_FXSAVE>, TB, Requires<[HasFXSR, In64BitMode]>; + "fxsave64\t$dst", [(int_x86_fxsave64 addr:$dst)]>, + TB, Requires<[HasFXSR, In64BitMode]>; def FXRSTOR : I<0xAE, MRM1m, (outs), (ins opaque512mem:$src), - "fxrstor\t$src", [(int_x86_fxrstor addr:$src)], IIC_FXRSTOR>, + "fxrstor\t$src", [(int_x86_fxrstor addr:$src)]>, TB, Requires<[HasFXSR]>; def FXRSTOR64 : RI<0xAE, MRM1m, (outs), (ins opaque512mem:$src), - "fxrstor64\t$src", [(int_x86_fxrstor64 addr:$src)], - IIC_FXRSTOR>, TB, Requires<[HasFXSR, In64BitMode]>; + "fxrstor64\t$src", [(int_x86_fxrstor64 addr:$src)]>, + TB, Requires<[HasFXSR, In64BitMode]>; } // SchedRW //===----------------------------------------------------------------------===// diff --git a/llvm/lib/Target/X86/X86InstrFormats.td b/llvm/lib/Target/X86/X86InstrFormats.td index a501a502f56..dff6d1e9ae2 100644 --- a/llvm/lib/Target/X86/X86InstrFormats.td +++ b/llvm/lib/Target/X86/X86InstrFormats.td @@ -432,14 +432,12 @@ class Ii32PCRel<bits<8> o, Format f, dag outs, dag ins, string asm, // FPStack Instruction Templates: // FPI - Floating Point Instruction template. -class FPI<bits<8> o, Format F, dag outs, dag ins, string asm, - InstrItinClass itin = NoItinerary> - : I<o, F, outs, ins, asm, [], itin> {} +class FPI<bits<8> o, Format F, dag outs, dag ins, string asm> + : I<o, F, outs, ins, asm, []> {} // FpI_ - Floating Point Pseudo Instruction template. Not Predicated. -class FpI_<dag outs, dag ins, FPFormat fp, list<dag> pattern, - InstrItinClass itin = NoItinerary> - : PseudoI<outs, ins, pattern, itin> { +class FpI_<dag outs, dag ins, FPFormat fp, list<dag> pattern> + : PseudoI<outs, ins, pattern> { let FPForm = fp; } diff --git a/llvm/lib/Target/X86/X86Schedule.td b/llvm/lib/Target/X86/X86Schedule.td index 0dc5f7288d5..5ffa6659b98 100644 --- a/llvm/lib/Target/X86/X86Schedule.td +++ b/llvm/lib/Target/X86/X86Schedule.td @@ -490,47 +490,6 @@ def IIC_CMPX_LOCK_16B : InstrItinClass; def IIC_XADD_LOCK_MEM : InstrItinClass; def IIC_XADD_LOCK_MEM8 : InstrItinClass; -def IIC_FCMOV : InstrItinClass; -def IIC_FILD : InstrItinClass; -def IIC_FLD : InstrItinClass; -def IIC_FLD80 : InstrItinClass; -def IIC_FST : InstrItinClass; -def IIC_FST80 : InstrItinClass; -def IIC_FIST : InstrItinClass; -def IIC_FLDZ : InstrItinClass; -def IIC_FUCOM : InstrItinClass; -def IIC_FUCOMI : InstrItinClass; -def IIC_FCOMI : InstrItinClass; -def IIC_FNSTSW : InstrItinClass; -def IIC_FNSTCW : InstrItinClass; -def IIC_FLDCW : InstrItinClass; -def IIC_FNINIT : InstrItinClass; -def IIC_FFREE : InstrItinClass; -def IIC_FNCLEX : InstrItinClass; -def IIC_WAIT : InstrItinClass; -def IIC_FXAM : InstrItinClass; -def IIC_FNOP : InstrItinClass; -def IIC_FLDL : InstrItinClass; -def IIC_F2XM1 : InstrItinClass; -def IIC_FYL2X : InstrItinClass; -def IIC_FPTAN : InstrItinClass; -def IIC_FPATAN : InstrItinClass; -def IIC_FXTRACT : InstrItinClass; -def IIC_FPREM1 : InstrItinClass; -def IIC_FPSTP : InstrItinClass; -def IIC_FPREM : InstrItinClass; -def IIC_FSIGN : InstrItinClass; -def IIC_FSQRT : InstrItinClass; -def IIC_FYL2XP1 : InstrItinClass; -def IIC_FSINCOS : InstrItinClass; -def IIC_FRNDINT : InstrItinClass; -def IIC_FSCALE : InstrItinClass; -def IIC_FCOMPP : InstrItinClass; -def IIC_FXSAVE : InstrItinClass; -def IIC_FXRSTOR : InstrItinClass; - -def IIC_FXCH : InstrItinClass; - // System instructions def IIC_CPUID : InstrItinClass; def IIC_INT : InstrItinClass; |

