forked from OSchip/llvm-project
724 lines
25 KiB
TableGen
724 lines
25 KiB
TableGen
//===-- X86Schedule.td - X86 Scheduling Definitions --------*- tablegen -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// InstrSchedModel annotations for out-of-order CPUs.
|
|
//
|
|
// These annotations are independent of the itinerary classes defined below.
|
|
|
|
// Instructions with folded loads need to read the memory operand immediately,
|
|
// but other register operands don't have to be read until the load is ready.
|
|
// These operands are marked with ReadAfterLd.
|
|
def ReadAfterLd : SchedRead;
|
|
|
|
// Instructions with both a load and a store folded are modeled as a folded
|
|
// load + WriteRMW.
|
|
def WriteRMW : SchedWrite;
|
|
|
|
// Most instructions can fold loads, so almost every SchedWrite comes in two
|
|
// variants: With and without a folded load.
|
|
// An X86FoldableSchedWrite holds a reference to the corresponding SchedWrite
|
|
// with a folded load.
|
|
class X86FoldableSchedWrite : SchedWrite {
|
|
// The SchedWrite to use when a load is folded into the instruction.
|
|
SchedWrite Folded;
|
|
}
|
|
|
|
// Multiclass that produces a linked pair of SchedWrites.
|
|
multiclass X86SchedWritePair {
|
|
// Register-Memory operation.
|
|
def Ld : SchedWrite;
|
|
// Register-Register operation.
|
|
def NAME : X86FoldableSchedWrite {
|
|
let Folded = !cast<SchedWrite>(NAME#"Ld");
|
|
}
|
|
}
|
|
|
|
// Arithmetic.
|
|
defm WriteALU : X86SchedWritePair; // Simple integer ALU op.
|
|
defm WriteIMul : X86SchedWritePair; // Integer multiplication.
|
|
def WriteIMulH : SchedWrite; // Integer multiplication, high part.
|
|
defm WriteIDiv : X86SchedWritePair; // Integer division.
|
|
def WriteLEA : SchedWrite; // LEA instructions can't fold loads.
|
|
|
|
defm WriteBitScan : X86SchedWritePair; // Bit scan forward/reverse.
|
|
defm WritePOPCNT : X86SchedWritePair; // Bit population count.
|
|
defm WriteLZCNT : X86SchedWritePair; // Leading zero count.
|
|
defm WriteTZCNT : X86SchedWritePair; // Trailing zero count.
|
|
|
|
// Integer shifts and rotates.
|
|
defm WriteShift : X86SchedWritePair;
|
|
|
|
// Loads, stores, and moves, not folded with other operations.
|
|
def WriteLoad : SchedWrite;
|
|
def WriteStore : SchedWrite;
|
|
def WriteMove : SchedWrite;
|
|
|
|
// Idioms that clear a register, like xorps %xmm0, %xmm0.
|
|
// These can often bypass execution ports completely.
|
|
def WriteZero : SchedWrite;
|
|
|
|
// Branches don't produce values, so they have no latency, but they still
|
|
// consume resources. Indirect branches can fold loads.
|
|
defm WriteJump : X86SchedWritePair;
|
|
|
|
// Floating point. This covers both scalar and vector operations.
|
|
def WriteFLoad : SchedWrite;
|
|
def WriteFStore : SchedWrite;
|
|
def WriteFMove : SchedWrite;
|
|
defm WriteFAdd : X86SchedWritePair; // Floating point add/sub/compare.
|
|
defm WriteFMul : X86SchedWritePair; // Floating point multiplication.
|
|
defm WriteFDiv : X86SchedWritePair; // Floating point division.
|
|
defm WriteFSqrt : X86SchedWritePair; // Floating point square root.
|
|
defm WriteFRcp : X86SchedWritePair; // Floating point reciprocal estimate.
|
|
defm WriteFRsqrt : X86SchedWritePair; // Floating point reciprocal square root estimate.
|
|
defm WriteFMA : X86SchedWritePair; // Fused Multiply Add.
|
|
defm WriteFShuffle : X86SchedWritePair; // Floating point vector shuffles.
|
|
defm WriteFBlend : X86SchedWritePair; // Floating point vector blends.
|
|
defm WriteFVarBlend : X86SchedWritePair; // Fp vector variable blends.
|
|
|
|
// FMA Scheduling helper class.
|
|
class FMASC { X86FoldableSchedWrite Sched = WriteFAdd; }
|
|
|
|
// Horizontal Add/Sub (float and integer)
|
|
defm WriteFHAdd : X86SchedWritePair;
|
|
defm WritePHAdd : X86SchedWritePair;
|
|
|
|
// Vector integer operations.
|
|
def WriteVecLoad : SchedWrite;
|
|
def WriteVecStore : SchedWrite;
|
|
def WriteVecMove : SchedWrite;
|
|
defm WriteVecALU : X86SchedWritePair; // Vector integer ALU op, no logicals.
|
|
defm WriteVecShift : X86SchedWritePair; // Vector integer shifts.
|
|
defm WriteVecIMul : X86SchedWritePair; // Vector integer multiply.
|
|
defm WriteShuffle : X86SchedWritePair; // Vector shuffles.
|
|
defm WriteBlend : X86SchedWritePair; // Vector blends.
|
|
defm WriteVarBlend : X86SchedWritePair; // Vector variable blends.
|
|
defm WriteMPSAD : X86SchedWritePair; // Vector MPSAD.
|
|
|
|
// Vector bitwise operations.
|
|
// These are often used on both floating point and integer vectors.
|
|
defm WriteVecLogic : X86SchedWritePair; // Vector and/or/xor.
|
|
|
|
// MOVMSK operations.
|
|
def WriteFMOVMSK : SchedWrite;
|
|
def WriteVecMOVMSK : SchedWrite;
|
|
def WriteMMXMOVMSK : SchedWrite;
|
|
|
|
// Conversion between integer and float.
|
|
defm WriteCvtF2I : X86SchedWritePair; // Float -> Integer.
|
|
defm WriteCvtI2F : X86SchedWritePair; // Integer -> Float.
|
|
defm WriteCvtF2F : X86SchedWritePair; // Float -> Float size conversion.
|
|
|
|
// CRC32 instruction.
|
|
defm WriteCRC32 : X86SchedWritePair;
|
|
|
|
// Strings instructions.
|
|
// Packed Compare Implicit Length Strings, Return Mask
|
|
defm WritePCmpIStrM : X86SchedWritePair;
|
|
// Packed Compare Explicit Length Strings, Return Mask
|
|
defm WritePCmpEStrM : X86SchedWritePair;
|
|
// Packed Compare Implicit Length Strings, Return Index
|
|
defm WritePCmpIStrI : X86SchedWritePair;
|
|
// Packed Compare Explicit Length Strings, Return Index
|
|
defm WritePCmpEStrI : X86SchedWritePair;
|
|
|
|
// AES instructions.
|
|
defm WriteAESDecEnc : X86SchedWritePair; // Decryption, encryption.
|
|
defm WriteAESIMC : X86SchedWritePair; // InvMixColumn.
|
|
defm WriteAESKeyGen : X86SchedWritePair; // Key Generation.
|
|
|
|
// Carry-less multiplication instructions.
|
|
defm WriteCLMul : X86SchedWritePair;
|
|
|
|
// Catch-all for expensive system instructions.
|
|
def WriteSystem : SchedWrite;
|
|
|
|
// AVX2.
|
|
defm WriteFShuffle256 : X86SchedWritePair; // Fp 256-bit width vector shuffles.
|
|
defm WriteShuffle256 : X86SchedWritePair; // 256-bit width vector shuffles.
|
|
defm WriteVarVecShift : X86SchedWritePair; // Variable vector shifts.
|
|
|
|
// Old microcoded instructions that nobody use.
|
|
def WriteMicrocoded : SchedWrite;
|
|
|
|
// Fence instructions.
|
|
def WriteFence : SchedWrite;
|
|
|
|
// Nop, not very useful expect it provides a model for nops!
|
|
def WriteNop : SchedWrite;
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Instruction Itinerary classes used for X86
|
|
def IIC_ALU_MEM : InstrItinClass;
|
|
def IIC_ALU_NONMEM : InstrItinClass;
|
|
def IIC_LEA : InstrItinClass;
|
|
def IIC_LEA_16 : InstrItinClass;
|
|
def IIC_MUL8_MEM : InstrItinClass;
|
|
def IIC_MUL8_REG : InstrItinClass;
|
|
def IIC_MUL16_MEM : InstrItinClass;
|
|
def IIC_MUL16_REG : InstrItinClass;
|
|
def IIC_MUL32_MEM : InstrItinClass;
|
|
def IIC_MUL32_REG : InstrItinClass;
|
|
def IIC_MUL64_MEM : InstrItinClass;
|
|
def IIC_MUL64_REG : InstrItinClass;
|
|
// imul by al, ax, eax, tax
|
|
def IIC_IMUL8_MEM : InstrItinClass;
|
|
def IIC_IMUL8_REG : InstrItinClass;
|
|
def IIC_IMUL16_MEM : InstrItinClass;
|
|
def IIC_IMUL16_REG : InstrItinClass;
|
|
def IIC_IMUL32_MEM : InstrItinClass;
|
|
def IIC_IMUL32_REG : InstrItinClass;
|
|
def IIC_IMUL64_MEM : InstrItinClass;
|
|
def IIC_IMUL64_REG : InstrItinClass;
|
|
// imul reg by reg|mem
|
|
def IIC_IMUL16_RM : InstrItinClass;
|
|
def IIC_IMUL16_RR : InstrItinClass;
|
|
def IIC_IMUL32_RM : InstrItinClass;
|
|
def IIC_IMUL32_RR : InstrItinClass;
|
|
def IIC_IMUL64_RM : InstrItinClass;
|
|
def IIC_IMUL64_RR : InstrItinClass;
|
|
// imul reg = reg/mem * imm
|
|
def IIC_IMUL16_RMI : InstrItinClass;
|
|
def IIC_IMUL16_RRI : InstrItinClass;
|
|
def IIC_IMUL32_RMI : InstrItinClass;
|
|
def IIC_IMUL32_RRI : InstrItinClass;
|
|
def IIC_IMUL64_RMI : InstrItinClass;
|
|
def IIC_IMUL64_RRI : InstrItinClass;
|
|
// div
|
|
def IIC_DIV8_MEM : InstrItinClass;
|
|
def IIC_DIV8_REG : InstrItinClass;
|
|
def IIC_DIV16_MEM : InstrItinClass;
|
|
def IIC_DIV16_REG : InstrItinClass;
|
|
def IIC_DIV32_MEM : InstrItinClass;
|
|
def IIC_DIV32_REG : InstrItinClass;
|
|
def IIC_DIV64_MEM : InstrItinClass;
|
|
def IIC_DIV64_REG : InstrItinClass;
|
|
// idiv
|
|
def IIC_IDIV8_MEM : InstrItinClass;
|
|
def IIC_IDIV8_REG : InstrItinClass;
|
|
def IIC_IDIV16_MEM : InstrItinClass;
|
|
def IIC_IDIV16_REG : InstrItinClass;
|
|
def IIC_IDIV32_MEM : InstrItinClass;
|
|
def IIC_IDIV32_REG : InstrItinClass;
|
|
def IIC_IDIV64_MEM : InstrItinClass;
|
|
def IIC_IDIV64_REG : InstrItinClass;
|
|
// neg/not/inc/dec
|
|
def IIC_UNARY_REG : InstrItinClass;
|
|
def IIC_UNARY_MEM : InstrItinClass;
|
|
// add/sub/and/or/xor/sbc/cmp/test
|
|
def IIC_BIN_MEM : InstrItinClass;
|
|
def IIC_BIN_NONMEM : InstrItinClass;
|
|
// adc/sbc
|
|
def IIC_BIN_CARRY_MEM : InstrItinClass;
|
|
def IIC_BIN_CARRY_NONMEM : InstrItinClass;
|
|
// shift/rotate
|
|
def IIC_SR : InstrItinClass;
|
|
// shift double
|
|
def IIC_SHD16_REG_IM : InstrItinClass;
|
|
def IIC_SHD16_REG_CL : InstrItinClass;
|
|
def IIC_SHD16_MEM_IM : InstrItinClass;
|
|
def IIC_SHD16_MEM_CL : InstrItinClass;
|
|
def IIC_SHD32_REG_IM : InstrItinClass;
|
|
def IIC_SHD32_REG_CL : InstrItinClass;
|
|
def IIC_SHD32_MEM_IM : InstrItinClass;
|
|
def IIC_SHD32_MEM_CL : InstrItinClass;
|
|
def IIC_SHD64_REG_IM : InstrItinClass;
|
|
def IIC_SHD64_REG_CL : InstrItinClass;
|
|
def IIC_SHD64_MEM_IM : InstrItinClass;
|
|
def IIC_SHD64_MEM_CL : InstrItinClass;
|
|
// cmov
|
|
def IIC_CMOV16_RM : InstrItinClass;
|
|
def IIC_CMOV16_RR : InstrItinClass;
|
|
def IIC_CMOV32_RM : InstrItinClass;
|
|
def IIC_CMOV32_RR : InstrItinClass;
|
|
def IIC_CMOV64_RM : InstrItinClass;
|
|
def IIC_CMOV64_RR : InstrItinClass;
|
|
// set
|
|
def IIC_SET_R : InstrItinClass;
|
|
def IIC_SET_M : InstrItinClass;
|
|
// jmp/jcc/jcxz
|
|
def IIC_Jcc : InstrItinClass;
|
|
def IIC_JCXZ : InstrItinClass;
|
|
def IIC_JMP_REL : InstrItinClass;
|
|
def IIC_JMP_REG : InstrItinClass;
|
|
def IIC_JMP_MEM : InstrItinClass;
|
|
def IIC_JMP_FAR_MEM : InstrItinClass;
|
|
def IIC_JMP_FAR_PTR : InstrItinClass;
|
|
// loop
|
|
def IIC_LOOP : InstrItinClass;
|
|
def IIC_LOOPE : InstrItinClass;
|
|
def IIC_LOOPNE : InstrItinClass;
|
|
// call
|
|
def IIC_CALL_RI : InstrItinClass;
|
|
def IIC_CALL_MEM : InstrItinClass;
|
|
def IIC_CALL_FAR_MEM : InstrItinClass;
|
|
def IIC_CALL_FAR_PTR : InstrItinClass;
|
|
// ret
|
|
def IIC_RET : InstrItinClass;
|
|
def IIC_RET_IMM : InstrItinClass;
|
|
//sign extension movs
|
|
def IIC_MOVSX : InstrItinClass;
|
|
def IIC_MOVSX_R16_R8 : InstrItinClass;
|
|
def IIC_MOVSX_R16_M8 : InstrItinClass;
|
|
//zero extension movs
|
|
def IIC_MOVZX : InstrItinClass;
|
|
def IIC_MOVZX_R16_R8 : InstrItinClass;
|
|
def IIC_MOVZX_R16_M8 : InstrItinClass;
|
|
|
|
def IIC_REP_MOVS : InstrItinClass;
|
|
def IIC_REP_STOS : InstrItinClass;
|
|
|
|
// SSE scalar/parallel binary operations
|
|
def IIC_SSE_ALU_F32S_RR : InstrItinClass;
|
|
def IIC_SSE_ALU_F32S_RM : InstrItinClass;
|
|
def IIC_SSE_ALU_F64S_RR : InstrItinClass;
|
|
def IIC_SSE_ALU_F64S_RM : InstrItinClass;
|
|
def IIC_SSE_MUL_F32S_RR : InstrItinClass;
|
|
def IIC_SSE_MUL_F32S_RM : InstrItinClass;
|
|
def IIC_SSE_MUL_F64S_RR : InstrItinClass;
|
|
def IIC_SSE_MUL_F64S_RM : InstrItinClass;
|
|
def IIC_SSE_DIV_F32S_RR : InstrItinClass;
|
|
def IIC_SSE_DIV_F32S_RM : InstrItinClass;
|
|
def IIC_SSE_DIV_F64S_RR : InstrItinClass;
|
|
def IIC_SSE_DIV_F64S_RM : InstrItinClass;
|
|
def IIC_SSE_ALU_F32P_RR : InstrItinClass;
|
|
def IIC_SSE_ALU_F32P_RM : InstrItinClass;
|
|
def IIC_SSE_ALU_F64P_RR : InstrItinClass;
|
|
def IIC_SSE_ALU_F64P_RM : InstrItinClass;
|
|
def IIC_SSE_MUL_F32P_RR : InstrItinClass;
|
|
def IIC_SSE_MUL_F32P_RM : InstrItinClass;
|
|
def IIC_SSE_MUL_F64P_RR : InstrItinClass;
|
|
def IIC_SSE_MUL_F64P_RM : InstrItinClass;
|
|
def IIC_SSE_DIV_F32P_RR : InstrItinClass;
|
|
def IIC_SSE_DIV_F32P_RM : InstrItinClass;
|
|
def IIC_SSE_DIV_F64P_RR : InstrItinClass;
|
|
def IIC_SSE_DIV_F64P_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_COMIS_RR : InstrItinClass;
|
|
def IIC_SSE_COMIS_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_HADDSUB_RR : InstrItinClass;
|
|
def IIC_SSE_HADDSUB_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_BIT_P_RR : InstrItinClass;
|
|
def IIC_SSE_BIT_P_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_INTALU_P_RR : InstrItinClass;
|
|
def IIC_SSE_INTALU_P_RM : InstrItinClass;
|
|
def IIC_SSE_INTALUQ_P_RR : InstrItinClass;
|
|
def IIC_SSE_INTALUQ_P_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_INTMUL_P_RR : InstrItinClass;
|
|
def IIC_SSE_INTMUL_P_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_INTSH_P_RR : InstrItinClass;
|
|
def IIC_SSE_INTSH_P_RM : InstrItinClass;
|
|
def IIC_SSE_INTSH_P_RI : InstrItinClass;
|
|
|
|
def IIC_SSE_INTSHDQ_P_RI : InstrItinClass;
|
|
|
|
def IIC_SSE_SHUFP : InstrItinClass;
|
|
def IIC_SSE_PSHUF_RI : InstrItinClass;
|
|
def IIC_SSE_PSHUF_MI : InstrItinClass;
|
|
|
|
def IIC_SSE_PACK : InstrItinClass;
|
|
def IIC_SSE_UNPCK : InstrItinClass;
|
|
|
|
def IIC_SSE_MOVMSK : InstrItinClass;
|
|
def IIC_SSE_MASKMOV : InstrItinClass;
|
|
|
|
def IIC_SSE_PEXTRW : InstrItinClass;
|
|
def IIC_SSE_PINSRW : InstrItinClass;
|
|
|
|
def IIC_SSE_PABS_RR : InstrItinClass;
|
|
def IIC_SSE_PABS_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_SQRTPS_RR : InstrItinClass;
|
|
def IIC_SSE_SQRTPS_RM : InstrItinClass;
|
|
def IIC_SSE_SQRTSS_RR : InstrItinClass;
|
|
def IIC_SSE_SQRTSS_RM : InstrItinClass;
|
|
def IIC_SSE_SQRTPD_RR : InstrItinClass;
|
|
def IIC_SSE_SQRTPD_RM : InstrItinClass;
|
|
def IIC_SSE_SQRTSD_RR : InstrItinClass;
|
|
def IIC_SSE_SQRTSD_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_RSQRTPS_RR : InstrItinClass;
|
|
def IIC_SSE_RSQRTPS_RM : InstrItinClass;
|
|
def IIC_SSE_RSQRTSS_RR : InstrItinClass;
|
|
def IIC_SSE_RSQRTSS_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_RCPP_RR : InstrItinClass;
|
|
def IIC_SSE_RCPP_RM : InstrItinClass;
|
|
def IIC_SSE_RCPS_RR : InstrItinClass;
|
|
def IIC_SSE_RCPS_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_MOV_S_RR : InstrItinClass;
|
|
def IIC_SSE_MOV_S_RM : InstrItinClass;
|
|
def IIC_SSE_MOV_S_MR : InstrItinClass;
|
|
|
|
def IIC_SSE_MOVA_P_RR : InstrItinClass;
|
|
def IIC_SSE_MOVA_P_RM : InstrItinClass;
|
|
def IIC_SSE_MOVA_P_MR : InstrItinClass;
|
|
|
|
def IIC_SSE_MOVU_P_RR : InstrItinClass;
|
|
def IIC_SSE_MOVU_P_RM : InstrItinClass;
|
|
def IIC_SSE_MOVU_P_MR : InstrItinClass;
|
|
|
|
def IIC_SSE_MOVDQ : InstrItinClass;
|
|
def IIC_SSE_MOVD_ToGP : InstrItinClass;
|
|
def IIC_SSE_MOVQ_RR : InstrItinClass;
|
|
|
|
def IIC_SSE_MOV_LH : InstrItinClass;
|
|
|
|
def IIC_SSE_LDDQU : InstrItinClass;
|
|
|
|
def IIC_SSE_MOVNT : InstrItinClass;
|
|
|
|
def IIC_SSE_PHADDSUBD_RR : InstrItinClass;
|
|
def IIC_SSE_PHADDSUBD_RM : InstrItinClass;
|
|
def IIC_SSE_PHADDSUBSW_RR : InstrItinClass;
|
|
def IIC_SSE_PHADDSUBSW_RM : InstrItinClass;
|
|
def IIC_SSE_PHADDSUBW_RR : InstrItinClass;
|
|
def IIC_SSE_PHADDSUBW_RM : InstrItinClass;
|
|
def IIC_SSE_PSHUFB_RR : InstrItinClass;
|
|
def IIC_SSE_PSHUFB_RM : InstrItinClass;
|
|
def IIC_SSE_PSIGN_RR : InstrItinClass;
|
|
def IIC_SSE_PSIGN_RM : InstrItinClass;
|
|
|
|
def IIC_SSE_PMADD : InstrItinClass;
|
|
def IIC_SSE_PMULHRSW : InstrItinClass;
|
|
def IIC_SSE_PALIGNRR : InstrItinClass;
|
|
def IIC_SSE_PALIGNRM : InstrItinClass;
|
|
def IIC_SSE_MWAIT : InstrItinClass;
|
|
def IIC_SSE_MONITOR : InstrItinClass;
|
|
def IIC_SSE_MWAITX : InstrItinClass;
|
|
def IIC_SSE_MONITORX : InstrItinClass;
|
|
def IIC_SSE_CLZERO : InstrItinClass;
|
|
|
|
def IIC_SSE_PREFETCH : InstrItinClass;
|
|
def IIC_SSE_PAUSE : InstrItinClass;
|
|
def IIC_SSE_LFENCE : InstrItinClass;
|
|
def IIC_SSE_MFENCE : InstrItinClass;
|
|
def IIC_SSE_SFENCE : InstrItinClass;
|
|
def IIC_SSE_LDMXCSR : InstrItinClass;
|
|
def IIC_SSE_STMXCSR : InstrItinClass;
|
|
|
|
def IIC_SSE_CVT_PD_RR : InstrItinClass;
|
|
def IIC_SSE_CVT_PD_RM : InstrItinClass;
|
|
def IIC_SSE_CVT_PS_RR : InstrItinClass;
|
|
def IIC_SSE_CVT_PS_RM : InstrItinClass;
|
|
def IIC_SSE_CVT_Scalar_RR : InstrItinClass;
|
|
def IIC_SSE_CVT_Scalar_RM : InstrItinClass;
|
|
def IIC_SSE_CVT_SS2SI32_RM : InstrItinClass;
|
|
def IIC_SSE_CVT_SS2SI32_RR : InstrItinClass;
|
|
def IIC_SSE_CVT_SS2SI64_RM : InstrItinClass;
|
|
def IIC_SSE_CVT_SS2SI64_RR : InstrItinClass;
|
|
def IIC_SSE_CVT_SD2SI_RM : InstrItinClass;
|
|
def IIC_SSE_CVT_SD2SI_RR : InstrItinClass;
|
|
|
|
def IIC_AVX_ZERO : InstrItinClass;
|
|
|
|
// MMX
|
|
def IIC_MMX_MOV_MM_RM : InstrItinClass;
|
|
def IIC_MMX_MOV_REG_MM : InstrItinClass;
|
|
def IIC_MMX_MOVQ_RM : InstrItinClass;
|
|
def IIC_MMX_MOVQ_RR : InstrItinClass;
|
|
|
|
def IIC_MMX_ALU_RM : InstrItinClass;
|
|
def IIC_MMX_ALU_RR : InstrItinClass;
|
|
def IIC_MMX_ALUQ_RM : InstrItinClass;
|
|
def IIC_MMX_ALUQ_RR : InstrItinClass;
|
|
def IIC_MMX_PHADDSUBW_RM : InstrItinClass;
|
|
def IIC_MMX_PHADDSUBW_RR : InstrItinClass;
|
|
def IIC_MMX_PHADDSUBD_RM : InstrItinClass;
|
|
def IIC_MMX_PHADDSUBD_RR : InstrItinClass;
|
|
def IIC_MMX_PMUL : InstrItinClass;
|
|
def IIC_MMX_MISC_FUNC_MEM : InstrItinClass;
|
|
def IIC_MMX_MISC_FUNC_REG : InstrItinClass;
|
|
def IIC_MMX_PSADBW : InstrItinClass;
|
|
def IIC_MMX_SHIFT_RI : InstrItinClass;
|
|
def IIC_MMX_SHIFT_RM : InstrItinClass;
|
|
def IIC_MMX_SHIFT_RR : InstrItinClass;
|
|
def IIC_MMX_UNPCK_H_RM : InstrItinClass;
|
|
def IIC_MMX_UNPCK_H_RR : InstrItinClass;
|
|
def IIC_MMX_UNPCK_L : InstrItinClass;
|
|
def IIC_MMX_PCK_RM : InstrItinClass;
|
|
def IIC_MMX_PCK_RR : InstrItinClass;
|
|
def IIC_MMX_PSHUF : InstrItinClass;
|
|
def IIC_MMX_PEXTR : InstrItinClass;
|
|
def IIC_MMX_PINSRW : InstrItinClass;
|
|
def IIC_MMX_MASKMOV : InstrItinClass;
|
|
def IIC_MMX_MOVMSK : InstrItinClass;
|
|
def IIC_MMX_CVT_PD_RR : InstrItinClass;
|
|
def IIC_MMX_CVT_PD_RM : InstrItinClass;
|
|
def IIC_MMX_CVT_PS_RR : InstrItinClass;
|
|
def IIC_MMX_CVT_PS_RM : InstrItinClass;
|
|
|
|
def IIC_3DNOW_FALU_RM : InstrItinClass;
|
|
def IIC_3DNOW_FALU_RR : InstrItinClass;
|
|
def IIC_3DNOW_FCVT_F2I_RM : InstrItinClass;
|
|
def IIC_3DNOW_FCVT_F2I_RR : InstrItinClass;
|
|
def IIC_3DNOW_FCVT_I2F_RM : InstrItinClass;
|
|
def IIC_3DNOW_FCVT_I2F_RR : InstrItinClass;
|
|
def IIC_3DNOW_MISC_FUNC_REG : InstrItinClass;
|
|
def IIC_3DNOW_MISC_FUNC_MEM : InstrItinClass;
|
|
|
|
def IIC_CMPX_LOCK : InstrItinClass;
|
|
def IIC_CMPX_LOCK_8 : InstrItinClass;
|
|
def IIC_CMPX_LOCK_8B : InstrItinClass;
|
|
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;
|
|
def IIC_INT3 : InstrItinClass;
|
|
def IIC_INVD : InstrItinClass;
|
|
def IIC_INVLPG : InstrItinClass;
|
|
def IIC_INVPCID : InstrItinClass;
|
|
def IIC_IRET : InstrItinClass;
|
|
def IIC_HLT : InstrItinClass;
|
|
def IIC_LXS : InstrItinClass;
|
|
def IIC_LTR : InstrItinClass;
|
|
def IIC_MPX : InstrItinClass;
|
|
def IIC_PKU : InstrItinClass;
|
|
def IIC_PTWRITE : InstrItinClass;
|
|
def IIC_RDPID : InstrItinClass;
|
|
def IIC_RDRAND : InstrItinClass;
|
|
def IIC_RDSEED : InstrItinClass;
|
|
def IIC_RDTSC : InstrItinClass;
|
|
def IIC_RDTSCP : InstrItinClass;
|
|
def IIC_RSM : InstrItinClass;
|
|
def IIC_SIDT : InstrItinClass;
|
|
def IIC_SGDT : InstrItinClass;
|
|
def IIC_SLDT : InstrItinClass;
|
|
def IIC_SMAP : InstrItinClass;
|
|
def IIC_SMX : InstrItinClass;
|
|
def IIC_STR : InstrItinClass;
|
|
def IIC_SKINIT : InstrItinClass;
|
|
def IIC_SVM : InstrItinClass;
|
|
def IIC_VMX : InstrItinClass;
|
|
def IIC_CLGI : InstrItinClass;
|
|
def IIC_STGI : InstrItinClass;
|
|
def IIC_SWAPGS : InstrItinClass;
|
|
def IIC_SYSCALL : InstrItinClass;
|
|
def IIC_SYS_ENTER_EXIT : InstrItinClass;
|
|
def IIC_IN_RR : InstrItinClass;
|
|
def IIC_IN_RI : InstrItinClass;
|
|
def IIC_OUT_RR : InstrItinClass;
|
|
def IIC_OUT_IR : InstrItinClass;
|
|
def IIC_INS : InstrItinClass;
|
|
def IIC_LWP : InstrItinClass;
|
|
def IIC_MOV_REG_DR : InstrItinClass;
|
|
def IIC_MOV_DR_REG : InstrItinClass;
|
|
def IIC_MOV_REG_CR : InstrItinClass;
|
|
def IIC_MOV_CR_REG : InstrItinClass;
|
|
def IIC_MOV_REG_SR : InstrItinClass;
|
|
def IIC_MOV_MEM_SR : InstrItinClass;
|
|
def IIC_MOV_SR_REG : InstrItinClass;
|
|
def IIC_MOV_SR_MEM : InstrItinClass;
|
|
def IIC_LAR_RM : InstrItinClass;
|
|
def IIC_LAR_RR : InstrItinClass;
|
|
def IIC_LSL_RM : InstrItinClass;
|
|
def IIC_LSL_RR : InstrItinClass;
|
|
def IIC_LGDT : InstrItinClass;
|
|
def IIC_LIDT : InstrItinClass;
|
|
def IIC_LLDT_REG : InstrItinClass;
|
|
def IIC_LLDT_MEM : InstrItinClass;
|
|
def IIC_PUSH_CS : InstrItinClass;
|
|
def IIC_PUSH_SR : InstrItinClass;
|
|
def IIC_POP_SR : InstrItinClass;
|
|
def IIC_POP_SR_SS : InstrItinClass;
|
|
def IIC_SEGMENT_BASE_R : InstrItinClass;
|
|
def IIC_SEGMENT_BASE_W : InstrItinClass;
|
|
def IIC_VERR : InstrItinClass;
|
|
def IIC_VERW_REG : InstrItinClass;
|
|
def IIC_VERW_MEM : InstrItinClass;
|
|
def IIC_WRMSR : InstrItinClass;
|
|
def IIC_RDMSR : InstrItinClass;
|
|
def IIC_RDPMC : InstrItinClass;
|
|
def IIC_SMSW : InstrItinClass;
|
|
def IIC_LMSW_REG : InstrItinClass;
|
|
def IIC_LMSW_MEM : InstrItinClass;
|
|
def IIC_ENTER : InstrItinClass;
|
|
def IIC_LEAVE : InstrItinClass;
|
|
def IIC_POP_MEM : InstrItinClass;
|
|
def IIC_POP_REG16 : InstrItinClass;
|
|
def IIC_POP_REG : InstrItinClass;
|
|
def IIC_POP_F : InstrItinClass;
|
|
def IIC_POP_FD : InstrItinClass;
|
|
def IIC_POP_A : InstrItinClass;
|
|
def IIC_PUSH_IMM : InstrItinClass;
|
|
def IIC_PUSH_MEM : InstrItinClass;
|
|
def IIC_PUSH_REG : InstrItinClass;
|
|
def IIC_PUSH_F : InstrItinClass;
|
|
def IIC_PUSH_A : InstrItinClass;
|
|
def IIC_BSWAP : InstrItinClass;
|
|
def IIC_BIT_SCAN_MEM : InstrItinClass;
|
|
def IIC_BIT_SCAN_REG : InstrItinClass;
|
|
def IIC_LZCNT_RR : InstrItinClass;
|
|
def IIC_LZCNT_RM : InstrItinClass;
|
|
def IIC_TZCNT_RR : InstrItinClass;
|
|
def IIC_TZCNT_RM : InstrItinClass;
|
|
def IIC_MOVS : InstrItinClass;
|
|
def IIC_STOS : InstrItinClass;
|
|
def IIC_SCAS : InstrItinClass;
|
|
def IIC_CMPS : InstrItinClass;
|
|
def IIC_MOV : InstrItinClass;
|
|
def IIC_MOV_MEM : InstrItinClass;
|
|
def IIC_AHF : InstrItinClass;
|
|
def IIC_BT_MI : InstrItinClass;
|
|
def IIC_BT_MR : InstrItinClass;
|
|
def IIC_BT_RI : InstrItinClass;
|
|
def IIC_BT_RR : InstrItinClass;
|
|
def IIC_BTX_MI : InstrItinClass;
|
|
def IIC_BTX_MR : InstrItinClass;
|
|
def IIC_BTX_RI : InstrItinClass;
|
|
def IIC_BTX_RR : InstrItinClass;
|
|
def IIC_XCHG_REG : InstrItinClass;
|
|
def IIC_XCHG_MEM : InstrItinClass;
|
|
def IIC_XADD_REG : InstrItinClass;
|
|
def IIC_XADD_MEM : InstrItinClass;
|
|
def IIC_CMPXCHG_MEM : InstrItinClass;
|
|
def IIC_CMPXCHG_REG : InstrItinClass;
|
|
def IIC_CMPXCHG_MEM8 : InstrItinClass;
|
|
def IIC_CMPXCHG_REG8 : InstrItinClass;
|
|
def IIC_CMPXCHG_8B : InstrItinClass;
|
|
def IIC_CMPXCHG_16B : InstrItinClass;
|
|
def IIC_LODS : InstrItinClass;
|
|
def IIC_OUTS : InstrItinClass;
|
|
def IIC_CLC : InstrItinClass;
|
|
def IIC_CLD : InstrItinClass;
|
|
def IIC_CLI : InstrItinClass;
|
|
def IIC_CMC : InstrItinClass;
|
|
def IIC_CLTS : InstrItinClass;
|
|
def IIC_STC : InstrItinClass;
|
|
def IIC_STI : InstrItinClass;
|
|
def IIC_STD : InstrItinClass;
|
|
def IIC_XLAT : InstrItinClass;
|
|
def IIC_AAA : InstrItinClass;
|
|
def IIC_AAD : InstrItinClass;
|
|
def IIC_AAM : InstrItinClass;
|
|
def IIC_AAS : InstrItinClass;
|
|
def IIC_DAA : InstrItinClass;
|
|
def IIC_DAS : InstrItinClass;
|
|
def IIC_BOUND : InstrItinClass;
|
|
def IIC_ARPL_REG : InstrItinClass;
|
|
def IIC_ARPL_MEM : InstrItinClass;
|
|
def IIC_MOVBE : InstrItinClass;
|
|
def IIC_AES : InstrItinClass;
|
|
def IIC_BLEND_MEM : InstrItinClass;
|
|
def IIC_BLEND_NOMEM : InstrItinClass;
|
|
def IIC_CBW : InstrItinClass;
|
|
def IIC_CRC32_REG : InstrItinClass;
|
|
def IIC_CRC32_MEM : InstrItinClass;
|
|
def IIC_SSE_DPPD_RR : InstrItinClass;
|
|
def IIC_SSE_DPPD_RM : InstrItinClass;
|
|
def IIC_SSE_DPPS_RR : InstrItinClass;
|
|
def IIC_SSE_DPPS_RM : InstrItinClass;
|
|
def IIC_MMX_EMMS : InstrItinClass;
|
|
def IIC_SSE_EXTRACTPS_RR : InstrItinClass;
|
|
def IIC_SSE_EXTRACTPS_RM : InstrItinClass;
|
|
def IIC_SSE_INSERTPS_RR : InstrItinClass;
|
|
def IIC_SSE_INSERTPS_RM : InstrItinClass;
|
|
def IIC_SSE_MPSADBW_RR : InstrItinClass;
|
|
def IIC_SSE_MPSADBW_RM : InstrItinClass;
|
|
def IIC_SSE_PMULLD_RR : InstrItinClass;
|
|
def IIC_SSE_PMULLD_RM : InstrItinClass;
|
|
def IIC_SSE_ROUNDPS_REG : InstrItinClass;
|
|
def IIC_SSE_ROUNDPS_MEM : InstrItinClass;
|
|
def IIC_SSE_ROUNDPD_REG : InstrItinClass;
|
|
def IIC_SSE_ROUNDPD_MEM : InstrItinClass;
|
|
def IIC_SSE_POPCNT_RR : InstrItinClass;
|
|
def IIC_SSE_POPCNT_RM : InstrItinClass;
|
|
def IIC_SSE_PCLMULQDQ_RR : InstrItinClass;
|
|
def IIC_SSE_PCLMULQDQ_RM : InstrItinClass;
|
|
|
|
def IIC_NOP : InstrItinClass;
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Processor instruction itineraries.
|
|
|
|
// IssueWidth is analogous to the number of decode units. Core and its
|
|
// descendents, including Nehalem and SandyBridge have 4 decoders.
|
|
// Resources beyond the decoder operate on micro-ops and are bufferred
|
|
// so adjacent micro-ops don't directly compete.
|
|
//
|
|
// MicroOpBufferSize > 1 indicates that RAW dependencies can be
|
|
// decoded in the same cycle. The value 32 is a reasonably arbitrary
|
|
// number of in-flight instructions.
|
|
//
|
|
// HighLatency=10 is optimistic. X86InstrInfo::isHighLatencyDef
|
|
// indicates high latency opcodes. Alternatively, InstrItinData
|
|
// entries may be included here to define specific operand
|
|
// latencies. Since these latencies are not used for pipeline hazards,
|
|
// they do not need to be exact.
|
|
//
|
|
// The GenericX86Model contains no instruction itineraries
|
|
// and disables PostRAScheduler.
|
|
class GenericX86Model : SchedMachineModel {
|
|
let IssueWidth = 4;
|
|
let MicroOpBufferSize = 32;
|
|
let LoadLatency = 4;
|
|
let HighLatency = 10;
|
|
let PostRAScheduler = 0;
|
|
let CompleteModel = 0;
|
|
}
|
|
|
|
def GenericModel : GenericX86Model;
|
|
|
|
// Define a model with the PostRAScheduler enabled.
|
|
def GenericPostRAModel : GenericX86Model {
|
|
let PostRAScheduler = 1;
|
|
}
|
|
|