1//===- X86ScheduleAtom.td - X86 Atom Scheduling Definitions -*- tablegen -*-==// 2// 3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4// See https://llvm.org/LICENSE.txt for license information. 5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6// 7//===----------------------------------------------------------------------===// 8// 9// This file defines the schedule class data for the Intel Atom 10// in order (Saltwell-32nm/Bonnell-45nm) processors. 11// 12//===----------------------------------------------------------------------===// 13 14// 15// Scheduling information derived from the "Intel 64 and IA32 Architectures 16// Optimization Reference Manual", Chapter 13, Section 4. 17 18// Atom machine model. 19def AtomModel : SchedMachineModel { 20 let IssueWidth = 2; // Allows 2 instructions per scheduling group. 21 let MicroOpBufferSize = 0; // In-order execution, always hide latency. 22 let LoadLatency = 3; // Expected cycles, may be overriden. 23 let HighLatency = 30;// Expected, may be overriden. 24 25 // On the Atom, the throughput for taken branches is 2 cycles. For small 26 // simple loops, expand by a small factor to hide the backedge cost. 27 let LoopMicroOpBufferSize = 10; 28 let PostRAScheduler = 1; 29 let CompleteModel = 0; 30} 31 32let SchedModel = AtomModel in { 33 34// Functional Units 35def AtomPort0 : ProcResource<1>; // ALU: ALU0, shift/rotate, load/store 36 // SIMD/FP: SIMD ALU, Shuffle,SIMD/FP multiply, divide 37def AtomPort1 : ProcResource<1>; // ALU: ALU1, bit processing, jump, and LEA 38 // SIMD/FP: SIMD ALU, FP Adder 39 40// NOTE: This is for ops that can use EITHER port, not for ops that require BOTH ports. 41def AtomPort01 : ProcResGroup<[AtomPort0, AtomPort1]>; 42 43// Loads are 3 cycles, so ReadAfterLd registers needn't be available until 3 44// cycles after the memory operand. 45def : ReadAdvance<ReadAfterLd, 3>; 46def : ReadAdvance<ReadAfterVecLd, 3>; 47def : ReadAdvance<ReadAfterVecXLd, 3>; 48def : ReadAdvance<ReadAfterVecYLd, 3>; 49 50def : ReadAdvance<ReadInt2Fpu, 0>; 51 52// This multiclass defines the resource usage for variants with and without 53// folded loads. 54multiclass AtomWriteResPair<X86FoldableSchedWrite SchedRW, 55 list<ProcResourceKind> RRPorts, 56 list<ProcResourceKind> RMPorts, 57 int RRLat = 1, int RMLat = 1, 58 list<int> RRRes = [1], 59 list<int> RMRes = [1], 60 int RRUOps = 1, 61 int RMUOps = 1> { 62 // Register variant. 63 def : WriteRes<SchedRW, RRPorts> { 64 let Latency = RRLat; 65 let ReleaseAtCycles = RRRes; 66 let NumMicroOps = RRUOps; 67 } 68 69 // Memory variant. 70 def : WriteRes<SchedRW.Folded, RMPorts> { 71 let Latency = RMLat; 72 let ReleaseAtCycles = RMRes; 73 let NumMicroOps = RMUOps; 74 } 75} 76 77// A folded store needs a cycle on Port0 for the store data. 78def : WriteRes<WriteRMW, [AtomPort0]>; 79 80//////////////////////////////////////////////////////////////////////////////// 81// Arithmetic. 82//////////////////////////////////////////////////////////////////////////////// 83 84defm : AtomWriteResPair<WriteALU, [AtomPort01], [AtomPort0]>; 85defm : AtomWriteResPair<WriteADC, [AtomPort01], [AtomPort0]>; 86 87defm : AtomWriteResPair<WriteIMul8, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 7, 7, [7,7], [7,7], 3, 3>; 88defm : AtomWriteResPair<WriteIMul16, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 7, 8, [7,7], [8,8], 4, 5>; 89defm : AtomWriteResPair<WriteIMul16Imm, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [7,7], 2, 3>; 90defm : AtomWriteResPair<WriteIMul16Reg, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [7,7], 2, 3>; 91defm : AtomWriteResPair<WriteIMul32, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [7,7], 3, 4>; 92defm : AtomWriteResPair<WriteIMul32Imm, [AtomPort0], [AtomPort0], 5, 5, [5], [5]>; 93defm : AtomWriteResPair<WriteIMul32Reg, [AtomPort0], [AtomPort0], 5, 5, [5], [5]>; 94defm : AtomWriteResPair<WriteIMul64, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 12, 12, [12,12], [12,12], 8, 8>; 95defm : AtomWriteResPair<WriteIMul64Imm, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 14, 14, [14,14], [14,14], 7, 7>; 96defm : AtomWriteResPair<WriteIMul64Reg, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 12, 12, [12,12], [12,12], 6, 6>; 97defm : X86WriteResUnsupported<WriteIMulH>; 98defm : X86WriteResUnsupported<WriteIMulHLd>; 99defm : X86WriteResPairUnsupported<WriteMULX32>; 100defm : X86WriteResPairUnsupported<WriteMULX64>; 101 102defm : X86WriteRes<WriteXCHG, [AtomPort01], 2, [2], 1>; 103defm : X86WriteRes<WriteBSWAP32, [AtomPort0], 1, [1], 1>; 104defm : X86WriteRes<WriteBSWAP64, [AtomPort0], 1, [1], 1>; 105defm : AtomWriteResPair<WriteCMPXCHG, [AtomPort01], [AtomPort01], 15, 15, [15]>; 106defm : X86WriteRes<WriteCMPXCHGRMW, [AtomPort01, AtomPort0], 1, [1, 1], 1>; 107 108defm : AtomWriteResPair<WriteDiv8, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 50, 68, [50,50], [68,68], 9, 9>; 109defm : AtomWriteResPair<WriteDiv16, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 50, 50, [50,50], [50,50], 12, 12>; 110defm : AtomWriteResPair<WriteDiv32, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 50, 50, [50,50], [50,50], 12, 12>; 111defm : AtomWriteResPair<WriteDiv64, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1],130,130,[130,130],[130,130], 38, 38>; 112defm : AtomWriteResPair<WriteIDiv8, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 62, 62, [62,62], [62,62], 26, 26>; 113defm : AtomWriteResPair<WriteIDiv16, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 62, 62, [62,62], [62,62], 29, 29>; 114defm : AtomWriteResPair<WriteIDiv32, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 62, 62, [62,62], [62,62], 29, 29>; 115defm : AtomWriteResPair<WriteIDiv64, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1],130,130,[130,130],[130,130], 60, 60>; 116 117defm : X86WriteResPairUnsupported<WriteCRC32>; 118 119defm : AtomWriteResPair<WriteCMOV, [AtomPort01], [AtomPort0]>; 120defm : X86WriteRes<WriteFCMOV, [AtomPort01], 9, [9], 1>; // x87 conditional move. 121 122def : WriteRes<WriteSETCC, [AtomPort01]>; 123def : WriteRes<WriteSETCCStore, [AtomPort01]> { 124 let Latency = 2; 125 let ReleaseAtCycles = [2]; 126} 127def : WriteRes<WriteLAHFSAHF, [AtomPort01]> { 128 let Latency = 2; 129 let ReleaseAtCycles = [2]; 130} 131defm : X86WriteRes<WriteBitTest, [AtomPort1], 1, [1], 1>; 132defm : X86WriteRes<WriteBitTestImmLd, [AtomPort0], 1, [1], 1>; 133defm : X86WriteRes<WriteBitTestRegLd, [AtomPort01], 9, [9], 1>; 134defm : X86WriteRes<WriteBitTestSet, [AtomPort1], 1, [1], 1>; 135//defm : X86WriteRes<WriteBitTestSetImmLd, [AtomPort1], 1, [1], 1>; 136//defm : X86WriteRes<WriteBitTestSetRegLd, [AtomPort1], 1, [1], 1>; 137 138// This is for simple LEAs with one or two input operands. 139def : WriteRes<WriteLEA, [AtomPort1]>; 140 141// Bit counts. 142defm : AtomWriteResPair<WriteBSF, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 16, 16, [16,16], [16,16], 10, 10>; 143defm : AtomWriteResPair<WriteBSR, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 16, 16, [16,16], [16,16], 10, 10>; 144defm : X86WriteResPairUnsupported<WritePOPCNT>; 145defm : X86WriteResPairUnsupported<WriteLZCNT>; 146defm : X86WriteResPairUnsupported<WriteTZCNT>; 147 148// BMI1 BEXTR/BLS, BMI2 BZHI 149defm : X86WriteResPairUnsupported<WriteBEXTR>; 150defm : X86WriteResPairUnsupported<WriteBLS>; 151defm : X86WriteResPairUnsupported<WriteBZHI>; 152 153//////////////////////////////////////////////////////////////////////////////// 154// Integer shifts and rotates. 155//////////////////////////////////////////////////////////////////////////////// 156 157defm : AtomWriteResPair<WriteShift, [AtomPort0], [AtomPort0]>; 158defm : AtomWriteResPair<WriteShiftCL, [AtomPort0], [AtomPort0]>; 159defm : AtomWriteResPair<WriteRotate, [AtomPort0], [AtomPort0]>; 160defm : AtomWriteResPair<WriteRotateCL, [AtomPort0], [AtomPort0]>; 161 162defm : X86WriteRes<WriteSHDrri, [AtomPort01], 2, [2], 1>; 163defm : X86WriteRes<WriteSHDrrcl,[AtomPort01], 2, [2], 1>; 164defm : X86WriteRes<WriteSHDmri, [AtomPort01], 4, [4], 1>; 165defm : X86WriteRes<WriteSHDmrcl,[AtomPort01], 4, [4], 1>; 166 167//////////////////////////////////////////////////////////////////////////////// 168// Loads, stores, and moves, not folded with other operations. 169//////////////////////////////////////////////////////////////////////////////// 170 171def : WriteRes<WriteLoad, [AtomPort0]>; 172def : WriteRes<WriteStore, [AtomPort0]>; 173def : WriteRes<WriteStoreNT, [AtomPort0]>; 174def : WriteRes<WriteMove, [AtomPort01]>; 175defm : X86WriteResUnsupported<WriteVecMaskedGatherWriteback>; 176 177// Treat misc copies as a move. 178def : InstRW<[WriteMove], (instrs COPY)>; 179 180//////////////////////////////////////////////////////////////////////////////// 181// Idioms that clear a register, like xorps %xmm0, %xmm0. 182// These can often bypass execution ports completely. 183//////////////////////////////////////////////////////////////////////////////// 184 185def : WriteRes<WriteZero, []>; 186 187//////////////////////////////////////////////////////////////////////////////// 188// Branches don't produce values, so they have no latency, but they still 189// consume resources. Indirect branches can fold loads. 190//////////////////////////////////////////////////////////////////////////////// 191 192defm : AtomWriteResPair<WriteJump, [AtomPort1], [AtomPort1]>; 193 194//////////////////////////////////////////////////////////////////////////////// 195// Special case scheduling classes. 196//////////////////////////////////////////////////////////////////////////////// 197 198def : WriteRes<WriteSystem, [AtomPort01]> { let Latency = 100; } 199def : WriteRes<WriteMicrocoded, [AtomPort01]> { let Latency = 100; } 200def : WriteRes<WriteFence, [AtomPort0]>; 201 202// Nops don't have dependencies, so there's no actual latency, but we set this 203// to '1' to tell the scheduler that the nop uses an ALU slot for a cycle. 204def : WriteRes<WriteNop, [AtomPort01]>; 205 206//////////////////////////////////////////////////////////////////////////////// 207// Floating point. This covers both scalar and vector operations. 208//////////////////////////////////////////////////////////////////////////////// 209 210defm : X86WriteRes<WriteFLD0, [AtomPort01], 1, [1], 1>; 211defm : X86WriteRes<WriteFLD1, [AtomPort01], 6, [6], 1>; 212def : WriteRes<WriteFLoad, [AtomPort0]>; 213def : WriteRes<WriteFLoadX, [AtomPort0]>; 214defm : X86WriteResUnsupported<WriteFLoadY>; 215defm : X86WriteResUnsupported<WriteFMaskedLoad>; 216defm : X86WriteResUnsupported<WriteFMaskedLoadY>; 217 218def : WriteRes<WriteFStore, [AtomPort0]>; 219def : WriteRes<WriteFStoreX, [AtomPort0]>; 220defm : X86WriteResUnsupported<WriteFStoreY>; 221def : WriteRes<WriteFStoreNT, [AtomPort0]>; 222def : WriteRes<WriteFStoreNTX, [AtomPort0]>; 223defm : X86WriteResUnsupported<WriteFStoreNTY>; 224defm : X86WriteResUnsupported<WriteFMaskedStore32>; 225defm : X86WriteResUnsupported<WriteFMaskedStore32Y>; 226defm : X86WriteResUnsupported<WriteFMaskedStore64>; 227defm : X86WriteResUnsupported<WriteFMaskedStore64Y>; 228 229def : WriteRes<WriteFMove, [AtomPort01]>; 230def : WriteRes<WriteFMoveX, [AtomPort01]>; 231defm : X86WriteResUnsupported<WriteFMoveY>; 232defm : X86WriteResUnsupported<WriteFMoveZ>; 233 234defm : X86WriteRes<WriteEMMS, [AtomPort01], 5, [5], 1>; 235 236defm : AtomWriteResPair<WriteFAdd, [AtomPort1], [AtomPort0,AtomPort1], 5, 5, [1], [1,1]>; 237defm : AtomWriteResPair<WriteFAddX, [AtomPort1], [AtomPort0,AtomPort1], 5, 5, [1], [1,1]>; 238defm : X86WriteResPairUnsupported<WriteFAddY>; 239defm : X86WriteResPairUnsupported<WriteFAddZ>; 240defm : AtomWriteResPair<WriteFAdd64, [AtomPort1], [AtomPort0,AtomPort1], 5, 5, [1], [1,1]>; 241defm : AtomWriteResPair<WriteFAdd64X, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [5,5], [6,6], 3, 4>; 242defm : X86WriteResPairUnsupported<WriteFAdd64Y>; 243defm : X86WriteResPairUnsupported<WriteFAdd64Z>; 244defm : AtomWriteResPair<WriteFCmp, [AtomPort1], [AtomPort0,AtomPort1], 5, 5, [1], [1,1]>; 245defm : AtomWriteResPair<WriteFCmpX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [5,5], [6,6], 3, 4>; 246defm : X86WriteResPairUnsupported<WriteFCmpY>; 247defm : X86WriteResPairUnsupported<WriteFCmpZ>; 248defm : AtomWriteResPair<WriteFCmp64, [AtomPort1], [AtomPort0,AtomPort1], 5, 5, [1], [1,1]>; 249defm : AtomWriteResPair<WriteFCmp64X, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [5,5], [6,6], 3, 4>; 250defm : X86WriteResPairUnsupported<WriteFCmp64Y>; 251defm : X86WriteResPairUnsupported<WriteFCmp64Z>; 252defm : AtomWriteResPair<WriteFCom, [AtomPort0], [AtomPort0], 5, 5, [5], [5]>; 253defm : AtomWriteResPair<WriteFComX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 9, 10, [9,9],[10,10], 4, 5>; 254defm : AtomWriteResPair<WriteFMul, [AtomPort0], [AtomPort0], 4, 4, [2], [2]>; 255defm : AtomWriteResPair<WriteFMulX, [AtomPort0], [AtomPort0], 5, 5, [2], [2]>; 256defm : X86WriteResPairUnsupported<WriteFMulY>; 257defm : X86WriteResPairUnsupported<WriteFMulZ>; 258defm : AtomWriteResPair<WriteFMul64, [AtomPort0], [AtomPort0], 5, 5, [2], [2]>; 259defm : AtomWriteResPair<WriteFMul64X, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 9, 10, [9,9],[10,10], 6, 7>; 260defm : X86WriteResPairUnsupported<WriteFMul64Y>; 261defm : X86WriteResPairUnsupported<WriteFMul64Z>; 262defm : AtomWriteResPair<WriteFRcp, [AtomPort0], [AtomPort0], 4, 4, [4], [4]>; 263defm : AtomWriteResPair<WriteFRcpX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 9, 10, [9,9], [10,10], 5, 6>; 264defm : X86WriteResPairUnsupported<WriteFRcpY>; 265defm : X86WriteResPairUnsupported<WriteFRcpZ>; 266defm : AtomWriteResPair<WriteFRsqrt, [AtomPort0], [AtomPort0], 4, 4, [4], [4]>; 267defm : AtomWriteResPair<WriteFRsqrtX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 9, 10, [9,9], [10,10], 5, 6>; 268defm : X86WriteResPairUnsupported<WriteFRsqrtY>; 269defm : X86WriteResPairUnsupported<WriteFRsqrtZ>; 270defm : AtomWriteResPair<WriteFDiv, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 34, 34, [34,34], [34,34], 3, 4>; 271defm : AtomWriteResPair<WriteFDivX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 70, 70, [70,70], [70,70], 6, 7>; 272defm : X86WriteResPairUnsupported<WriteFDivY>; 273defm : X86WriteResPairUnsupported<WriteFDivZ>; 274defm : AtomWriteResPair<WriteFDiv64, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 62, 62, [62,62], [62,62], 3, 4>; 275defm : AtomWriteResPair<WriteFDiv64X, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1],125,125,[125,125],[125,125], 6, 7>; 276defm : X86WriteResPairUnsupported<WriteFDiv64Y>; 277defm : X86WriteResPairUnsupported<WriteFDiv64Z>; 278defm : AtomWriteResPair<WriteFSqrt, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 34, 34, [34,34], [34,34], 3, 4>; 279defm : AtomWriteResPair<WriteFSqrtX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 70, 70, [70,70], [70,70], 5, 6>; 280defm : X86WriteResPairUnsupported<WriteFSqrtY>; 281defm : X86WriteResPairUnsupported<WriteFSqrtZ>; 282defm : AtomWriteResPair<WriteFSqrt64, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 62, 62, [62,62], [62,62], 3, 4>; 283defm : AtomWriteResPair<WriteFSqrt64X, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1],125,125,[125,125],[125,125], 5, 6>; 284defm : X86WriteResPairUnsupported<WriteFSqrt64Y>; 285defm : X86WriteResPairUnsupported<WriteFSqrt64Z>; 286defm : AtomWriteResPair<WriteFSqrt80, [AtomPort0], [AtomPort0], 71, 71, [71], [71]>; 287defm : AtomWriteResPair<WriteFSign, [AtomPort1], [AtomPort1]>; 288defm : AtomWriteResPair<WriteFRnd, [AtomPort0], [AtomPort0], 5, 5, [5], [5]>; 289defm : X86WriteResPairUnsupported<WriteFRndY>; 290defm : X86WriteResPairUnsupported<WriteFRndZ>; 291defm : AtomWriteResPair<WriteFLogic, [AtomPort01], [AtomPort0]>; 292defm : X86WriteResPairUnsupported<WriteFLogicY>; 293defm : X86WriteResPairUnsupported<WriteFLogicZ>; 294defm : AtomWriteResPair<WriteFTest, [AtomPort01], [AtomPort0]>; 295defm : X86WriteResPairUnsupported<WriteFTestY>; 296defm : X86WriteResPairUnsupported<WriteFTestZ>; 297defm : AtomWriteResPair<WriteFShuffle, [AtomPort0], [AtomPort0]>; 298defm : X86WriteResPairUnsupported<WriteFShuffleY>; 299defm : X86WriteResPairUnsupported<WriteFShuffleZ>; 300defm : X86WriteResPairUnsupported<WriteFVarShuffle>; 301defm : X86WriteResPairUnsupported<WriteFVarShuffleY>; 302defm : X86WriteResPairUnsupported<WriteFVarShuffleZ>; 303defm : X86WriteResPairUnsupported<WriteFMA>; 304defm : X86WriteResPairUnsupported<WriteFMAX>; 305defm : X86WriteResPairUnsupported<WriteFMAY>; 306defm : X86WriteResPairUnsupported<WriteFMAZ>; 307defm : X86WriteResPairUnsupported<WriteDPPD>; 308defm : X86WriteResPairUnsupported<WriteDPPS>; 309defm : X86WriteResPairUnsupported<WriteDPPSY>; 310defm : X86WriteResPairUnsupported<WriteFBlend>; 311defm : X86WriteResPairUnsupported<WriteFBlendY>; 312defm : X86WriteResPairUnsupported<WriteFBlendZ>; 313defm : X86WriteResPairUnsupported<WriteFVarBlend>; 314defm : X86WriteResPairUnsupported<WriteFVarBlendY>; 315defm : X86WriteResPairUnsupported<WriteFVarBlendZ>; 316defm : X86WriteResPairUnsupported<WriteFShuffle256>; 317defm : X86WriteResPairUnsupported<WriteFVarShuffle256>; 318 319//////////////////////////////////////////////////////////////////////////////// 320// Conversions. 321//////////////////////////////////////////////////////////////////////////////// 322 323defm : AtomWriteResPair<WriteCvtSS2I, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 8, 9, [8,8], [9,9], 3, 4>; 324defm : AtomWriteResPair<WriteCvtPS2I, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [7,7], 3, 4>; 325defm : X86WriteResPairUnsupported<WriteCvtPS2IY>; 326defm : X86WriteResPairUnsupported<WriteCvtPS2IZ>; 327defm : AtomWriteResPair<WriteCvtSD2I, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 8, 9, [8,8],[10,10], 3, 4>; 328defm : AtomWriteResPair<WriteCvtPD2I, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 7, 8, [7,7], [8,8], 4, 5>; 329defm : X86WriteResPairUnsupported<WriteCvtPD2IY>; 330defm : X86WriteResPairUnsupported<WriteCvtPD2IZ>; 331 332defm : AtomWriteResPair<WriteCvtI2SS, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [6,6], 3, 1>; 333defm : AtomWriteResPair<WriteCvtI2PS, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [7,7], 3, 4>; 334defm : X86WriteResPairUnsupported<WriteCvtI2PSY>; 335defm : X86WriteResPairUnsupported<WriteCvtI2PSZ>; 336defm : AtomWriteResPair<WriteCvtI2SD, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [7,7], 3, 3>; 337defm : AtomWriteResPair<WriteCvtI2PD, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 7, 8, [6,6], [7,7], 3, 4>; 338defm : X86WriteResPairUnsupported<WriteCvtI2PDY>; 339defm : X86WriteResPairUnsupported<WriteCvtI2PDZ>; 340 341defm : AtomWriteResPair<WriteCvtSS2SD, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 6, 7, [6,6], [7,7], 3, 4>; 342defm : AtomWriteResPair<WriteCvtPS2PD, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 7, 8, [6,6], [7,7], 4, 5>; 343defm : X86WriteResPairUnsupported<WriteCvtPS2PDY>; 344defm : X86WriteResPairUnsupported<WriteCvtPS2PDZ>; 345defm : AtomWriteResPair<WriteCvtSD2SS, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 10, 11,[10,10],[12,12], 3, 4>; 346defm : AtomWriteResPair<WriteCvtPD2PS, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 11, 12,[11,11],[12,12], 4, 5>; 347defm : X86WriteResPairUnsupported<WriteCvtPD2PSY>; 348defm : X86WriteResPairUnsupported<WriteCvtPD2PSZ>; 349 350defm : X86WriteResPairUnsupported<WriteCvtPH2PS>; 351defm : X86WriteResPairUnsupported<WriteCvtPH2PSY>; 352defm : X86WriteResPairUnsupported<WriteCvtPH2PSZ>; 353defm : X86WriteResUnsupported<WriteCvtPS2PH>; 354defm : X86WriteResUnsupported<WriteCvtPS2PHSt>; 355defm : X86WriteResUnsupported<WriteCvtPS2PHY>; 356defm : X86WriteResUnsupported<WriteCvtPS2PHZ>; 357defm : X86WriteResUnsupported<WriteCvtPS2PHYSt>; 358defm : X86WriteResUnsupported<WriteCvtPS2PHZSt>; 359 360//////////////////////////////////////////////////////////////////////////////// 361// Vector integer operations. 362//////////////////////////////////////////////////////////////////////////////// 363 364def : WriteRes<WriteVecLoad, [AtomPort0]>; 365def : WriteRes<WriteVecLoadX, [AtomPort0]>; 366defm : X86WriteResUnsupported<WriteVecLoadY>; 367def : WriteRes<WriteVecLoadNT, [AtomPort0]>; 368defm : X86WriteResUnsupported<WriteVecLoadNTY>; 369defm : X86WriteResUnsupported<WriteVecMaskedLoad>; 370defm : X86WriteResUnsupported<WriteVecMaskedLoadY>; 371 372def : WriteRes<WriteVecStore, [AtomPort0]>; 373def : WriteRes<WriteVecStoreX, [AtomPort0]>; 374defm : X86WriteResUnsupported<WriteVecStoreY>; 375def : WriteRes<WriteVecStoreNT, [AtomPort0]>; 376defm : X86WriteResUnsupported<WriteVecStoreNTY>; 377defm : X86WriteResUnsupported<WriteVecMaskedStore32>; 378defm : X86WriteResUnsupported<WriteVecMaskedStore64>; 379defm : X86WriteResUnsupported<WriteVecMaskedStore32Y>; 380defm : X86WriteResUnsupported<WriteVecMaskedStore64Y>; 381 382def : WriteRes<WriteVecMove, [AtomPort0]>; 383def : WriteRes<WriteVecMoveX, [AtomPort01]>; 384defm : X86WriteResUnsupported<WriteVecMoveY>; 385defm : X86WriteResUnsupported<WriteVecMoveZ>; 386defm : X86WriteRes<WriteVecMoveToGpr, [AtomPort0], 3, [3], 1>; 387defm : X86WriteRes<WriteVecMoveFromGpr, [AtomPort0], 1, [1], 1>; 388 389defm : AtomWriteResPair<WriteVecALU, [AtomPort01], [AtomPort0], 1, 1>; 390defm : AtomWriteResPair<WriteVecALUX, [AtomPort01], [AtomPort0], 1, 1>; 391defm : X86WriteResPairUnsupported<WriteVecALUY>; 392defm : X86WriteResPairUnsupported<WriteVecALUZ>; 393defm : AtomWriteResPair<WriteVecLogic, [AtomPort01], [AtomPort0], 1, 1>; 394defm : AtomWriteResPair<WriteVecLogicX, [AtomPort01], [AtomPort0], 1, 1>; 395defm : X86WriteResPairUnsupported<WriteVecLogicY>; 396defm : X86WriteResPairUnsupported<WriteVecLogicZ>; 397defm : X86WriteResPairUnsupported<WriteVecTest>; 398defm : X86WriteResPairUnsupported<WriteVecTestY>; 399defm : X86WriteResPairUnsupported<WriteVecTestZ>; 400defm : AtomWriteResPair<WriteVecShift, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 2, 3, [1,1], [2,2], 2, 3>; 401defm : AtomWriteResPair<WriteVecShiftX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 2, 3, [1,1], [2,2], 2, 3>; 402defm : X86WriteResPairUnsupported<WriteVecShiftY>; 403defm : X86WriteResPairUnsupported<WriteVecShiftZ>; 404defm : AtomWriteResPair<WriteVecShiftImm, [AtomPort0], [AtomPort0], 1, 1>; 405defm : AtomWriteResPair<WriteVecShiftImmX, [AtomPort0], [AtomPort0], 1, 1>; 406defm : X86WriteResPairUnsupported<WriteVecShiftImmY>; 407defm : X86WriteResPairUnsupported<WriteVecShiftImmZ>; 408defm : AtomWriteResPair<WriteVecIMul, [AtomPort0], [AtomPort0], 4, 4, [1], [1]>; 409defm : AtomWriteResPair<WriteVecIMulX, [AtomPort0], [AtomPort0], 5, 5, [2], [2]>; 410defm : X86WriteResPairUnsupported<WriteVecIMulY>; 411defm : X86WriteResPairUnsupported<WriteVecIMulZ>; 412defm : X86WriteResPairUnsupported<WritePMULLD>; 413defm : X86WriteResPairUnsupported<WritePMULLDY>; 414defm : X86WriteResPairUnsupported<WritePMULLDZ>; 415defm : X86WriteResPairUnsupported<WritePHMINPOS>; 416defm : X86WriteResPairUnsupported<WriteMPSAD>; 417defm : X86WriteResPairUnsupported<WriteMPSADY>; 418defm : X86WriteResPairUnsupported<WriteMPSADZ>; 419defm : AtomWriteResPair<WritePSADBW, [AtomPort0], [AtomPort0], 4, 4, [1], [1]>; 420defm : AtomWriteResPair<WritePSADBWX, [AtomPort0], [AtomPort0], 5, 5, [2], [2]>; 421defm : X86WriteResPairUnsupported<WritePSADBWY>; 422defm : X86WriteResPairUnsupported<WritePSADBWZ>; 423defm : AtomWriteResPair<WriteShuffle, [AtomPort0], [AtomPort0], 1, 1>; 424defm : AtomWriteResPair<WriteShuffleX, [AtomPort0], [AtomPort0], 1, 1>; 425defm : X86WriteResPairUnsupported<WriteShuffleY>; 426defm : X86WriteResPairUnsupported<WriteShuffleZ>; 427defm : AtomWriteResPair<WriteVarShuffle, [AtomPort0], [AtomPort0], 1, 1>; 428defm : AtomWriteResPair<WriteVarShuffleX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 4, 5, [3,3], [4,4], 4, 5>; 429defm : X86WriteResPairUnsupported<WriteVarShuffleY>; 430defm : X86WriteResPairUnsupported<WriteVarShuffleZ>; 431defm : X86WriteResPairUnsupported<WriteBlend>; 432defm : X86WriteResPairUnsupported<WriteBlendY>; 433defm : X86WriteResPairUnsupported<WriteBlendZ>; 434defm : X86WriteResPairUnsupported<WriteVarBlend>; 435defm : X86WriteResPairUnsupported<WriteVarBlendY>; 436defm : X86WriteResPairUnsupported<WriteVarBlendZ>; 437defm : X86WriteResPairUnsupported<WriteShuffle256>; 438defm : X86WriteResPairUnsupported<WriteVPMOV256>; 439defm : X86WriteResPairUnsupported<WriteVarShuffle256>; 440defm : X86WriteResPairUnsupported<WriteVarVecShift>; 441defm : X86WriteResPairUnsupported<WriteVarVecShiftY>; 442defm : X86WriteResPairUnsupported<WriteVarVecShiftZ>; 443 444//////////////////////////////////////////////////////////////////////////////// 445// Vector insert/extract operations. 446//////////////////////////////////////////////////////////////////////////////// 447 448defm : AtomWriteResPair<WriteVecInsert, [AtomPort0], [AtomPort0], 1, 1>; 449def : WriteRes<WriteVecExtract, [AtomPort0]>; 450def : WriteRes<WriteVecExtractSt, [AtomPort0]>; 451 452//////////////////////////////////////////////////////////////////////////////// 453// SSE42 String instructions. 454//////////////////////////////////////////////////////////////////////////////// 455 456defm : X86WriteResPairUnsupported<WritePCmpIStrI>; 457defm : X86WriteResPairUnsupported<WritePCmpIStrM>; 458defm : X86WriteResPairUnsupported<WritePCmpEStrI>; 459defm : X86WriteResPairUnsupported<WritePCmpEStrM>; 460 461//////////////////////////////////////////////////////////////////////////////// 462// MOVMSK Instructions. 463//////////////////////////////////////////////////////////////////////////////// 464 465def : WriteRes<WriteFMOVMSK, [AtomPort0]> { let Latency = 3; let ReleaseAtCycles = [3]; } 466def : WriteRes<WriteVecMOVMSK, [AtomPort0]> { let Latency = 3; let ReleaseAtCycles = [3]; } 467defm : X86WriteResUnsupported<WriteVecMOVMSKY>; 468def : WriteRes<WriteMMXMOVMSK, [AtomPort0]> { let Latency = 3; let ReleaseAtCycles = [3]; } 469 470//////////////////////////////////////////////////////////////////////////////// 471// AES instructions. 472//////////////////////////////////////////////////////////////////////////////// 473 474defm : X86WriteResPairUnsupported<WriteAESIMC>; 475defm : X86WriteResPairUnsupported<WriteAESKeyGen>; 476defm : X86WriteResPairUnsupported<WriteAESDecEnc>; 477 478//////////////////////////////////////////////////////////////////////////////// 479// Horizontal add/sub instructions. 480//////////////////////////////////////////////////////////////////////////////// 481 482defm : AtomWriteResPair<WriteFHAdd, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 8, 9, [8,8], [9,9], 5, 6>; 483defm : X86WriteResPairUnsupported<WriteFHAddY>; 484defm : AtomWriteResPair<WritePHAdd, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 3, 4, [3,3], [4,4], 3, 4>; 485defm : AtomWriteResPair<WritePHAddX, [AtomPort0,AtomPort1], [AtomPort0,AtomPort1], 7, 8, [7,7], [8,8], 3, 4>; 486defm : X86WriteResPairUnsupported<WritePHAddY>; 487 488//////////////////////////////////////////////////////////////////////////////// 489// Carry-less multiplication instructions. 490//////////////////////////////////////////////////////////////////////////////// 491 492defm : X86WriteResPairUnsupported<WriteCLMul>; 493 494//////////////////////////////////////////////////////////////////////////////// 495// Load/store MXCSR. 496//////////////////////////////////////////////////////////////////////////////// 497 498defm : X86WriteRes<WriteLDMXCSR, [AtomPort0,AtomPort1], 5, [5,5], 4>; 499defm : X86WriteRes<WriteSTMXCSR, [AtomPort0,AtomPort1], 15, [15,15], 4>; 500 501//////////////////////////////////////////////////////////////////////////////// 502// Special Cases. 503//////////////////////////////////////////////////////////////////////////////// 504 505// Port0 506def AtomWrite0_1 : SchedWriteRes<[AtomPort0]> { 507 let Latency = 1; 508 let ReleaseAtCycles = [1]; 509} 510def : InstRW<[AtomWrite0_1], (instrs XAM_F, LD_Frr, 511 MOVSX64rr32)>; 512def : SchedAlias<WriteALURMW, AtomWrite0_1>; 513def : SchedAlias<WriteADCRMW, AtomWrite0_1>; 514def : InstRW<[AtomWrite0_1], (instregex "(RCL|RCR|ROL|ROR|SAR|SHL|SHR)(8|16|32|64)m", 515 "MOV(S|Z)X(32|64)rr(8|8_NOREX|16)")>; 516 517// Port1 518def AtomWrite1_1 : SchedWriteRes<[AtomPort1]> { 519 let Latency = 1; 520 let ReleaseAtCycles = [1]; 521} 522def : InstRW<[AtomWrite1_1], (instrs FCOMPP)>; 523def : InstRW<[AtomWrite1_1], (instregex "UCOM_F(P|PP)?r")>; 524 525def AtomWrite1_5 : SchedWriteRes<[AtomPort1]> { 526 let Latency = 5; 527 let ReleaseAtCycles = [5]; 528} 529def : InstRW<[AtomWrite1_5], (instrs MMX_CVTPI2PSrr, MMX_CVTPI2PSrm, 530 MMX_CVTPS2PIrr, MMX_CVTTPS2PIrr)>; 531 532// Port0 and Port1 533def AtomWrite0_1_1 : SchedWriteRes<[AtomPort0, AtomPort1]> { 534 let Latency = 1; 535 let ReleaseAtCycles = [1, 1]; 536} 537def : InstRW<[AtomWrite0_1_1], (instrs POP32r, POP64r, 538 POP16rmr, POP32rmr, POP64rmr, 539 PUSH16r, PUSH32r, PUSH64r, 540 PUSH16i, PUSH32i, 541 PUSH16rmr, PUSH32rmr, PUSH64rmr, 542 PUSH16i8, PUSH32i8, PUSH64i8, PUSH64i32, 543 XCH_F)>; 544def : InstRW<[AtomWrite0_1_1], (instregex "RETI(16|32|64)$", 545 "IRET(16|32|64)?")>; 546 547def AtomWrite0_1_5 : SchedWriteRes<[AtomPort0, AtomPort1]> { 548 let Latency = 5; 549 let ReleaseAtCycles = [5, 5]; 550} 551def : InstRW<[AtomWrite0_1_5], (instrs MMX_CVTPS2PIrm, MMX_CVTTPS2PIrm)>; 552def : InstRW<[AtomWrite0_1_5], (instregex "ILD_F(16|32|64)")>; 553 554def AtomWrite0_1_7 : SchedWriteRes<[AtomPort0,AtomPort1]> { 555 let Latency = 7; 556 let ReleaseAtCycles = [6,6]; 557} 558def : InstRW<[AtomWrite0_1_7], (instregex "CVTSI642SDrm(_Int)?")>; 559 560def AtomWrite0_1_7_4 : SchedWriteRes<[AtomPort0,AtomPort1]> { 561 let Latency = 7; 562 let ReleaseAtCycles = [8,8]; 563 let NumMicroOps = 4; 564} 565def : InstRW<[AtomWrite0_1_7_4], (instregex "CVTSI642SSrr(_Int)?")>; 566 567def AtomWrite0_1_8_4 : SchedWriteRes<[AtomPort0,AtomPort1]> { 568 let Latency = 8; 569 let ReleaseAtCycles = [8,8]; 570 let NumMicroOps = 4; 571} 572def : InstRW<[AtomWrite0_1_7_4], (instregex "CVTSI642SSrm(_Int)?")>; 573 574def AtomWrite0_1_9 : SchedWriteRes<[AtomPort0,AtomPort1]> { 575 let Latency = 9; 576 let ReleaseAtCycles = [9,9]; 577 let NumMicroOps = 4; 578} 579def : InstRW<[AtomWrite0_1_9], (instregex "CVT(T)?SS2SI64rr(_Int)?")>; 580 581def AtomWrite0_1_10 : SchedWriteRes<[AtomPort0,AtomPort1]> { 582 let Latency = 10; 583 let ReleaseAtCycles = [11,11]; 584 let NumMicroOps = 5; 585} 586def : InstRW<[AtomWrite0_1_10], (instregex "CVT(T)?SS2SI64rm(_Int)?")>; 587 588// Port0 or Port1 589def AtomWrite01_1 : SchedWriteRes<[AtomPort01]> { 590 let Latency = 1; 591 let ReleaseAtCycles = [1]; 592} 593def : InstRW<[AtomWrite01_1], (instrs FDECSTP, FFREE, FFREEP, FINCSTP, WAIT, 594 LFENCE, 595 STOSB, STOSL, STOSQ, STOSW, 596 MOVSSrr, MOVSSrr_REV)>; 597 598def AtomWrite01_2 : SchedWriteRes<[AtomPort01]> { 599 let Latency = 2; 600 let ReleaseAtCycles = [2]; 601} 602def : InstRW<[AtomWrite01_2], (instrs LEAVE, LEAVE64, POP16r, 603 PUSH16rmm, PUSH32rmm, PUSH64rmm, 604 LODSB, LODSL, LODSQ, LODSW, 605 SCASB, SCASL, SCASQ, SCASW)>; 606def : InstRW<[AtomWrite01_2], (instregex "PUSH(CS|DS|ES|FS|GS|SS)(16|32|64)", 607 "(ST|ISTT)_F(P)?(16|32|64)?(m|rr)", 608 "MMX_P(ADD|SUB)Qrr", 609 "MOV(S|Z)X16rr8", 610 "MOV(UPS|UPD|DQU)mr", 611 "MASKMOVDQU(64)?", 612 "P(ADD|SUB)Qrr")>; 613def : SchedAlias<WriteBitTestSetImmRMW, AtomWrite01_2>; 614 615def AtomWrite01_3 : SchedWriteRes<[AtomPort01]> { 616 let Latency = 3; 617 let ReleaseAtCycles = [3]; 618} 619def : InstRW<[AtomWrite01_3], (instrs CLD, LDDQUrm, 620 CMPSB, CMPSL, CMPSQ, CMPSW, 621 MOVSB, MOVSL, MOVSQ, MOVSW, 622 POP16rmm, POP32rmm, POP64rmm)>; 623def : InstRW<[AtomWrite01_3], (instregex "XADD(8|16|32|64)rm", 624 "XCHG(8|16|32|64)rm", 625 "PH(ADD|SUB)Drr", 626 "MOV(S|Z)X16rm8", 627 "MMX_P(ADD|SUB)Qrm", 628 "MOV(UPS|UPD|DQU)rm", 629 "P(ADD|SUB)Qrm")>; 630 631def AtomWrite01_4 : SchedWriteRes<[AtomPort01]> { 632 let Latency = 4; 633 let ReleaseAtCycles = [4]; 634} 635def : InstRW<[AtomWrite01_4], (instrs CBW, CWD, CWDE, CDQ, CDQE, CQO, 636 JCXZ, JECXZ, JRCXZ, 637 LD_F80m)>; 638def : InstRW<[AtomWrite01_4], (instregex "PH(ADD|SUB)Drm", 639 "(MMX_)?PEXTRWrr(_REV)?")>; 640 641def AtomWrite01_5 : SchedWriteRes<[AtomPort01]> { 642 let Latency = 5; 643 let ReleaseAtCycles = [5]; 644} 645def : InstRW<[AtomWrite01_5], (instrs FLDCW16m, ST_FP80m)>; 646def : InstRW<[AtomWrite01_5], (instregex "MMX_PH(ADD|SUB)S?Wrr")>; 647 648def AtomWrite01_6 : SchedWriteRes<[AtomPort01]> { 649 let Latency = 6; 650 let ReleaseAtCycles = [6]; 651} 652def : InstRW<[AtomWrite01_6], (instrs CMPXCHG8rm, INTO, XLAT, 653 SHLD16rrCL, SHRD16rrCL, 654 SHLD16rri8, SHRD16rri8, 655 SHLD16mrCL, SHRD16mrCL, 656 SHLD16mri8, SHRD16mri8)>; 657def : InstRW<[AtomWrite01_6], (instregex "IST_F(P)?(16|32|64)?m", 658 "MMX_PH(ADD|SUB)S?Wrm")>; 659 660def AtomWrite01_7 : SchedWriteRes<[AtomPort01]> { 661 let Latency = 7; 662 let ReleaseAtCycles = [7]; 663} 664def : InstRW<[AtomWrite01_7], (instrs AAD8i8)>; 665 666def AtomWrite01_8 : SchedWriteRes<[AtomPort01]> { 667 let Latency = 8; 668 let ReleaseAtCycles = [8]; 669} 670def : InstRW<[AtomWrite01_8], (instrs LOOPE, 671 PUSHA16, PUSHA32, 672 SHLD64rrCL, SHRD64rrCL, 673 FNSTCW16m)>; 674 675def AtomWrite01_9 : SchedWriteRes<[AtomPort01]> { 676 let Latency = 9; 677 let ReleaseAtCycles = [9]; 678} 679def : InstRW<[AtomWrite01_9], (instrs POPA16, POPA32, 680 PUSHF16, PUSHF32, PUSHF64, 681 SHLD64mrCL, SHRD64mrCL, 682 SHLD64mri8, SHRD64mri8, 683 SHLD64rri8, SHRD64rri8, 684 CMPXCHG8rr)>; 685def : InstRW<[AtomWrite01_9], (instregex "(U)?COM_FI", "TST_F")>; 686 687def AtomWrite01_10 : SchedWriteRes<[AtomPort01]> { 688 let Latency = 10; 689 let ReleaseAtCycles = [10]; 690} 691def : SchedAlias<WriteFLDC, AtomWrite01_10>; 692 693def AtomWrite01_11 : SchedWriteRes<[AtomPort01]> { 694 let Latency = 11; 695 let ReleaseAtCycles = [11]; 696} 697def : InstRW<[AtomWrite01_11], (instrs BOUNDS16rm, BOUNDS32rm)>; 698def : SchedAlias<WriteBitTestSetRegRMW, AtomWrite01_11>; 699 700def AtomWrite01_13 : SchedWriteRes<[AtomPort01]> { 701 let Latency = 13; 702 let ReleaseAtCycles = [13]; 703} 704def : InstRW<[AtomWrite01_13], (instrs AAA, AAS)>; 705 706def AtomWrite01_14 : SchedWriteRes<[AtomPort01]> { 707 let Latency = 14; 708 let ReleaseAtCycles = [14]; 709} 710def : InstRW<[AtomWrite01_14], (instrs CMPXCHG16rm, CMPXCHG32rm, CMPXCHG64rm)>; 711 712def AtomWrite01_17 : SchedWriteRes<[AtomPort01]> { 713 let Latency = 17; 714 let ReleaseAtCycles = [17]; 715} 716def : InstRW<[AtomWrite01_17], (instrs LOOPNE, PAUSE)>; 717 718def AtomWrite01_18 : SchedWriteRes<[AtomPort01]> { 719 let Latency = 18; 720 let ReleaseAtCycles = [18]; 721} 722def : InstRW<[AtomWrite01_18], (instrs CMPXCHG8B, DAA, LOOP)>; 723 724def AtomWrite01_20 : SchedWriteRes<[AtomPort01]> { 725 let Latency = 20; 726 let ReleaseAtCycles = [20]; 727} 728def : InstRW<[AtomWrite01_20], (instrs DAS)>; 729 730def AtomWrite01_21 : SchedWriteRes<[AtomPort01]> { 731 let Latency = 21; 732 let ReleaseAtCycles = [21]; 733} 734def : InstRW<[AtomWrite01_21], (instrs AAM8i8, STD)>; 735 736def AtomWrite01_22 : SchedWriteRes<[AtomPort01]> { 737 let Latency = 22; 738 let ReleaseAtCycles = [22]; 739} 740def : InstRW<[AtomWrite01_22], (instrs CMPXCHG16B)>; 741 742def AtomWrite01_23 : SchedWriteRes<[AtomPort01]> { 743 let Latency = 23; 744 let ReleaseAtCycles = [23]; 745} 746def : InstRW<[AtomWrite01_23], (instrs ARPL16mr, ARPL16rr)>; 747 748def AtomWrite01_25 : SchedWriteRes<[AtomPort01]> { 749 let Latency = 25; 750 let ReleaseAtCycles = [25]; 751} 752def : InstRW<[AtomWrite01_25], (instrs FNCLEX, FXTRACT)>; 753 754def AtomWrite01_26 : SchedWriteRes<[AtomPort01]> { 755 let Latency = 26; 756 let ReleaseAtCycles = [26]; 757} 758def : InstRW<[AtomWrite01_26], (instrs POPF32, POPF64)>; 759 760def AtomWrite01_29 : SchedWriteRes<[AtomPort01]> { 761 let Latency = 29; 762 let ReleaseAtCycles = [29]; 763} 764def : InstRW<[AtomWrite01_29], (instregex "POP(DS|ES|FS|GS)(16|32|64)")>; 765 766def AtomWrite01_30 : SchedWriteRes<[AtomPort01]> { 767 let Latency = 30; 768 let ReleaseAtCycles = [30]; 769} 770def : InstRW<[AtomWrite01_30], (instrs RDTSC, RDTSCP)>; 771 772def AtomWrite01_32 : SchedWriteRes<[AtomPort01]> { 773 let Latency = 32; 774 let ReleaseAtCycles = [32]; 775} 776def : InstRW<[AtomWrite01_32], (instrs ENTER, POPF16)>; 777 778def AtomWrite01_45 : SchedWriteRes<[AtomPort01]> { 779 let Latency = 45; 780 let ReleaseAtCycles = [45]; 781} 782def : InstRW<[AtomWrite01_45], (instrs MONITOR32rrr, MONITOR64rrr)>; 783 784def AtomWrite01_46 : SchedWriteRes<[AtomPort01]> { 785 let Latency = 46; 786 let ReleaseAtCycles = [46]; 787} 788def : InstRW<[AtomWrite01_46], (instrs FRNDINT, MWAITrr, RDPMC)>; 789 790def AtomWrite01_48 : SchedWriteRes<[AtomPort01]> { 791 let Latency = 48; 792 let ReleaseAtCycles = [48]; 793} 794def : InstRW<[AtomWrite01_48], (instrs POPSS16, POPSS32)>; 795 796def AtomWrite01_55 : SchedWriteRes<[AtomPort01]> { 797 let Latency = 55; 798 let ReleaseAtCycles = [55]; 799} 800def : InstRW<[AtomWrite01_55], (instrs FPREM)>; 801 802def AtomWrite01_59 : SchedWriteRes<[AtomPort01]> { 803 let Latency = 59; 804 let ReleaseAtCycles = [59]; 805} 806def : InstRW<[AtomWrite01_59], (instrs INSB, INSL, INSW)>; 807 808def AtomWrite01_63 : SchedWriteRes<[AtomPort01]> { 809 let Latency = 63; 810 let ReleaseAtCycles = [63]; 811} 812def : InstRW<[AtomWrite01_63], (instrs FNINIT)>; 813 814def AtomWrite01_68 : SchedWriteRes<[AtomPort01]> { 815 let Latency = 68; 816 let ReleaseAtCycles = [68]; 817} 818def : InstRW<[AtomWrite01_68], (instrs OUT8rr, OUT16rr, OUT32rr)>; 819 820def AtomWrite01_71 : SchedWriteRes<[AtomPort01]> { 821 let Latency = 71; 822 let ReleaseAtCycles = [71]; 823} 824def : InstRW<[AtomWrite01_71], (instrs FPREM1, 825 INVLPG, INVLPGA32, INVLPGA64)>; 826 827def AtomWrite01_72 : SchedWriteRes<[AtomPort01]> { 828 let Latency = 72; 829 let ReleaseAtCycles = [72]; 830} 831def : InstRW<[AtomWrite01_72], (instrs OUT8ir, OUT16ir, OUT32ir)>; 832 833def AtomWrite01_74 : SchedWriteRes<[AtomPort01]> { 834 let Latency = 74; 835 let ReleaseAtCycles = [74]; 836} 837def : InstRW<[AtomWrite01_74], (instrs OUTSB, OUTSL, OUTSW)>; 838 839def AtomWrite01_77 : SchedWriteRes<[AtomPort01]> { 840 let Latency = 77; 841 let ReleaseAtCycles = [77]; 842} 843def : InstRW<[AtomWrite01_77], (instrs FSCALE)>; 844 845def AtomWrite01_78 : SchedWriteRes<[AtomPort01]> { 846 let Latency = 78; 847 let ReleaseAtCycles = [78]; 848} 849def : InstRW<[AtomWrite01_78], (instrs RDMSR)>; 850 851def AtomWrite01_79 : SchedWriteRes<[AtomPort01]> { 852 let Latency = 79; 853 let ReleaseAtCycles = [79]; 854} 855def : InstRW<[AtomWrite01_79], (instregex "RET(16|32|64)?$", 856 "LRETI?(16|32|64)")>; 857 858def AtomWrite01_92 : SchedWriteRes<[AtomPort01]> { 859 let Latency = 92; 860 let ReleaseAtCycles = [92]; 861} 862def : InstRW<[AtomWrite01_92], (instrs IN8ri, IN16ri, IN32ri)>; 863 864def AtomWrite01_94 : SchedWriteRes<[AtomPort01]> { 865 let Latency = 94; 866 let ReleaseAtCycles = [94]; 867} 868def : InstRW<[AtomWrite01_94], (instrs IN8rr, IN16rr, IN32rr)>; 869 870def AtomWrite01_99 : SchedWriteRes<[AtomPort01]> { 871 let Latency = 99; 872 let ReleaseAtCycles = [99]; 873} 874def : InstRW<[AtomWrite01_99], (instrs F2XM1)>; 875 876def AtomWrite01_121 : SchedWriteRes<[AtomPort01]> { 877 let Latency = 121; 878 let ReleaseAtCycles = [121]; 879} 880def : InstRW<[AtomWrite01_121], (instrs CPUID)>; 881 882def AtomWrite01_127 : SchedWriteRes<[AtomPort01]> { 883 let Latency = 127; 884 let ReleaseAtCycles = [127]; 885} 886def : InstRW<[AtomWrite01_127], (instrs INT)>; 887 888def AtomWrite01_130 : SchedWriteRes<[AtomPort01]> { 889 let Latency = 130; 890 let ReleaseAtCycles = [130]; 891} 892def : InstRW<[AtomWrite01_130], (instrs INT3)>; 893 894def AtomWrite01_140 : SchedWriteRes<[AtomPort01]> { 895 let Latency = 140; 896 let ReleaseAtCycles = [140]; 897} 898def : InstRW<[AtomWrite01_140], (instrs FXSAVE, FXSAVE64)>; 899 900def AtomWrite01_141 : SchedWriteRes<[AtomPort01]> { 901 let Latency = 141; 902 let ReleaseAtCycles = [141]; 903} 904def : InstRW<[AtomWrite01_141], (instrs FXRSTOR, FXRSTOR64)>; 905 906def AtomWrite01_146 : SchedWriteRes<[AtomPort01]> { 907 let Latency = 146; 908 let ReleaseAtCycles = [146]; 909} 910def : InstRW<[AtomWrite01_146], (instrs FYL2X)>; 911 912def AtomWrite01_147 : SchedWriteRes<[AtomPort01]> { 913 let Latency = 147; 914 let ReleaseAtCycles = [147]; 915} 916def : InstRW<[AtomWrite01_147], (instrs FYL2XP1)>; 917 918def AtomWrite01_168 : SchedWriteRes<[AtomPort01]> { 919 let Latency = 168; 920 let ReleaseAtCycles = [168]; 921} 922def : InstRW<[AtomWrite01_168], (instrs FPTAN)>; 923 924def AtomWrite01_174 : SchedWriteRes<[AtomPort01]> { 925 let Latency = 174; 926 let ReleaseAtCycles = [174]; 927} 928def : InstRW<[AtomWrite01_174], (instrs FSINCOS, FSIN, FCOS)>; 929 930def AtomWrite01_183 : SchedWriteRes<[AtomPort01]> { 931 let Latency = 183; 932 let ReleaseAtCycles = [183]; 933} 934def : InstRW<[AtomWrite01_183], (instrs FPATAN)>; 935 936def AtomWrite01_202 : SchedWriteRes<[AtomPort01]> { 937 let Latency = 202; 938 let ReleaseAtCycles = [202]; 939} 940def : InstRW<[AtomWrite01_202], (instrs WRMSR)>; 941 942} // SchedModel 943