1*9880d681SAndroid Build Coastguard Worker//===-- X86Schedule.td - X86 Scheduling Definitions --------*- tablegen -*-===// 2*9880d681SAndroid Build Coastguard Worker// 3*9880d681SAndroid Build Coastguard Worker// The LLVM Compiler Infrastructure 4*9880d681SAndroid Build Coastguard Worker// 5*9880d681SAndroid Build Coastguard Worker// This file is distributed under the University of Illinois Open Source 6*9880d681SAndroid Build Coastguard Worker// License. See LICENSE.TXT for details. 7*9880d681SAndroid Build Coastguard Worker// 8*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===// 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker// InstrSchedModel annotations for out-of-order CPUs. 11*9880d681SAndroid Build Coastguard Worker// 12*9880d681SAndroid Build Coastguard Worker// These annotations are independent of the itinerary classes defined below. 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker// Instructions with folded loads need to read the memory operand immediately, 15*9880d681SAndroid Build Coastguard Worker// but other register operands don't have to be read until the load is ready. 16*9880d681SAndroid Build Coastguard Worker// These operands are marked with ReadAfterLd. 17*9880d681SAndroid Build Coastguard Workerdef ReadAfterLd : SchedRead; 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker// Instructions with both a load and a store folded are modeled as a folded 20*9880d681SAndroid Build Coastguard Worker// load + WriteRMW. 21*9880d681SAndroid Build Coastguard Workerdef WriteRMW : SchedWrite; 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker// Most instructions can fold loads, so almost every SchedWrite comes in two 24*9880d681SAndroid Build Coastguard Worker// variants: With and without a folded load. 25*9880d681SAndroid Build Coastguard Worker// An X86FoldableSchedWrite holds a reference to the corresponding SchedWrite 26*9880d681SAndroid Build Coastguard Worker// with a folded load. 27*9880d681SAndroid Build Coastguard Workerclass X86FoldableSchedWrite : SchedWrite { 28*9880d681SAndroid Build Coastguard Worker // The SchedWrite to use when a load is folded into the instruction. 29*9880d681SAndroid Build Coastguard Worker SchedWrite Folded; 30*9880d681SAndroid Build Coastguard Worker} 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Worker// Multiclass that produces a linked pair of SchedWrites. 33*9880d681SAndroid Build Coastguard Workermulticlass X86SchedWritePair { 34*9880d681SAndroid Build Coastguard Worker // Register-Memory operation. 35*9880d681SAndroid Build Coastguard Worker def Ld : SchedWrite; 36*9880d681SAndroid Build Coastguard Worker // Register-Register operation. 37*9880d681SAndroid Build Coastguard Worker def NAME : X86FoldableSchedWrite { 38*9880d681SAndroid Build Coastguard Worker let Folded = !cast<SchedWrite>(NAME#"Ld"); 39*9880d681SAndroid Build Coastguard Worker } 40*9880d681SAndroid Build Coastguard Worker} 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Worker// Arithmetic. 43*9880d681SAndroid Build Coastguard Workerdefm WriteALU : X86SchedWritePair; // Simple integer ALU op. 44*9880d681SAndroid Build Coastguard Workerdefm WriteIMul : X86SchedWritePair; // Integer multiplication. 45*9880d681SAndroid Build Coastguard Workerdef WriteIMulH : SchedWrite; // Integer multiplication, high part. 46*9880d681SAndroid Build Coastguard Workerdefm WriteIDiv : X86SchedWritePair; // Integer division. 47*9880d681SAndroid Build Coastguard Workerdef WriteLEA : SchedWrite; // LEA instructions can't fold loads. 48*9880d681SAndroid Build Coastguard Worker 49*9880d681SAndroid Build Coastguard Worker// Integer shifts and rotates. 50*9880d681SAndroid Build Coastguard Workerdefm WriteShift : X86SchedWritePair; 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Worker// Loads, stores, and moves, not folded with other operations. 53*9880d681SAndroid Build Coastguard Workerdef WriteLoad : SchedWrite; 54*9880d681SAndroid Build Coastguard Workerdef WriteStore : SchedWrite; 55*9880d681SAndroid Build Coastguard Workerdef WriteMove : SchedWrite; 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker// Idioms that clear a register, like xorps %xmm0, %xmm0. 58*9880d681SAndroid Build Coastguard Worker// These can often bypass execution ports completely. 59*9880d681SAndroid Build Coastguard Workerdef WriteZero : SchedWrite; 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Worker// Branches don't produce values, so they have no latency, but they still 62*9880d681SAndroid Build Coastguard Worker// consume resources. Indirect branches can fold loads. 63*9880d681SAndroid Build Coastguard Workerdefm WriteJump : X86SchedWritePair; 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Worker// Floating point. This covers both scalar and vector operations. 66*9880d681SAndroid Build Coastguard Workerdefm WriteFAdd : X86SchedWritePair; // Floating point add/sub/compare. 67*9880d681SAndroid Build Coastguard Workerdefm WriteFMul : X86SchedWritePair; // Floating point multiplication. 68*9880d681SAndroid Build Coastguard Workerdefm WriteFDiv : X86SchedWritePair; // Floating point division. 69*9880d681SAndroid Build Coastguard Workerdefm WriteFSqrt : X86SchedWritePair; // Floating point square root. 70*9880d681SAndroid Build Coastguard Workerdefm WriteFRcp : X86SchedWritePair; // Floating point reciprocal estimate. 71*9880d681SAndroid Build Coastguard Workerdefm WriteFRsqrt : X86SchedWritePair; // Floating point reciprocal square root estimate. 72*9880d681SAndroid Build Coastguard Workerdefm WriteFMA : X86SchedWritePair; // Fused Multiply Add. 73*9880d681SAndroid Build Coastguard Workerdefm WriteFShuffle : X86SchedWritePair; // Floating point vector shuffles. 74*9880d681SAndroid Build Coastguard Workerdefm WriteFBlend : X86SchedWritePair; // Floating point vector blends. 75*9880d681SAndroid Build Coastguard Workerdefm WriteFVarBlend : X86SchedWritePair; // Fp vector variable blends. 76*9880d681SAndroid Build Coastguard Worker 77*9880d681SAndroid Build Coastguard Worker// FMA Scheduling helper class. 78*9880d681SAndroid Build Coastguard Workerclass FMASC { X86FoldableSchedWrite Sched = WriteFAdd; } 79*9880d681SAndroid Build Coastguard Worker 80*9880d681SAndroid Build Coastguard Worker// Vector integer operations. 81*9880d681SAndroid Build Coastguard Workerdefm WriteVecALU : X86SchedWritePair; // Vector integer ALU op, no logicals. 82*9880d681SAndroid Build Coastguard Workerdefm WriteVecShift : X86SchedWritePair; // Vector integer shifts. 83*9880d681SAndroid Build Coastguard Workerdefm WriteVecIMul : X86SchedWritePair; // Vector integer multiply. 84*9880d681SAndroid Build Coastguard Workerdefm WriteShuffle : X86SchedWritePair; // Vector shuffles. 85*9880d681SAndroid Build Coastguard Workerdefm WriteBlend : X86SchedWritePair; // Vector blends. 86*9880d681SAndroid Build Coastguard Workerdefm WriteVarBlend : X86SchedWritePair; // Vector variable blends. 87*9880d681SAndroid Build Coastguard Workerdefm WriteMPSAD : X86SchedWritePair; // Vector MPSAD. 88*9880d681SAndroid Build Coastguard Worker 89*9880d681SAndroid Build Coastguard Worker// Vector bitwise operations. 90*9880d681SAndroid Build Coastguard Worker// These are often used on both floating point and integer vectors. 91*9880d681SAndroid Build Coastguard Workerdefm WriteVecLogic : X86SchedWritePair; // Vector and/or/xor. 92*9880d681SAndroid Build Coastguard Worker 93*9880d681SAndroid Build Coastguard Worker// Conversion between integer and float. 94*9880d681SAndroid Build Coastguard Workerdefm WriteCvtF2I : X86SchedWritePair; // Float -> Integer. 95*9880d681SAndroid Build Coastguard Workerdefm WriteCvtI2F : X86SchedWritePair; // Integer -> Float. 96*9880d681SAndroid Build Coastguard Workerdefm WriteCvtF2F : X86SchedWritePair; // Float -> Float size conversion. 97*9880d681SAndroid Build Coastguard Worker 98*9880d681SAndroid Build Coastguard Worker// Strings instructions. 99*9880d681SAndroid Build Coastguard Worker// Packed Compare Implicit Length Strings, Return Mask 100*9880d681SAndroid Build Coastguard Workerdefm WritePCmpIStrM : X86SchedWritePair; 101*9880d681SAndroid Build Coastguard Worker// Packed Compare Explicit Length Strings, Return Mask 102*9880d681SAndroid Build Coastguard Workerdefm WritePCmpEStrM : X86SchedWritePair; 103*9880d681SAndroid Build Coastguard Worker// Packed Compare Implicit Length Strings, Return Index 104*9880d681SAndroid Build Coastguard Workerdefm WritePCmpIStrI : X86SchedWritePair; 105*9880d681SAndroid Build Coastguard Worker// Packed Compare Explicit Length Strings, Return Index 106*9880d681SAndroid Build Coastguard Workerdefm WritePCmpEStrI : X86SchedWritePair; 107*9880d681SAndroid Build Coastguard Worker 108*9880d681SAndroid Build Coastguard Worker// AES instructions. 109*9880d681SAndroid Build Coastguard Workerdefm WriteAESDecEnc : X86SchedWritePair; // Decryption, encryption. 110*9880d681SAndroid Build Coastguard Workerdefm WriteAESIMC : X86SchedWritePair; // InvMixColumn. 111*9880d681SAndroid Build Coastguard Workerdefm WriteAESKeyGen : X86SchedWritePair; // Key Generation. 112*9880d681SAndroid Build Coastguard Worker 113*9880d681SAndroid Build Coastguard Worker// Carry-less multiplication instructions. 114*9880d681SAndroid Build Coastguard Workerdefm WriteCLMul : X86SchedWritePair; 115*9880d681SAndroid Build Coastguard Worker 116*9880d681SAndroid Build Coastguard Worker// Catch-all for expensive system instructions. 117*9880d681SAndroid Build Coastguard Workerdef WriteSystem : SchedWrite; 118*9880d681SAndroid Build Coastguard Worker 119*9880d681SAndroid Build Coastguard Worker// AVX2. 120*9880d681SAndroid Build Coastguard Workerdefm WriteFShuffle256 : X86SchedWritePair; // Fp 256-bit width vector shuffles. 121*9880d681SAndroid Build Coastguard Workerdefm WriteShuffle256 : X86SchedWritePair; // 256-bit width vector shuffles. 122*9880d681SAndroid Build Coastguard Workerdefm WriteVarVecShift : X86SchedWritePair; // Variable vector shifts. 123*9880d681SAndroid Build Coastguard Worker 124*9880d681SAndroid Build Coastguard Worker// Old microcoded instructions that nobody use. 125*9880d681SAndroid Build Coastguard Workerdef WriteMicrocoded : SchedWrite; 126*9880d681SAndroid Build Coastguard Worker 127*9880d681SAndroid Build Coastguard Worker// Fence instructions. 128*9880d681SAndroid Build Coastguard Workerdef WriteFence : SchedWrite; 129*9880d681SAndroid Build Coastguard Worker 130*9880d681SAndroid Build Coastguard Worker// Nop, not very useful expect it provides a model for nops! 131*9880d681SAndroid Build Coastguard Workerdef WriteNop : SchedWrite; 132*9880d681SAndroid Build Coastguard Worker 133*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===// 134*9880d681SAndroid Build Coastguard Worker// Instruction Itinerary classes used for X86 135*9880d681SAndroid Build Coastguard Workerdef IIC_ALU_MEM : InstrItinClass; 136*9880d681SAndroid Build Coastguard Workerdef IIC_ALU_NONMEM : InstrItinClass; 137*9880d681SAndroid Build Coastguard Workerdef IIC_LEA : InstrItinClass; 138*9880d681SAndroid Build Coastguard Workerdef IIC_LEA_16 : InstrItinClass; 139*9880d681SAndroid Build Coastguard Workerdef IIC_MUL8 : InstrItinClass; 140*9880d681SAndroid Build Coastguard Workerdef IIC_MUL16_MEM : InstrItinClass; 141*9880d681SAndroid Build Coastguard Workerdef IIC_MUL16_REG : InstrItinClass; 142*9880d681SAndroid Build Coastguard Workerdef IIC_MUL32_MEM : InstrItinClass; 143*9880d681SAndroid Build Coastguard Workerdef IIC_MUL32_REG : InstrItinClass; 144*9880d681SAndroid Build Coastguard Workerdef IIC_MUL64 : InstrItinClass; 145*9880d681SAndroid Build Coastguard Worker// imul by al, ax, eax, tax 146*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL8 : InstrItinClass; 147*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_MEM : InstrItinClass; 148*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_REG : InstrItinClass; 149*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_MEM : InstrItinClass; 150*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_REG : InstrItinClass; 151*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64 : InstrItinClass; 152*9880d681SAndroid Build Coastguard Worker// imul reg by reg|mem 153*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RM : InstrItinClass; 154*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RR : InstrItinClass; 155*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RM : InstrItinClass; 156*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RR : InstrItinClass; 157*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RM : InstrItinClass; 158*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RR : InstrItinClass; 159*9880d681SAndroid Build Coastguard Worker// imul reg = reg/mem * imm 160*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RMI : InstrItinClass; 161*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL16_RRI : InstrItinClass; 162*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RMI : InstrItinClass; 163*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL32_RRI : InstrItinClass; 164*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RMI : InstrItinClass; 165*9880d681SAndroid Build Coastguard Workerdef IIC_IMUL64_RRI : InstrItinClass; 166*9880d681SAndroid Build Coastguard Worker// div 167*9880d681SAndroid Build Coastguard Workerdef IIC_DIV8_MEM : InstrItinClass; 168*9880d681SAndroid Build Coastguard Workerdef IIC_DIV8_REG : InstrItinClass; 169*9880d681SAndroid Build Coastguard Workerdef IIC_DIV16 : InstrItinClass; 170*9880d681SAndroid Build Coastguard Workerdef IIC_DIV32 : InstrItinClass; 171*9880d681SAndroid Build Coastguard Workerdef IIC_DIV64 : InstrItinClass; 172*9880d681SAndroid Build Coastguard Worker// idiv 173*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV8 : InstrItinClass; 174*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV16 : InstrItinClass; 175*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV32 : InstrItinClass; 176*9880d681SAndroid Build Coastguard Workerdef IIC_IDIV64 : InstrItinClass; 177*9880d681SAndroid Build Coastguard Worker// neg/not/inc/dec 178*9880d681SAndroid Build Coastguard Workerdef IIC_UNARY_REG : InstrItinClass; 179*9880d681SAndroid Build Coastguard Workerdef IIC_UNARY_MEM : InstrItinClass; 180*9880d681SAndroid Build Coastguard Worker// add/sub/and/or/xor/sbc/cmp/test 181*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_MEM : InstrItinClass; 182*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_NONMEM : InstrItinClass; 183*9880d681SAndroid Build Coastguard Worker// adc/sbc 184*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_CARRY_MEM : InstrItinClass; 185*9880d681SAndroid Build Coastguard Workerdef IIC_BIN_CARRY_NONMEM : InstrItinClass; 186*9880d681SAndroid Build Coastguard Worker// shift/rotate 187*9880d681SAndroid Build Coastguard Workerdef IIC_SR : InstrItinClass; 188*9880d681SAndroid Build Coastguard Worker// shift double 189*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_REG_IM : InstrItinClass; 190*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_REG_CL : InstrItinClass; 191*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_MEM_IM : InstrItinClass; 192*9880d681SAndroid Build Coastguard Workerdef IIC_SHD16_MEM_CL : InstrItinClass; 193*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_REG_IM : InstrItinClass; 194*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_REG_CL : InstrItinClass; 195*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_MEM_IM : InstrItinClass; 196*9880d681SAndroid Build Coastguard Workerdef IIC_SHD32_MEM_CL : InstrItinClass; 197*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_REG_IM : InstrItinClass; 198*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_REG_CL : InstrItinClass; 199*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_MEM_IM : InstrItinClass; 200*9880d681SAndroid Build Coastguard Workerdef IIC_SHD64_MEM_CL : InstrItinClass; 201*9880d681SAndroid Build Coastguard Worker// cmov 202*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV16_RM : InstrItinClass; 203*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV16_RR : InstrItinClass; 204*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV32_RM : InstrItinClass; 205*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV32_RR : InstrItinClass; 206*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV64_RM : InstrItinClass; 207*9880d681SAndroid Build Coastguard Workerdef IIC_CMOV64_RR : InstrItinClass; 208*9880d681SAndroid Build Coastguard Worker// set 209*9880d681SAndroid Build Coastguard Workerdef IIC_SET_R : InstrItinClass; 210*9880d681SAndroid Build Coastguard Workerdef IIC_SET_M : InstrItinClass; 211*9880d681SAndroid Build Coastguard Worker// jmp/jcc/jcxz 212*9880d681SAndroid Build Coastguard Workerdef IIC_Jcc : InstrItinClass; 213*9880d681SAndroid Build Coastguard Workerdef IIC_JCXZ : InstrItinClass; 214*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_REL : InstrItinClass; 215*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_REG : InstrItinClass; 216*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_MEM : InstrItinClass; 217*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_FAR_MEM : InstrItinClass; 218*9880d681SAndroid Build Coastguard Workerdef IIC_JMP_FAR_PTR : InstrItinClass; 219*9880d681SAndroid Build Coastguard Worker// loop 220*9880d681SAndroid Build Coastguard Workerdef IIC_LOOP : InstrItinClass; 221*9880d681SAndroid Build Coastguard Workerdef IIC_LOOPE : InstrItinClass; 222*9880d681SAndroid Build Coastguard Workerdef IIC_LOOPNE : InstrItinClass; 223*9880d681SAndroid Build Coastguard Worker// call 224*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_RI : InstrItinClass; 225*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_MEM : InstrItinClass; 226*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_FAR_MEM : InstrItinClass; 227*9880d681SAndroid Build Coastguard Workerdef IIC_CALL_FAR_PTR : InstrItinClass; 228*9880d681SAndroid Build Coastguard Worker// ret 229*9880d681SAndroid Build Coastguard Workerdef IIC_RET : InstrItinClass; 230*9880d681SAndroid Build Coastguard Workerdef IIC_RET_IMM : InstrItinClass; 231*9880d681SAndroid Build Coastguard Worker//sign extension movs 232*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX : InstrItinClass; 233*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R16_R8 : InstrItinClass; 234*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R16_M8 : InstrItinClass; 235*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R16_R16 : InstrItinClass; 236*9880d681SAndroid Build Coastguard Workerdef IIC_MOVSX_R32_R32 : InstrItinClass; 237*9880d681SAndroid Build Coastguard Worker//zero extension movs 238*9880d681SAndroid Build Coastguard Workerdef IIC_MOVZX : InstrItinClass; 239*9880d681SAndroid Build Coastguard Workerdef IIC_MOVZX_R16_R8 : InstrItinClass; 240*9880d681SAndroid Build Coastguard Workerdef IIC_MOVZX_R16_M8 : InstrItinClass; 241*9880d681SAndroid Build Coastguard Worker 242*9880d681SAndroid Build Coastguard Workerdef IIC_REP_MOVS : InstrItinClass; 243*9880d681SAndroid Build Coastguard Workerdef IIC_REP_STOS : InstrItinClass; 244*9880d681SAndroid Build Coastguard Worker 245*9880d681SAndroid Build Coastguard Worker// SSE scalar/parallel binary operations 246*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32S_RR : InstrItinClass; 247*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32S_RM : InstrItinClass; 248*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64S_RR : InstrItinClass; 249*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64S_RM : InstrItinClass; 250*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32S_RR : InstrItinClass; 251*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32S_RM : InstrItinClass; 252*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64S_RR : InstrItinClass; 253*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64S_RM : InstrItinClass; 254*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32S_RR : InstrItinClass; 255*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32S_RM : InstrItinClass; 256*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64S_RR : InstrItinClass; 257*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64S_RM : InstrItinClass; 258*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32P_RR : InstrItinClass; 259*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F32P_RM : InstrItinClass; 260*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64P_RR : InstrItinClass; 261*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ALU_F64P_RM : InstrItinClass; 262*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32P_RR : InstrItinClass; 263*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F32P_RM : InstrItinClass; 264*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64P_RR : InstrItinClass; 265*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MUL_F64P_RM : InstrItinClass; 266*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32P_RR : InstrItinClass; 267*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F32P_RM : InstrItinClass; 268*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64P_RR : InstrItinClass; 269*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DIV_F64P_RM : InstrItinClass; 270*9880d681SAndroid Build Coastguard Worker 271*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_COMIS_RR : InstrItinClass; 272*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_COMIS_RM : InstrItinClass; 273*9880d681SAndroid Build Coastguard Worker 274*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_HADDSUB_RR : InstrItinClass; 275*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_HADDSUB_RM : InstrItinClass; 276*9880d681SAndroid Build Coastguard Worker 277*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_BIT_P_RR : InstrItinClass; 278*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_BIT_P_RM : InstrItinClass; 279*9880d681SAndroid Build Coastguard Worker 280*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALU_P_RR : InstrItinClass; 281*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALU_P_RM : InstrItinClass; 282*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALUQ_P_RR : InstrItinClass; 283*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTALUQ_P_RM : InstrItinClass; 284*9880d681SAndroid Build Coastguard Worker 285*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTMUL_P_RR : InstrItinClass; 286*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTMUL_P_RM : InstrItinClass; 287*9880d681SAndroid Build Coastguard Worker 288*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSH_P_RR : InstrItinClass; 289*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSH_P_RM : InstrItinClass; 290*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSH_P_RI : InstrItinClass; 291*9880d681SAndroid Build Coastguard Worker 292*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INTSHDQ_P_RI : InstrItinClass; 293*9880d681SAndroid Build Coastguard Worker 294*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SHUFP : InstrItinClass; 295*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUF_RI : InstrItinClass; 296*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUF_MI : InstrItinClass; 297*9880d681SAndroid Build Coastguard Worker 298*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_UNPCK : InstrItinClass; 299*9880d681SAndroid Build Coastguard Worker 300*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVMSK : InstrItinClass; 301*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MASKMOV : InstrItinClass; 302*9880d681SAndroid Build Coastguard Worker 303*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PEXTRW : InstrItinClass; 304*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PINSRW : InstrItinClass; 305*9880d681SAndroid Build Coastguard Worker 306*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PABS_RR : InstrItinClass; 307*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PABS_RM : InstrItinClass; 308*9880d681SAndroid Build Coastguard Worker 309*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPS_RR : InstrItinClass; 310*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPS_RM : InstrItinClass; 311*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSS_RR : InstrItinClass; 312*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSS_RM : InstrItinClass; 313*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPD_RR : InstrItinClass; 314*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTPD_RM : InstrItinClass; 315*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSD_RR : InstrItinClass; 316*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SQRTSD_RM : InstrItinClass; 317*9880d681SAndroid Build Coastguard Worker 318*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTPS_RR : InstrItinClass; 319*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTPS_RM : InstrItinClass; 320*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTSS_RR : InstrItinClass; 321*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RSQRTSS_RM : InstrItinClass; 322*9880d681SAndroid Build Coastguard Worker 323*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPP_RR : InstrItinClass; 324*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPP_RM : InstrItinClass; 325*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPS_RR : InstrItinClass; 326*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_RCPS_RM : InstrItinClass; 327*9880d681SAndroid Build Coastguard Worker 328*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_S_RR : InstrItinClass; 329*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_S_RM : InstrItinClass; 330*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_S_MR : InstrItinClass; 331*9880d681SAndroid Build Coastguard Worker 332*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVA_P_RR : InstrItinClass; 333*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVA_P_RM : InstrItinClass; 334*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVA_P_MR : InstrItinClass; 335*9880d681SAndroid Build Coastguard Worker 336*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVU_P_RR : InstrItinClass; 337*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVU_P_RM : InstrItinClass; 338*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVU_P_MR : InstrItinClass; 339*9880d681SAndroid Build Coastguard Worker 340*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVDQ : InstrItinClass; 341*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVD_ToGP : InstrItinClass; 342*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVQ_RR : InstrItinClass; 343*9880d681SAndroid Build Coastguard Worker 344*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOV_LH : InstrItinClass; 345*9880d681SAndroid Build Coastguard Worker 346*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_LDDQU : InstrItinClass; 347*9880d681SAndroid Build Coastguard Worker 348*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MOVNT : InstrItinClass; 349*9880d681SAndroid Build Coastguard Worker 350*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBD_RR : InstrItinClass; 351*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBD_RM : InstrItinClass; 352*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBSW_RR : InstrItinClass; 353*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBSW_RM : InstrItinClass; 354*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBW_RR : InstrItinClass; 355*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PHADDSUBW_RM : InstrItinClass; 356*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUFB_RR : InstrItinClass; 357*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSHUFB_RM : InstrItinClass; 358*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSIGN_RR : InstrItinClass; 359*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PSIGN_RM : InstrItinClass; 360*9880d681SAndroid Build Coastguard Worker 361*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMADD : InstrItinClass; 362*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMULHRSW : InstrItinClass; 363*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PALIGNRR : InstrItinClass; 364*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PALIGNRM : InstrItinClass; 365*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MWAIT : InstrItinClass; 366*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MONITOR : InstrItinClass; 367*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MWAITX : InstrItinClass; 368*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MONITORX : InstrItinClass; 369*9880d681SAndroid Build Coastguard Worker 370*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PREFETCH : InstrItinClass; 371*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PAUSE : InstrItinClass; 372*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_LFENCE : InstrItinClass; 373*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MFENCE : InstrItinClass; 374*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_SFENCE : InstrItinClass; 375*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_LDMXCSR : InstrItinClass; 376*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_STMXCSR : InstrItinClass; 377*9880d681SAndroid Build Coastguard Worker 378*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PD_RR : InstrItinClass; 379*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PD_RM : InstrItinClass; 380*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PS_RR : InstrItinClass; 381*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PS_RM : InstrItinClass; 382*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PI2PS_RR : InstrItinClass; 383*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_PI2PS_RM : InstrItinClass; 384*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_Scalar_RR : InstrItinClass; 385*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_Scalar_RM : InstrItinClass; 386*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI32_RM : InstrItinClass; 387*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI32_RR : InstrItinClass; 388*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI64_RM : InstrItinClass; 389*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SS2SI64_RR : InstrItinClass; 390*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SD2SI_RM : InstrItinClass; 391*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_CVT_SD2SI_RR : InstrItinClass; 392*9880d681SAndroid Build Coastguard Worker 393*9880d681SAndroid Build Coastguard Worker// MMX 394*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOV_MM_RM : InstrItinClass; 395*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOV_REG_MM : InstrItinClass; 396*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOVQ_RM : InstrItinClass; 397*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MOVQ_RR : InstrItinClass; 398*9880d681SAndroid Build Coastguard Worker 399*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALU_RM : InstrItinClass; 400*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALU_RR : InstrItinClass; 401*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALUQ_RM : InstrItinClass; 402*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_ALUQ_RR : InstrItinClass; 403*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBW_RM : InstrItinClass; 404*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBW_RR : InstrItinClass; 405*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBD_RM : InstrItinClass; 406*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PHADDSUBD_RR : InstrItinClass; 407*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PMUL : InstrItinClass; 408*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MISC_FUNC_MEM : InstrItinClass; 409*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MISC_FUNC_REG : InstrItinClass; 410*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PSADBW : InstrItinClass; 411*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_SHIFT_RI : InstrItinClass; 412*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_SHIFT_RM : InstrItinClass; 413*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_SHIFT_RR : InstrItinClass; 414*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_UNPCK_H_RM : InstrItinClass; 415*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_UNPCK_H_RR : InstrItinClass; 416*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_UNPCK_L : InstrItinClass; 417*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PCK_RM : InstrItinClass; 418*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PCK_RR : InstrItinClass; 419*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PSHUF : InstrItinClass; 420*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PEXTR : InstrItinClass; 421*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_PINSRW : InstrItinClass; 422*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_MASKMOV : InstrItinClass; 423*9880d681SAndroid Build Coastguard Worker 424*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PD_RR : InstrItinClass; 425*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PD_RM : InstrItinClass; 426*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PS_RR : InstrItinClass; 427*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_CVT_PS_RM : InstrItinClass; 428*9880d681SAndroid Build Coastguard Worker 429*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK : InstrItinClass; 430*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK_8 : InstrItinClass; 431*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK_8B : InstrItinClass; 432*9880d681SAndroid Build Coastguard Workerdef IIC_CMPX_LOCK_16B : InstrItinClass; 433*9880d681SAndroid Build Coastguard Worker 434*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_LOCK_MEM : InstrItinClass; 435*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_LOCK_MEM8 : InstrItinClass; 436*9880d681SAndroid Build Coastguard Worker 437*9880d681SAndroid Build Coastguard Workerdef IIC_FILD : InstrItinClass; 438*9880d681SAndroid Build Coastguard Workerdef IIC_FLD : InstrItinClass; 439*9880d681SAndroid Build Coastguard Workerdef IIC_FLD80 : InstrItinClass; 440*9880d681SAndroid Build Coastguard Workerdef IIC_FST : InstrItinClass; 441*9880d681SAndroid Build Coastguard Workerdef IIC_FST80 : InstrItinClass; 442*9880d681SAndroid Build Coastguard Workerdef IIC_FIST : InstrItinClass; 443*9880d681SAndroid Build Coastguard Workerdef IIC_FLDZ : InstrItinClass; 444*9880d681SAndroid Build Coastguard Workerdef IIC_FUCOM : InstrItinClass; 445*9880d681SAndroid Build Coastguard Workerdef IIC_FUCOMI : InstrItinClass; 446*9880d681SAndroid Build Coastguard Workerdef IIC_FCOMI : InstrItinClass; 447*9880d681SAndroid Build Coastguard Workerdef IIC_FNSTSW : InstrItinClass; 448*9880d681SAndroid Build Coastguard Workerdef IIC_FNSTCW : InstrItinClass; 449*9880d681SAndroid Build Coastguard Workerdef IIC_FLDCW : InstrItinClass; 450*9880d681SAndroid Build Coastguard Workerdef IIC_FNINIT : InstrItinClass; 451*9880d681SAndroid Build Coastguard Workerdef IIC_FFREE : InstrItinClass; 452*9880d681SAndroid Build Coastguard Workerdef IIC_FNCLEX : InstrItinClass; 453*9880d681SAndroid Build Coastguard Workerdef IIC_WAIT : InstrItinClass; 454*9880d681SAndroid Build Coastguard Workerdef IIC_FXAM : InstrItinClass; 455*9880d681SAndroid Build Coastguard Workerdef IIC_FNOP : InstrItinClass; 456*9880d681SAndroid Build Coastguard Workerdef IIC_FLDL : InstrItinClass; 457*9880d681SAndroid Build Coastguard Workerdef IIC_F2XM1 : InstrItinClass; 458*9880d681SAndroid Build Coastguard Workerdef IIC_FYL2X : InstrItinClass; 459*9880d681SAndroid Build Coastguard Workerdef IIC_FPTAN : InstrItinClass; 460*9880d681SAndroid Build Coastguard Workerdef IIC_FPATAN : InstrItinClass; 461*9880d681SAndroid Build Coastguard Workerdef IIC_FXTRACT : InstrItinClass; 462*9880d681SAndroid Build Coastguard Workerdef IIC_FPREM1 : InstrItinClass; 463*9880d681SAndroid Build Coastguard Workerdef IIC_FPSTP : InstrItinClass; 464*9880d681SAndroid Build Coastguard Workerdef IIC_FPREM : InstrItinClass; 465*9880d681SAndroid Build Coastguard Workerdef IIC_FYL2XP1 : InstrItinClass; 466*9880d681SAndroid Build Coastguard Workerdef IIC_FSINCOS : InstrItinClass; 467*9880d681SAndroid Build Coastguard Workerdef IIC_FRNDINT : InstrItinClass; 468*9880d681SAndroid Build Coastguard Workerdef IIC_FSCALE : InstrItinClass; 469*9880d681SAndroid Build Coastguard Workerdef IIC_FCOMPP : InstrItinClass; 470*9880d681SAndroid Build Coastguard Workerdef IIC_FXSAVE : InstrItinClass; 471*9880d681SAndroid Build Coastguard Workerdef IIC_FXRSTOR : InstrItinClass; 472*9880d681SAndroid Build Coastguard Worker 473*9880d681SAndroid Build Coastguard Workerdef IIC_FXCH : InstrItinClass; 474*9880d681SAndroid Build Coastguard Worker 475*9880d681SAndroid Build Coastguard Worker// System instructions 476*9880d681SAndroid Build Coastguard Workerdef IIC_CPUID : InstrItinClass; 477*9880d681SAndroid Build Coastguard Workerdef IIC_INT : InstrItinClass; 478*9880d681SAndroid Build Coastguard Workerdef IIC_INT3 : InstrItinClass; 479*9880d681SAndroid Build Coastguard Workerdef IIC_INVD : InstrItinClass; 480*9880d681SAndroid Build Coastguard Workerdef IIC_INVLPG : InstrItinClass; 481*9880d681SAndroid Build Coastguard Workerdef IIC_IRET : InstrItinClass; 482*9880d681SAndroid Build Coastguard Workerdef IIC_HLT : InstrItinClass; 483*9880d681SAndroid Build Coastguard Workerdef IIC_LXS : InstrItinClass; 484*9880d681SAndroid Build Coastguard Workerdef IIC_LTR : InstrItinClass; 485*9880d681SAndroid Build Coastguard Workerdef IIC_RDTSC : InstrItinClass; 486*9880d681SAndroid Build Coastguard Workerdef IIC_RSM : InstrItinClass; 487*9880d681SAndroid Build Coastguard Workerdef IIC_SIDT : InstrItinClass; 488*9880d681SAndroid Build Coastguard Workerdef IIC_SGDT : InstrItinClass; 489*9880d681SAndroid Build Coastguard Workerdef IIC_SLDT : InstrItinClass; 490*9880d681SAndroid Build Coastguard Workerdef IIC_STR : InstrItinClass; 491*9880d681SAndroid Build Coastguard Workerdef IIC_SWAPGS : InstrItinClass; 492*9880d681SAndroid Build Coastguard Workerdef IIC_SYSCALL : InstrItinClass; 493*9880d681SAndroid Build Coastguard Workerdef IIC_SYS_ENTER_EXIT : InstrItinClass; 494*9880d681SAndroid Build Coastguard Workerdef IIC_IN_RR : InstrItinClass; 495*9880d681SAndroid Build Coastguard Workerdef IIC_IN_RI : InstrItinClass; 496*9880d681SAndroid Build Coastguard Workerdef IIC_OUT_RR : InstrItinClass; 497*9880d681SAndroid Build Coastguard Workerdef IIC_OUT_IR : InstrItinClass; 498*9880d681SAndroid Build Coastguard Workerdef IIC_INS : InstrItinClass; 499*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_REG_DR : InstrItinClass; 500*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_DR_REG : InstrItinClass; 501*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_REG_CR : InstrItinClass; 502*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_CR_REG : InstrItinClass; 503*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_REG_SR : InstrItinClass; 504*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_MEM_SR : InstrItinClass; 505*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_SR_REG : InstrItinClass; 506*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_SR_MEM : InstrItinClass; 507*9880d681SAndroid Build Coastguard Workerdef IIC_LAR_RM : InstrItinClass; 508*9880d681SAndroid Build Coastguard Workerdef IIC_LAR_RR : InstrItinClass; 509*9880d681SAndroid Build Coastguard Workerdef IIC_LSL_RM : InstrItinClass; 510*9880d681SAndroid Build Coastguard Workerdef IIC_LSL_RR : InstrItinClass; 511*9880d681SAndroid Build Coastguard Workerdef IIC_LGDT : InstrItinClass; 512*9880d681SAndroid Build Coastguard Workerdef IIC_LIDT : InstrItinClass; 513*9880d681SAndroid Build Coastguard Workerdef IIC_LLDT_REG : InstrItinClass; 514*9880d681SAndroid Build Coastguard Workerdef IIC_LLDT_MEM : InstrItinClass; 515*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_CS : InstrItinClass; 516*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_SR : InstrItinClass; 517*9880d681SAndroid Build Coastguard Workerdef IIC_POP_SR : InstrItinClass; 518*9880d681SAndroid Build Coastguard Workerdef IIC_POP_SR_SS : InstrItinClass; 519*9880d681SAndroid Build Coastguard Workerdef IIC_VERR : InstrItinClass; 520*9880d681SAndroid Build Coastguard Workerdef IIC_VERW_REG : InstrItinClass; 521*9880d681SAndroid Build Coastguard Workerdef IIC_VERW_MEM : InstrItinClass; 522*9880d681SAndroid Build Coastguard Workerdef IIC_WRMSR : InstrItinClass; 523*9880d681SAndroid Build Coastguard Workerdef IIC_RDMSR : InstrItinClass; 524*9880d681SAndroid Build Coastguard Workerdef IIC_RDPMC : InstrItinClass; 525*9880d681SAndroid Build Coastguard Workerdef IIC_SMSW : InstrItinClass; 526*9880d681SAndroid Build Coastguard Workerdef IIC_LMSW_REG : InstrItinClass; 527*9880d681SAndroid Build Coastguard Workerdef IIC_LMSW_MEM : InstrItinClass; 528*9880d681SAndroid Build Coastguard Workerdef IIC_ENTER : InstrItinClass; 529*9880d681SAndroid Build Coastguard Workerdef IIC_LEAVE : InstrItinClass; 530*9880d681SAndroid Build Coastguard Workerdef IIC_POP_MEM : InstrItinClass; 531*9880d681SAndroid Build Coastguard Workerdef IIC_POP_REG16 : InstrItinClass; 532*9880d681SAndroid Build Coastguard Workerdef IIC_POP_REG : InstrItinClass; 533*9880d681SAndroid Build Coastguard Workerdef IIC_POP_F : InstrItinClass; 534*9880d681SAndroid Build Coastguard Workerdef IIC_POP_FD : InstrItinClass; 535*9880d681SAndroid Build Coastguard Workerdef IIC_POP_A : InstrItinClass; 536*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_IMM : InstrItinClass; 537*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_MEM : InstrItinClass; 538*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_REG : InstrItinClass; 539*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_F : InstrItinClass; 540*9880d681SAndroid Build Coastguard Workerdef IIC_PUSH_A : InstrItinClass; 541*9880d681SAndroid Build Coastguard Workerdef IIC_BSWAP : InstrItinClass; 542*9880d681SAndroid Build Coastguard Workerdef IIC_BIT_SCAN_MEM : InstrItinClass; 543*9880d681SAndroid Build Coastguard Workerdef IIC_BIT_SCAN_REG : InstrItinClass; 544*9880d681SAndroid Build Coastguard Workerdef IIC_MOVS : InstrItinClass; 545*9880d681SAndroid Build Coastguard Workerdef IIC_STOS : InstrItinClass; 546*9880d681SAndroid Build Coastguard Workerdef IIC_SCAS : InstrItinClass; 547*9880d681SAndroid Build Coastguard Workerdef IIC_CMPS : InstrItinClass; 548*9880d681SAndroid Build Coastguard Workerdef IIC_MOV : InstrItinClass; 549*9880d681SAndroid Build Coastguard Workerdef IIC_MOV_MEM : InstrItinClass; 550*9880d681SAndroid Build Coastguard Workerdef IIC_AHF : InstrItinClass; 551*9880d681SAndroid Build Coastguard Workerdef IIC_BT_MI : InstrItinClass; 552*9880d681SAndroid Build Coastguard Workerdef IIC_BT_MR : InstrItinClass; 553*9880d681SAndroid Build Coastguard Workerdef IIC_BT_RI : InstrItinClass; 554*9880d681SAndroid Build Coastguard Workerdef IIC_BT_RR : InstrItinClass; 555*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_MI : InstrItinClass; 556*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_MR : InstrItinClass; 557*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_RI : InstrItinClass; 558*9880d681SAndroid Build Coastguard Workerdef IIC_BTX_RR : InstrItinClass; 559*9880d681SAndroid Build Coastguard Workerdef IIC_XCHG_REG : InstrItinClass; 560*9880d681SAndroid Build Coastguard Workerdef IIC_XCHG_MEM : InstrItinClass; 561*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_REG : InstrItinClass; 562*9880d681SAndroid Build Coastguard Workerdef IIC_XADD_MEM : InstrItinClass; 563*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_MEM : InstrItinClass; 564*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_REG : InstrItinClass; 565*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_MEM8 : InstrItinClass; 566*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_REG8 : InstrItinClass; 567*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_8B : InstrItinClass; 568*9880d681SAndroid Build Coastguard Workerdef IIC_CMPXCHG_16B : InstrItinClass; 569*9880d681SAndroid Build Coastguard Workerdef IIC_LODS : InstrItinClass; 570*9880d681SAndroid Build Coastguard Workerdef IIC_OUTS : InstrItinClass; 571*9880d681SAndroid Build Coastguard Workerdef IIC_CLC : InstrItinClass; 572*9880d681SAndroid Build Coastguard Workerdef IIC_CLD : InstrItinClass; 573*9880d681SAndroid Build Coastguard Workerdef IIC_CLI : InstrItinClass; 574*9880d681SAndroid Build Coastguard Workerdef IIC_CMC : InstrItinClass; 575*9880d681SAndroid Build Coastguard Workerdef IIC_CLTS : InstrItinClass; 576*9880d681SAndroid Build Coastguard Workerdef IIC_STC : InstrItinClass; 577*9880d681SAndroid Build Coastguard Workerdef IIC_STI : InstrItinClass; 578*9880d681SAndroid Build Coastguard Workerdef IIC_STD : InstrItinClass; 579*9880d681SAndroid Build Coastguard Workerdef IIC_XLAT : InstrItinClass; 580*9880d681SAndroid Build Coastguard Workerdef IIC_AAA : InstrItinClass; 581*9880d681SAndroid Build Coastguard Workerdef IIC_AAD : InstrItinClass; 582*9880d681SAndroid Build Coastguard Workerdef IIC_AAM : InstrItinClass; 583*9880d681SAndroid Build Coastguard Workerdef IIC_AAS : InstrItinClass; 584*9880d681SAndroid Build Coastguard Workerdef IIC_DAA : InstrItinClass; 585*9880d681SAndroid Build Coastguard Workerdef IIC_DAS : InstrItinClass; 586*9880d681SAndroid Build Coastguard Workerdef IIC_BOUND : InstrItinClass; 587*9880d681SAndroid Build Coastguard Workerdef IIC_ARPL_REG : InstrItinClass; 588*9880d681SAndroid Build Coastguard Workerdef IIC_ARPL_MEM : InstrItinClass; 589*9880d681SAndroid Build Coastguard Workerdef IIC_MOVBE : InstrItinClass; 590*9880d681SAndroid Build Coastguard Workerdef IIC_AES : InstrItinClass; 591*9880d681SAndroid Build Coastguard Workerdef IIC_BLEND_MEM : InstrItinClass; 592*9880d681SAndroid Build Coastguard Workerdef IIC_BLEND_NOMEM : InstrItinClass; 593*9880d681SAndroid Build Coastguard Workerdef IIC_CBW : InstrItinClass; 594*9880d681SAndroid Build Coastguard Workerdef IIC_CRC32_REG : InstrItinClass; 595*9880d681SAndroid Build Coastguard Workerdef IIC_CRC32_MEM : InstrItinClass; 596*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPD_RR : InstrItinClass; 597*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPD_RM : InstrItinClass; 598*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPS_RR : InstrItinClass; 599*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_DPPS_RM : InstrItinClass; 600*9880d681SAndroid Build Coastguard Workerdef IIC_MMX_EMMS : InstrItinClass; 601*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_EXTRACTPS_RR : InstrItinClass; 602*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_EXTRACTPS_RM : InstrItinClass; 603*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INSERTPS_RR : InstrItinClass; 604*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_INSERTPS_RM : InstrItinClass; 605*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MPSADBW_RR : InstrItinClass; 606*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_MPSADBW_RM : InstrItinClass; 607*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMULLD_RR : InstrItinClass; 608*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PMULLD_RM : InstrItinClass; 609*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPS_REG : InstrItinClass; 610*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPS_MEM : InstrItinClass; 611*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPD_REG : InstrItinClass; 612*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_ROUNDPD_MEM : InstrItinClass; 613*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_POPCNT_RR : InstrItinClass; 614*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_POPCNT_RM : InstrItinClass; 615*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PCLMULQDQ_RR : InstrItinClass; 616*9880d681SAndroid Build Coastguard Workerdef IIC_SSE_PCLMULQDQ_RM : InstrItinClass; 617*9880d681SAndroid Build Coastguard Worker 618*9880d681SAndroid Build Coastguard Workerdef IIC_NOP : InstrItinClass; 619*9880d681SAndroid Build Coastguard Worker 620*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===// 621*9880d681SAndroid Build Coastguard Worker// Processor instruction itineraries. 622*9880d681SAndroid Build Coastguard Worker 623*9880d681SAndroid Build Coastguard Worker// IssueWidth is analogous to the number of decode units. Core and its 624*9880d681SAndroid Build Coastguard Worker// descendents, including Nehalem and SandyBridge have 4 decoders. 625*9880d681SAndroid Build Coastguard Worker// Resources beyond the decoder operate on micro-ops and are bufferred 626*9880d681SAndroid Build Coastguard Worker// so adjacent micro-ops don't directly compete. 627*9880d681SAndroid Build Coastguard Worker// 628*9880d681SAndroid Build Coastguard Worker// MicroOpBufferSize > 1 indicates that RAW dependencies can be 629*9880d681SAndroid Build Coastguard Worker// decoded in the same cycle. The value 32 is a reasonably arbitrary 630*9880d681SAndroid Build Coastguard Worker// number of in-flight instructions. 631*9880d681SAndroid Build Coastguard Worker// 632*9880d681SAndroid Build Coastguard Worker// HighLatency=10 is optimistic. X86InstrInfo::isHighLatencyDef 633*9880d681SAndroid Build Coastguard Worker// indicates high latency opcodes. Alternatively, InstrItinData 634*9880d681SAndroid Build Coastguard Worker// entries may be included here to define specific operand 635*9880d681SAndroid Build Coastguard Worker// latencies. Since these latencies are not used for pipeline hazards, 636*9880d681SAndroid Build Coastguard Worker// they do not need to be exact. 637*9880d681SAndroid Build Coastguard Worker// 638*9880d681SAndroid Build Coastguard Worker// The GenericX86Model contains no instruction itineraries 639*9880d681SAndroid Build Coastguard Worker// and disables PostRAScheduler. 640*9880d681SAndroid Build Coastguard Workerclass GenericX86Model : SchedMachineModel { 641*9880d681SAndroid Build Coastguard Worker let IssueWidth = 4; 642*9880d681SAndroid Build Coastguard Worker let MicroOpBufferSize = 32; 643*9880d681SAndroid Build Coastguard Worker let LoadLatency = 4; 644*9880d681SAndroid Build Coastguard Worker let HighLatency = 10; 645*9880d681SAndroid Build Coastguard Worker let PostRAScheduler = 0; 646*9880d681SAndroid Build Coastguard Worker let CompleteModel = 0; 647*9880d681SAndroid Build Coastguard Worker} 648*9880d681SAndroid Build Coastguard Worker 649*9880d681SAndroid Build Coastguard Workerdef GenericModel : GenericX86Model; 650*9880d681SAndroid Build Coastguard Worker 651*9880d681SAndroid Build Coastguard Worker// Define a model with the PostRAScheduler enabled. 652*9880d681SAndroid Build Coastguard Workerdef GenericPostRAModel : GenericX86Model { 653*9880d681SAndroid Build Coastguard Worker let PostRAScheduler = 1; 654*9880d681SAndroid Build Coastguard Worker} 655*9880d681SAndroid Build Coastguard Worker 656*9880d681SAndroid Build Coastguard Workerinclude "X86ScheduleAtom.td" 657*9880d681SAndroid Build Coastguard Workerinclude "X86SchedSandyBridge.td" 658*9880d681SAndroid Build Coastguard Workerinclude "X86SchedHaswell.td" 659*9880d681SAndroid Build Coastguard Workerinclude "X86ScheduleSLM.td" 660*9880d681SAndroid Build Coastguard Workerinclude "X86ScheduleBtVer2.td" 661*9880d681SAndroid Build Coastguard Worker 662