mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-05 13:09:10 +00:00
This patch continues the work of adding instruction latencies for X86 Atom,
by providing the latencies for the instructions in X86InstrFPStack.td. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@155996 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e2849851b2
commit
95f0cf0438
@ -423,24 +423,40 @@ def IST_Fp64m80 : FpI_<(outs), (ins i64mem:$op, RFP80:$src), OneArgFP, []>;
|
||||
}
|
||||
|
||||
let mayLoad = 1 in {
|
||||
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">;
|
||||
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>;
|
||||
}
|
||||
let mayStore = 1 in {
|
||||
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">;
|
||||
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>;
|
||||
}
|
||||
|
||||
// FISTTP requires SSE3 even though it's a FPStack op.
|
||||
@ -466,17 +482,23 @@ def ISTT_Fp64m80 : FpI_<(outs), (ins i64mem:$op, RFP80:$src), OneArgFP,
|
||||
} // Predicates = [HasSSE3]
|
||||
|
||||
let mayStore = 1 in {
|
||||
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_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">;
|
||||
"fisttp{ll}\t$dst", IIC_FST>;
|
||||
}
|
||||
|
||||
// FP Stack manipulation instructions.
|
||||
def LD_Frr : FPI<0xC0, AddRegFrm, (outs), (ins RST:$op), "fld\t$op">, D9;
|
||||
def ST_Frr : FPI<0xD0, AddRegFrm, (outs), (ins RST:$op), "fst\t$op">, DD;
|
||||
def ST_FPrr : FPI<0xD8, AddRegFrm, (outs), (ins RST:$op), "fstp\t$op">, DD;
|
||||
def XCH_F : FPI<0xC8, AddRegFrm, (outs), (ins RST:$op), "fxch\t$op">, D9;
|
||||
def LD_Frr : FPI<0xC0, AddRegFrm, (outs), (ins RST:$op), "fld\t$op",
|
||||
IIC_FLD>, D9;
|
||||
def ST_Frr : FPI<0xD0, AddRegFrm, (outs), (ins RST:$op), "fst\t$op",
|
||||
IIC_FST>, DD;
|
||||
def ST_FPrr : FPI<0xD8, AddRegFrm, (outs), (ins RST:$op), "fstp\t$op",
|
||||
IIC_FST>, DD;
|
||||
def XCH_F : FPI<0xC8, AddRegFrm, (outs), (ins RST:$op), "fxch\t$op",
|
||||
IIC_FXCH>, D9;
|
||||
|
||||
// Floating point constant loads.
|
||||
let isReMaterializable = 1 in {
|
||||
@ -494,8 +516,8 @@ def LD_Fp180 : FpI_<(outs RFP80:$dst), (ins), ZeroArgFP,
|
||||
[(set RFP80:$dst, fpimm1)]>;
|
||||
}
|
||||
|
||||
def LD_F0 : FPI<0xEE, RawFrm, (outs), (ins), "fldz">, D9;
|
||||
def LD_F1 : FPI<0xE8, RawFrm, (outs), (ins), "fld1">, D9;
|
||||
def LD_F0 : FPI<0xEE, RawFrm, (outs), (ins), "fldz", IIC_FLDZ>, D9;
|
||||
def LD_F1 : FPI<0xE8, RawFrm, (outs), (ins), "fld1", IIC_FIST>, D9;
|
||||
|
||||
|
||||
// Floating point compares.
|
||||
@ -520,89 +542,91 @@ def UCOM_FpIr80: FpI_<(outs), (ins RFP80:$lhs, RFP80:$rhs), CompareFP,
|
||||
let Defs = [FPSW], Uses = [ST0] in {
|
||||
def UCOM_Fr : FPI<0xE0, AddRegFrm, // FPSW = cmp ST(0) with ST(i)
|
||||
(outs), (ins RST:$reg),
|
||||
"fucom\t$reg">, DD;
|
||||
"fucom\t$reg", IIC_FUCOM>, DD;
|
||||
def UCOM_FPr : FPI<0xE8, AddRegFrm, // FPSW = cmp ST(0) with ST(i), pop
|
||||
(outs), (ins RST:$reg),
|
||||
"fucomp\t$reg">, DD;
|
||||
"fucomp\t$reg", IIC_FUCOM>, DD;
|
||||
def UCOM_FPPr : FPI<0xE9, RawFrm, // cmp ST(0) with ST(1), pop, pop
|
||||
(outs), (ins),
|
||||
"fucompp">, DA;
|
||||
"fucompp", IIC_FUCOM>, DA;
|
||||
}
|
||||
|
||||
let Defs = [EFLAGS, FPSW], Uses = [ST0] in {
|
||||
def UCOM_FIr : FPI<0xE8, AddRegFrm, // CC = cmp ST(0) with ST(i)
|
||||
(outs), (ins RST:$reg),
|
||||
"fucomi\t$reg">, DB;
|
||||
"fucomi\t$reg", IIC_FUCOMI>, DB;
|
||||
def UCOM_FIPr : FPI<0xE8, AddRegFrm, // CC = cmp ST(0) with ST(i), pop
|
||||
(outs), (ins RST:$reg),
|
||||
"fucompi\t$reg">, DF;
|
||||
"fucompi\t$reg", IIC_FUCOMI>, DF;
|
||||
}
|
||||
|
||||
let Defs = [EFLAGS, FPSW] in {
|
||||
def COM_FIr : FPI<0xF0, AddRegFrm, (outs), (ins RST:$reg),
|
||||
"fcomi\t$reg">, DB;
|
||||
"fcomi\t$reg", IIC_FCOMI>, DB;
|
||||
def COM_FIPr : FPI<0xF0, AddRegFrm, (outs), (ins RST:$reg),
|
||||
"fcompi\t$reg">, DF;
|
||||
"fcompi\t$reg", IIC_FCOMI>, DF;
|
||||
}
|
||||
|
||||
// Floating point flag ops.
|
||||
let Defs = [AX], Uses = [FPSW] in
|
||||
def FNSTSW16r : I<0xE0, RawFrm, // AX = fp flags
|
||||
(outs), (ins), "fnstsw %ax",
|
||||
[(set AX, (X86fp_stsw FPSW))]>, DF;
|
||||
[(set AX, (X86fp_stsw FPSW))], IIC_FNSTSW>, DF;
|
||||
|
||||
def FNSTCW16m : I<0xD9, MRM7m, // [mem16] = X87 control world
|
||||
(outs), (ins i16mem:$dst), "fnstcw\t$dst",
|
||||
[(X86fp_cwd_get16 addr:$dst)]>;
|
||||
[(X86fp_cwd_get16 addr:$dst)], IIC_FNSTCW>;
|
||||
|
||||
let mayLoad = 1 in
|
||||
def FLDCW16m : I<0xD9, MRM5m, // X87 control world = [mem16]
|
||||
(outs), (ins i16mem:$dst), "fldcw\t$dst", []>;
|
||||
(outs), (ins i16mem:$dst), "fldcw\t$dst", [], IIC_FLDCW>;
|
||||
|
||||
// FPU control instructions
|
||||
let Defs = [FPSW] in
|
||||
def FNINIT : I<0xE3, RawFrm, (outs), (ins), "fninit", []>, DB;
|
||||
def FNINIT : I<0xE3, RawFrm, (outs), (ins), "fninit", [], IIC_FNINIT>, DB;
|
||||
def FFREE : FPI<0xC0, AddRegFrm, (outs), (ins RST:$reg),
|
||||
"ffree\t$reg">, DD;
|
||||
"ffree\t$reg", IIC_FFREE>, DD;
|
||||
|
||||
// Clear exceptions
|
||||
|
||||
let Defs = [FPSW] in
|
||||
def FNCLEX : I<0xE2, RawFrm, (outs), (ins), "fnclex", []>, DB;
|
||||
def FNCLEX : I<0xE2, RawFrm, (outs), (ins), "fnclex", [], IIC_FNCLEX>, DB;
|
||||
|
||||
// Operandless floating-point instructions for the disassembler.
|
||||
def WAIT : I<0x9B, RawFrm, (outs), (ins), "wait", []>;
|
||||
def WAIT : I<0x9B, RawFrm, (outs), (ins), "wait", [], IIC_WAIT>;
|
||||
|
||||
def FNOP : I<0xD0, RawFrm, (outs), (ins), "fnop", []>, D9;
|
||||
def FXAM : I<0xE5, RawFrm, (outs), (ins), "fxam", []>, D9;
|
||||
def FLDL2T : I<0xE9, RawFrm, (outs), (ins), "fldl2t", []>, D9;
|
||||
def FLDL2E : I<0xEA, RawFrm, (outs), (ins), "fldl2e", []>, D9;
|
||||
def FLDPI : I<0xEB, RawFrm, (outs), (ins), "fldpi", []>, D9;
|
||||
def FLDLG2 : I<0xEC, RawFrm, (outs), (ins), "fldlg2", []>, D9;
|
||||
def FLDLN2 : I<0xED, RawFrm, (outs), (ins), "fldln2", []>, D9;
|
||||
def F2XM1 : I<0xF0, RawFrm, (outs), (ins), "f2xm1", []>, D9;
|
||||
def FYL2X : I<0xF1, RawFrm, (outs), (ins), "fyl2x", []>, D9;
|
||||
def FPTAN : I<0xF2, RawFrm, (outs), (ins), "fptan", []>, D9;
|
||||
def FPATAN : I<0xF3, RawFrm, (outs), (ins), "fpatan", []>, D9;
|
||||
def FXTRACT : I<0xF4, RawFrm, (outs), (ins), "fxtract", []>, D9;
|
||||
def FPREM1 : I<0xF5, RawFrm, (outs), (ins), "fprem1", []>, D9;
|
||||
def FDECSTP : I<0xF6, RawFrm, (outs), (ins), "fdecstp", []>, D9;
|
||||
def FINCSTP : I<0xF7, RawFrm, (outs), (ins), "fincstp", []>, D9;
|
||||
def FPREM : I<0xF8, RawFrm, (outs), (ins), "fprem", []>, D9;
|
||||
def FYL2XP1 : I<0xF9, RawFrm, (outs), (ins), "fyl2xp1", []>, D9;
|
||||
def FSINCOS : I<0xFB, RawFrm, (outs), (ins), "fsincos", []>, D9;
|
||||
def FRNDINT : I<0xFC, RawFrm, (outs), (ins), "frndint", []>, D9;
|
||||
def FSCALE : I<0xFD, RawFrm, (outs), (ins), "fscale", []>, D9;
|
||||
def FCOMPP : I<0xD9, RawFrm, (outs), (ins), "fcompp", []>, DE;
|
||||
def FNOP : I<0xD0, RawFrm, (outs), (ins), "fnop", [], IIC_FNOP>, D9;
|
||||
def FXAM : I<0xE5, RawFrm, (outs), (ins), "fxam", [], IIC_FXAM>, D9;
|
||||
def FLDL2T : I<0xE9, RawFrm, (outs), (ins), "fldl2t", [], IIC_FLDL>, D9;
|
||||
def FLDL2E : I<0xEA, RawFrm, (outs), (ins), "fldl2e", [], IIC_FLDL>, D9;
|
||||
def FLDPI : I<0xEB, RawFrm, (outs), (ins), "fldpi", [], IIC_FLDL>, D9;
|
||||
def FLDLG2 : I<0xEC, RawFrm, (outs), (ins), "fldlg2", [], IIC_FLDL>, D9;
|
||||
def FLDLN2 : I<0xED, RawFrm, (outs), (ins), "fldln2", [], IIC_FLDL>, D9;
|
||||
def F2XM1 : I<0xF0, RawFrm, (outs), (ins), "f2xm1", [], IIC_F2XM1>, D9;
|
||||
def FYL2X : I<0xF1, RawFrm, (outs), (ins), "fyl2x", [], IIC_FYL2X>, D9;
|
||||
def FPTAN : I<0xF2, RawFrm, (outs), (ins), "fptan", [], IIC_FPTAN>, D9;
|
||||
def FPATAN : I<0xF3, RawFrm, (outs), (ins), "fpatan", [], IIC_FPATAN>, D9;
|
||||
def FXTRACT : I<0xF4, RawFrm, (outs), (ins), "fxtract", [], IIC_FXTRACT>, D9;
|
||||
def FPREM1 : I<0xF5, RawFrm, (outs), (ins), "fprem1", [], IIC_FPREM1>, D9;
|
||||
def FDECSTP : I<0xF6, RawFrm, (outs), (ins), "fdecstp", [], IIC_FPSTP>, D9;
|
||||
def FINCSTP : I<0xF7, RawFrm, (outs), (ins), "fincstp", [], IIC_FPSTP>, D9;
|
||||
def FPREM : I<0xF8, RawFrm, (outs), (ins), "fprem", [], IIC_FPREM>, D9;
|
||||
def FYL2XP1 : I<0xF9, RawFrm, (outs), (ins), "fyl2xp1", [], IIC_FYL2XP1>, D9;
|
||||
def FSINCOS : I<0xFB, RawFrm, (outs), (ins), "fsincos", [], IIC_FSINCOS>, D9;
|
||||
def FRNDINT : I<0xFC, RawFrm, (outs), (ins), "frndint", [], IIC_FRNDINT>, D9;
|
||||
def FSCALE : I<0xFD, RawFrm, (outs), (ins), "fscale", [], IIC_FSCALE>, D9;
|
||||
def FCOMPP : I<0xD9, RawFrm, (outs), (ins), "fcompp", [], IIC_FCOMPP>, DE;
|
||||
|
||||
def FXSAVE : I<0xAE, MRM0m, (outs opaque512mem:$dst), (ins),
|
||||
"fxsave\t$dst", []>, TB;
|
||||
"fxsave\t$dst", [], IIC_FXSAVE>, TB;
|
||||
def FXSAVE64 : I<0xAE, MRM0m, (outs opaque512mem:$dst), (ins),
|
||||
"fxsaveq\t$dst", []>, TB, REX_W, Requires<[In64BitMode]>;
|
||||
"fxsaveq\t$dst", [], IIC_FXSAVE>, TB, REX_W,
|
||||
Requires<[In64BitMode]>;
|
||||
def FXRSTOR : I<0xAE, MRM1m, (outs), (ins opaque512mem:$src),
|
||||
"fxrstor\t$src", []>, TB;
|
||||
"fxrstor\t$src", [], IIC_FXRSTOR>, TB;
|
||||
def FXRSTOR64 : I<0xAE, MRM1m, (outs), (ins opaque512mem:$src),
|
||||
"fxrstorq\t$src", []>, TB, REX_W, Requires<[In64BitMode]>;
|
||||
"fxrstorq\t$src", [], IIC_FXRSTOR>, TB, REX_W,
|
||||
Requires<[In64BitMode]>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Non-Instruction Patterns
|
||||
|
@ -255,8 +255,9 @@ 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>
|
||||
: I<o, F, outs, ins, asm, []> {}
|
||||
class FPI<bits<8> o, Format F, dag outs, dag ins, string asm,
|
||||
InstrItinClass itin = IIC_DEFAULT>
|
||||
: I<o, F, outs, ins, asm, [], itin> {}
|
||||
|
||||
// FpI_ - Floating Point Pseudo Instruction template. Not Predicated.
|
||||
class FpI_<dag outs, dag ins, FPFormat fp, list<dag> pattern,
|
||||
|
@ -261,6 +261,44 @@ def IIC_CMPX_LOCK_16B : InstrItinClass;
|
||||
def IIC_XADD_LOCK_MEM : InstrItinClass;
|
||||
def IIC_XADD_LOCK_MEM8 : 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_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;
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Processor instruction itineraries.
|
||||
|
@ -300,6 +300,46 @@ def AtomItineraries : ProcessorItineraries<
|
||||
InstrItinData<IIC_CMPX_LOCK_16B, [InstrStage<22, [Port0, Port1]>] >,
|
||||
|
||||
InstrItinData<IIC_XADD_LOCK_MEM, [InstrStage<2, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_XADD_LOCK_MEM, [InstrStage<3, [Port0, Port1]>] >
|
||||
InstrItinData<IIC_XADD_LOCK_MEM, [InstrStage<3, [Port0, Port1]>] >,
|
||||
|
||||
InstrItinData<IIC_FILD, [InstrStage<5, [Port0], 0>, InstrStage<5, [Port1]>] >,
|
||||
InstrItinData<IIC_FLD, [InstrStage<1, [Port0]>] >,
|
||||
InstrItinData<IIC_FLD80, [InstrStage<4, [Port0, Port1]>] >,
|
||||
|
||||
InstrItinData<IIC_FST, [InstrStage<2, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FST80, [InstrStage<5, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FIST, [InstrStage<6, [Port0, Port1]>] >,
|
||||
|
||||
InstrItinData<IIC_FLDZ, [InstrStage<1, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FUCOM, [InstrStage<1, [Port1]>] >,
|
||||
InstrItinData<IIC_FUCOMI, [InstrStage<9, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FCOMI, [InstrStage<9, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FNSTSW, [InstrStage<10, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FNSTCW, [InstrStage<8, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FLDCW, [InstrStage<5, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FNINIT, [InstrStage<63, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FFREE, [InstrStage<1, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FNCLEX, [InstrStage<25, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_WAIT, [InstrStage<1, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FXAM, [InstrStage<1, [Port0]>] >,
|
||||
InstrItinData<IIC_FNOP, [InstrStage<1, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FLDL, [InstrStage<10, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_F2XM1, [InstrStage<99, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FYL2X, [InstrStage<146, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FPTAN, [InstrStage<168, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FPATAN, [InstrStage<183, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FXTRACT, [InstrStage<25, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FPREM1, [InstrStage<71, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FPSTP, [InstrStage<1, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FPREM, [InstrStage<55, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FYL2XP1, [InstrStage<147, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FSINCOS, [InstrStage<174, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FRNDINT, [InstrStage<46, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FSCALE, [InstrStage<77, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FCOMPP, [InstrStage<1, [Port1]>] >,
|
||||
InstrItinData<IIC_FXSAVE, [InstrStage<140, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FXRSTOR, [InstrStage<141, [Port0, Port1]>] >,
|
||||
InstrItinData<IIC_FXCH, [InstrStage<1, [Port0], 0>, InstrStage<1, [Port1]>] >
|
||||
|
||||
]>;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user