1//=- ARMScheduleA9.td - ARM Cortex-A9 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 itinerary class data for the ARM Cortex A9 processors. 10// 11//===----------------------------------------------------------------------===// 12 13// ===---------------------------------------------------------------------===// 14// This section contains legacy support for itineraries. This is 15// required until SD and PostRA schedulers are replaced by MachineScheduler. 16 17// 18// Ad-hoc scheduling information derived from pretty vague "Cortex-A9 Technical 19// Reference Manual". 20// 21// Functional units 22def A9_Issue0 : FuncUnit; // Issue 0 23def A9_Issue1 : FuncUnit; // Issue 1 24def A9_Branch : FuncUnit; // Branch 25def A9_ALU0 : FuncUnit; // ALU / MUL pipeline 0 26def A9_ALU1 : FuncUnit; // ALU pipeline 1 27def A9_AGU : FuncUnit; // Address generation unit for ld / st 28def A9_NPipe : FuncUnit; // NEON pipeline 29def A9_MUX0 : FuncUnit; // AGU + NEON/FPU multiplexer 30def A9_LSUnit : FuncUnit; // L/S Unit 31def A9_DRegsVFP: FuncUnit; // FP register set, VFP side 32def A9_DRegsN : FuncUnit; // FP register set, NEON side 33 34// Bypasses 35def A9_LdBypass : Bypass; 36 37def CortexA9Itineraries : ProcessorItineraries< 38 [A9_Issue0, A9_Issue1, A9_Branch, A9_ALU0, A9_ALU1, A9_AGU, A9_NPipe, A9_MUX0, 39 A9_LSUnit, A9_DRegsVFP, A9_DRegsN], 40 [A9_LdBypass], [ 41 // Two fully-pipelined integer ALU pipelines 42 43 // 44 // Move instructions, unconditional 45 InstrItinData<IIC_iMOVi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 46 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1]>, 47 InstrItinData<IIC_iMOVr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 48 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1]>, 49 InstrItinData<IIC_iMOVsi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 50 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1]>, 51 InstrItinData<IIC_iMOVsr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 52 InstrStage<2, [A9_ALU0, A9_ALU1]>], [2, 1, 1]>, 53 InstrItinData<IIC_iMOVix2 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 54 InstrStage<1, [A9_ALU0, A9_ALU1]>, 55 InstrStage<1, [A9_ALU0, A9_ALU1]>], [2]>, 56 InstrItinData<IIC_iMOVix2addpc,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 57 InstrStage<1, [A9_ALU0, A9_ALU1]>, 58 InstrStage<1, [A9_ALU0, A9_ALU1]>, 59 InstrStage<1, [A9_ALU0, A9_ALU1]>], [3]>, 60 InstrItinData<IIC_iMOVix2ld,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 61 InstrStage<1, [A9_ALU0, A9_ALU1]>, 62 InstrStage<1, [A9_ALU0, A9_ALU1]>, 63 InstrStage<1, [A9_MUX0], 0>, 64 InstrStage<1, [A9_AGU], 0>, 65 InstrStage<1, [A9_LSUnit]>], [5]>, 66 // 67 // MVN instructions 68 InstrItinData<IIC_iMVNi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 69 InstrStage<1, [A9_ALU0, A9_ALU1]>], 70 [1]>, 71 InstrItinData<IIC_iMVNr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 72 InstrStage<1, [A9_ALU0, A9_ALU1]>], 73 [1, 1], [NoBypass, A9_LdBypass]>, 74 InstrItinData<IIC_iMVNsi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 75 InstrStage<2, [A9_ALU0, A9_ALU1]>], 76 [2, 1]>, 77 InstrItinData<IIC_iMVNsr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 78 InstrStage<3, [A9_ALU0, A9_ALU1]>], 79 [3, 1, 1]>, 80 // 81 // No operand cycles 82 InstrItinData<IIC_iALUx , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 83 InstrStage<1, [A9_ALU0, A9_ALU1]>]>, 84 // 85 // Binary Instructions that produce a result 86 InstrItinData<IIC_iALUi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 87 InstrStage<1, [A9_ALU0, A9_ALU1]>], 88 [1, 1], [NoBypass, A9_LdBypass]>, 89 InstrItinData<IIC_iALUr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 90 InstrStage<1, [A9_ALU0, A9_ALU1]>], 91 [1, 1, 1], [NoBypass, A9_LdBypass, A9_LdBypass]>, 92 InstrItinData<IIC_iALUsi, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 93 InstrStage<2, [A9_ALU0, A9_ALU1]>], 94 [2, 1, 1], [NoBypass, A9_LdBypass, NoBypass]>, 95 InstrItinData<IIC_iALUsir,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 96 InstrStage<2, [A9_ALU0, A9_ALU1]>], 97 [2, 1, 1], [NoBypass, NoBypass, A9_LdBypass]>, 98 InstrItinData<IIC_iALUsr, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 99 InstrStage<3, [A9_ALU0, A9_ALU1]>], 100 [3, 1, 1, 1], 101 [NoBypass, A9_LdBypass, NoBypass, NoBypass]>, 102 // 103 // Bitwise Instructions that produce a result 104 InstrItinData<IIC_iBITi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 105 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1]>, 106 InstrItinData<IIC_iBITr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 107 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1, 1]>, 108 InstrItinData<IIC_iBITsi, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 109 InstrStage<2, [A9_ALU0, A9_ALU1]>], [2, 1, 1]>, 110 InstrItinData<IIC_iBITsr, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 111 InstrStage<3, [A9_ALU0, A9_ALU1]>], [3, 1, 1, 1]>, 112 // 113 // Unary Instructions that produce a result 114 115 // CLZ, RBIT, etc. 116 InstrItinData<IIC_iUNAr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 117 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1]>, 118 119 // BFC, BFI, UBFX, SBFX 120 InstrItinData<IIC_iUNAsi, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 121 InstrStage<2, [A9_ALU0, A9_ALU1]>], [2, 1]>, 122 123 // 124 // Zero and sign extension instructions 125 InstrItinData<IIC_iEXTr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 126 InstrStage<1, [A9_ALU0, A9_ALU1]>], [2, 1]>, 127 InstrItinData<IIC_iEXTAr, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 128 InstrStage<2, [A9_ALU0, A9_ALU1]>], [3, 1, 1]>, 129 InstrItinData<IIC_iEXTAsr,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 130 InstrStage<3, [A9_ALU0, A9_ALU1]>], [3, 1, 1, 1]>, 131 // 132 // Compare instructions 133 InstrItinData<IIC_iCMPi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 134 InstrStage<1, [A9_ALU0, A9_ALU1]>], 135 [1], [A9_LdBypass]>, 136 InstrItinData<IIC_iCMPr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 137 InstrStage<1, [A9_ALU0, A9_ALU1]>], 138 [1, 1], [A9_LdBypass, A9_LdBypass]>, 139 InstrItinData<IIC_iCMPsi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 140 InstrStage<2, [A9_ALU0, A9_ALU1]>], 141 [1, 1], [A9_LdBypass, NoBypass]>, 142 InstrItinData<IIC_iCMPsr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 143 InstrStage<3, [A9_ALU0, A9_ALU1]>], 144 [1, 1, 1], [A9_LdBypass, NoBypass, NoBypass]>, 145 // 146 // Test instructions 147 InstrItinData<IIC_iTSTi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 148 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1]>, 149 InstrItinData<IIC_iTSTr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 150 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1]>, 151 InstrItinData<IIC_iTSTsi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 152 InstrStage<2, [A9_ALU0, A9_ALU1]>], [1, 1]>, 153 InstrItinData<IIC_iTSTsr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 154 InstrStage<3, [A9_ALU0, A9_ALU1]>], [1, 1, 1]>, 155 // 156 // Move instructions, conditional 157 // FIXME: Correctly model the extra input dep on the destination. 158 InstrItinData<IIC_iCMOVi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 159 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1]>, 160 InstrItinData<IIC_iCMOVr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 161 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1]>, 162 InstrItinData<IIC_iCMOVsi , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 163 InstrStage<1, [A9_ALU0, A9_ALU1]>], [1, 1]>, 164 InstrItinData<IIC_iCMOVsr , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 165 InstrStage<2, [A9_ALU0, A9_ALU1]>], [2, 1, 1]>, 166 InstrItinData<IIC_iCMOVix2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 167 InstrStage<1, [A9_ALU0, A9_ALU1]>, 168 InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 169 InstrStage<1, [A9_ALU0, A9_ALU1]>], [2]>, 170 171 // Integer multiply pipeline 172 // 173 InstrItinData<IIC_iMUL16 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 174 InstrStage<2, [A9_ALU0]>], [3, 1, 1]>, 175 InstrItinData<IIC_iMAC16 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 176 InstrStage<2, [A9_ALU0]>], 177 [3, 1, 1, 1]>, 178 InstrItinData<IIC_iMUL32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 179 InstrStage<2, [A9_ALU0]>], [4, 1, 1]>, 180 InstrItinData<IIC_iMAC32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 181 InstrStage<2, [A9_ALU0]>], 182 [4, 1, 1, 1]>, 183 InstrItinData<IIC_iMUL64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 184 InstrStage<3, [A9_ALU0]>], [4, 5, 1, 1]>, 185 InstrItinData<IIC_iMAC64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 186 InstrStage<3, [A9_ALU0]>], 187 [4, 5, 1, 1]>, 188 // Integer load pipeline 189 // FIXME: The timings are some rough approximations 190 // 191 // Immediate offset 192 InstrItinData<IIC_iLoad_i , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 193 InstrStage<1, [A9_MUX0], 0>, 194 InstrStage<1, [A9_AGU], 0>, 195 InstrStage<1, [A9_LSUnit]>], 196 [3, 1], [A9_LdBypass]>, 197 InstrItinData<IIC_iLoad_bh_i, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 198 InstrStage<1, [A9_MUX0], 0>, 199 InstrStage<2, [A9_AGU], 0>, 200 InstrStage<1, [A9_LSUnit]>], 201 [4, 1], [A9_LdBypass]>, 202 // FIXME: If address is 64-bit aligned, AGU cycles is 1. 203 InstrItinData<IIC_iLoad_d_i , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 204 InstrStage<1, [A9_MUX0], 0>, 205 InstrStage<2, [A9_AGU], 0>, 206 InstrStage<1, [A9_LSUnit]>], 207 [3, 3, 1], [A9_LdBypass]>, 208 // 209 // Register offset 210 InstrItinData<IIC_iLoad_r , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 211 InstrStage<1, [A9_MUX0], 0>, 212 InstrStage<1, [A9_AGU], 0>, 213 InstrStage<1, [A9_LSUnit]>], 214 [3, 1, 1], [A9_LdBypass]>, 215 InstrItinData<IIC_iLoad_bh_r, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 216 InstrStage<1, [A9_MUX0], 0>, 217 InstrStage<2, [A9_AGU], 0>, 218 InstrStage<1, [A9_LSUnit]>], 219 [4, 1, 1], [A9_LdBypass]>, 220 InstrItinData<IIC_iLoad_d_r , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 221 InstrStage<1, [A9_MUX0], 0>, 222 InstrStage<2, [A9_AGU], 0>, 223 InstrStage<1, [A9_LSUnit]>], 224 [3, 3, 1, 1], [A9_LdBypass]>, 225 // 226 // Scaled register offset 227 InstrItinData<IIC_iLoad_si , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 228 InstrStage<1, [A9_MUX0], 0>, 229 InstrStage<1, [A9_AGU], 0>, 230 InstrStage<1, [A9_LSUnit], 0>], 231 [4, 1, 1], [A9_LdBypass]>, 232 InstrItinData<IIC_iLoad_bh_si,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 233 InstrStage<1, [A9_MUX0], 0>, 234 InstrStage<2, [A9_AGU], 0>, 235 InstrStage<1, [A9_LSUnit]>], 236 [5, 1, 1], [A9_LdBypass]>, 237 // 238 // Immediate offset with update 239 InstrItinData<IIC_iLoad_iu , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 240 InstrStage<1, [A9_MUX0], 0>, 241 InstrStage<1, [A9_AGU], 0>, 242 InstrStage<1, [A9_LSUnit]>], 243 [3, 2, 1], [A9_LdBypass]>, 244 InstrItinData<IIC_iLoad_bh_iu,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 245 InstrStage<1, [A9_MUX0], 0>, 246 InstrStage<2, [A9_AGU], 0>, 247 InstrStage<1, [A9_LSUnit]>], 248 [4, 3, 1], [A9_LdBypass]>, 249 // 250 // Register offset with update 251 InstrItinData<IIC_iLoad_ru , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 252 InstrStage<1, [A9_MUX0], 0>, 253 InstrStage<1, [A9_AGU], 0>, 254 InstrStage<1, [A9_LSUnit]>], 255 [3, 2, 1, 1], [A9_LdBypass]>, 256 InstrItinData<IIC_iLoad_bh_ru,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 257 InstrStage<1, [A9_MUX0], 0>, 258 InstrStage<2, [A9_AGU], 0>, 259 InstrStage<1, [A9_LSUnit]>], 260 [4, 3, 1, 1], [A9_LdBypass]>, 261 InstrItinData<IIC_iLoad_d_ru, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 262 InstrStage<1, [A9_MUX0], 0>, 263 InstrStage<2, [A9_AGU], 0>, 264 InstrStage<1, [A9_LSUnit]>], 265 [3, 3, 1, 1], [A9_LdBypass]>, 266 // 267 // Scaled register offset with update 268 InstrItinData<IIC_iLoad_siu , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 269 InstrStage<1, [A9_MUX0], 0>, 270 InstrStage<1, [A9_AGU], 0>, 271 InstrStage<1, [A9_LSUnit]>], 272 [4, 3, 1, 1], [A9_LdBypass]>, 273 InstrItinData<IIC_iLoad_bh_siu,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 274 InstrStage<1, [A9_MUX0], 0>, 275 InstrStage<2, [A9_AGU], 0>, 276 InstrStage<1, [A9_LSUnit]>], 277 [5, 4, 1, 1], [A9_LdBypass]>, 278 // 279 // Load multiple, def is the 5th operand. 280 // FIXME: This assumes 3 to 4 registers. 281 InstrItinData<IIC_iLoad_m , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 282 InstrStage<1, [A9_MUX0], 0>, 283 InstrStage<2, [A9_AGU], 1>, 284 InstrStage<2, [A9_LSUnit]>], 285 [1, 1, 1, 1, 3], 286 [NoBypass, NoBypass, NoBypass, NoBypass, A9_LdBypass], 287 -1>, // dynamic uops 288 // 289 // Load multiple + update, defs are the 1st and 5th operands. 290 InstrItinData<IIC_iLoad_mu , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 291 InstrStage<1, [A9_MUX0], 0>, 292 InstrStage<2, [A9_AGU], 1>, 293 InstrStage<2, [A9_LSUnit]>], 294 [2, 1, 1, 1, 3], 295 [NoBypass, NoBypass, NoBypass, NoBypass, A9_LdBypass], 296 -1>, // dynamic uops 297 // 298 // Load multiple plus branch 299 InstrItinData<IIC_iLoad_mBr, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 300 InstrStage<1, [A9_MUX0], 0>, 301 InstrStage<1, [A9_AGU], 1>, 302 InstrStage<2, [A9_LSUnit]>, 303 InstrStage<1, [A9_Branch]>], 304 [1, 2, 1, 1, 3], 305 [NoBypass, NoBypass, NoBypass, NoBypass, A9_LdBypass], 306 -1>, // dynamic uops 307 // 308 // Pop, def is the 3rd operand. 309 InstrItinData<IIC_iPop , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 310 InstrStage<1, [A9_MUX0], 0>, 311 InstrStage<2, [A9_AGU], 1>, 312 InstrStage<2, [A9_LSUnit]>], 313 [1, 1, 3], 314 [NoBypass, NoBypass, A9_LdBypass], 315 -1>, // dynamic uops 316 // 317 // Pop + branch, def is the 3rd operand. 318 InstrItinData<IIC_iPop_Br, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 319 InstrStage<1, [A9_MUX0], 0>, 320 InstrStage<2, [A9_AGU], 1>, 321 InstrStage<2, [A9_LSUnit]>, 322 InstrStage<1, [A9_Branch]>], 323 [1, 1, 3], 324 [NoBypass, NoBypass, A9_LdBypass], 325 -1>, // dynamic uops 326 // 327 // iLoadi + iALUr for t2LDRpci_pic. 328 InstrItinData<IIC_iLoadiALU, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 329 InstrStage<1, [A9_MUX0], 0>, 330 InstrStage<1, [A9_AGU], 0>, 331 InstrStage<1, [A9_LSUnit]>, 332 InstrStage<1, [A9_ALU0, A9_ALU1]>], 333 [2, 1]>, 334 335 // Integer store pipeline 336 /// 337 // Immediate offset 338 InstrItinData<IIC_iStore_i , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 339 InstrStage<1, [A9_MUX0], 0>, 340 InstrStage<1, [A9_AGU], 0>, 341 InstrStage<1, [A9_LSUnit]>], [1, 1]>, 342 InstrItinData<IIC_iStore_bh_i,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 343 InstrStage<1, [A9_MUX0], 0>, 344 InstrStage<2, [A9_AGU], 1>, 345 InstrStage<1, [A9_LSUnit]>], [1, 1]>, 346 // FIXME: If address is 64-bit aligned, AGU cycles is 1. 347 InstrItinData<IIC_iStore_d_i, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 348 InstrStage<1, [A9_MUX0], 0>, 349 InstrStage<2, [A9_AGU], 1>, 350 InstrStage<1, [A9_LSUnit]>], [1, 1]>, 351 // 352 // Register offset 353 InstrItinData<IIC_iStore_r , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 354 InstrStage<1, [A9_MUX0], 0>, 355 InstrStage<1, [A9_AGU], 0>, 356 InstrStage<1, [A9_LSUnit]>], [1, 1, 1]>, 357 InstrItinData<IIC_iStore_bh_r,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 358 InstrStage<1, [A9_MUX0], 0>, 359 InstrStage<2, [A9_AGU], 1>, 360 InstrStage<1, [A9_LSUnit]>], [1, 1, 1]>, 361 InstrItinData<IIC_iStore_d_r, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 362 InstrStage<1, [A9_MUX0], 0>, 363 InstrStage<2, [A9_AGU], 1>, 364 InstrStage<1, [A9_LSUnit]>], [1, 1, 1]>, 365 // 366 // Scaled register offset 367 InstrItinData<IIC_iStore_si , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 368 InstrStage<1, [A9_MUX0], 0>, 369 InstrStage<1, [A9_AGU], 0>, 370 InstrStage<1, [A9_LSUnit]>], [1, 1, 1]>, 371 InstrItinData<IIC_iStore_bh_si,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 372 InstrStage<1, [A9_MUX0], 0>, 373 InstrStage<2, [A9_AGU], 1>, 374 InstrStage<1, [A9_LSUnit]>], [1, 1, 1]>, 375 // 376 // Immediate offset with update 377 InstrItinData<IIC_iStore_iu , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 378 InstrStage<1, [A9_MUX0], 0>, 379 InstrStage<1, [A9_AGU], 0>, 380 InstrStage<1, [A9_LSUnit]>], [2, 1, 1]>, 381 InstrItinData<IIC_iStore_bh_iu,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 382 InstrStage<1, [A9_MUX0], 0>, 383 InstrStage<2, [A9_AGU], 1>, 384 InstrStage<1, [A9_LSUnit]>], [3, 1, 1]>, 385 // 386 // Register offset with update 387 InstrItinData<IIC_iStore_ru , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 388 InstrStage<1, [A9_MUX0], 0>, 389 InstrStage<1, [A9_AGU], 0>, 390 InstrStage<1, [A9_LSUnit]>], 391 [2, 1, 1, 1]>, 392 InstrItinData<IIC_iStore_bh_ru,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 393 InstrStage<1, [A9_MUX0], 0>, 394 InstrStage<2, [A9_AGU], 1>, 395 InstrStage<1, [A9_LSUnit]>], 396 [3, 1, 1, 1]>, 397 InstrItinData<IIC_iStore_d_ru, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 398 InstrStage<1, [A9_MUX0], 0>, 399 InstrStage<2, [A9_AGU], 1>, 400 InstrStage<1, [A9_LSUnit]>], 401 [3, 1, 1, 1]>, 402 // 403 // Scaled register offset with update 404 InstrItinData<IIC_iStore_siu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 405 InstrStage<1, [A9_MUX0], 0>, 406 InstrStage<1, [A9_AGU], 0>, 407 InstrStage<1, [A9_LSUnit]>], 408 [2, 1, 1, 1]>, 409 InstrItinData<IIC_iStore_bh_siu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 410 InstrStage<1, [A9_MUX0], 0>, 411 InstrStage<2, [A9_AGU], 1>, 412 InstrStage<1, [A9_LSUnit]>], 413 [3, 1, 1, 1]>, 414 // 415 // Store multiple 416 InstrItinData<IIC_iStore_m , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 417 InstrStage<1, [A9_MUX0], 0>, 418 InstrStage<1, [A9_AGU], 0>, 419 InstrStage<2, [A9_LSUnit]>], 420 [], [], -1>, // dynamic uops 421 // 422 // Store multiple + update 423 InstrItinData<IIC_iStore_mu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 424 InstrStage<1, [A9_MUX0], 0>, 425 InstrStage<1, [A9_AGU], 0>, 426 InstrStage<2, [A9_LSUnit]>], 427 [2], [], -1>, // dynamic uops 428 // 429 // Preload 430 InstrItinData<IIC_Preload, [InstrStage<1, [A9_Issue0, A9_Issue1]>], [1, 1]>, 431 432 // Branch 433 // 434 // no delay slots, so the latency of a branch is unimportant 435 InstrItinData<IIC_Br , [InstrStage<1, [A9_Issue0], 0>, 436 InstrStage<1, [A9_Issue1], 0>, 437 InstrStage<1, [A9_Branch]>]>, 438 439 // VFP and NEON shares the same register file. This means that every VFP 440 // instruction should wait for full completion of the consecutive NEON 441 // instruction and vice-versa. We model this behavior with two artificial FUs: 442 // DRegsVFP and DRegsVFP. 443 // 444 // Every VFP instruction: 445 // - Acquires DRegsVFP resource for 1 cycle 446 // - Reserves DRegsN resource for the whole duration (including time to 447 // register file writeback!). 448 // Every NEON instruction does the same but with FUs swapped. 449 // 450 // Since the reserved FU cannot be acquired, this models precisely 451 // "cross-domain" stalls. 452 453 // VFP 454 // Issue through integer pipeline, and execute in NEON unit. 455 456 // FP Special Register to Integer Register File Move 457 InstrItinData<IIC_fpSTAT , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 458 InstrStage<1, [A9_MUX0], 0>, 459 InstrStage<1, [A9_DRegsVFP], 0, Required>, 460 InstrStage<2, [A9_DRegsN], 0, Reserved>, 461 InstrStage<1, [A9_NPipe]>], 462 [1]>, 463 // 464 // Single-precision FP Unary 465 InstrItinData<IIC_fpUNA32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 466 InstrStage<1, [A9_MUX0], 0>, 467 InstrStage<1, [A9_DRegsVFP], 0, Required>, 468 // Extra latency cycles since wbck is 2 cycles 469 InstrStage<3, [A9_DRegsN], 0, Reserved>, 470 InstrStage<1, [A9_NPipe]>], 471 [1, 1]>, 472 // 473 // Double-precision FP Unary 474 InstrItinData<IIC_fpUNA64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 475 InstrStage<1, [A9_MUX0], 0>, 476 InstrStage<1, [A9_DRegsVFP], 0, Required>, 477 // Extra latency cycles since wbck is 2 cycles 478 InstrStage<3, [A9_DRegsN], 0, Reserved>, 479 InstrStage<1, [A9_NPipe]>], 480 [1, 1]>, 481 482 // 483 // Single-precision FP Compare 484 InstrItinData<IIC_fpCMP32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 485 InstrStage<1, [A9_MUX0], 0>, 486 InstrStage<1, [A9_DRegsVFP], 0, Required>, 487 // Extra latency cycles since wbck is 4 cycles 488 InstrStage<5, [A9_DRegsN], 0, Reserved>, 489 InstrStage<1, [A9_NPipe]>], 490 [1, 1]>, 491 // 492 // Double-precision FP Compare 493 InstrItinData<IIC_fpCMP64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 494 InstrStage<1, [A9_MUX0], 0>, 495 InstrStage<1, [A9_DRegsVFP], 0, Required>, 496 // Extra latency cycles since wbck is 4 cycles 497 InstrStage<5, [A9_DRegsN], 0, Reserved>, 498 InstrStage<1, [A9_NPipe]>], 499 [1, 1]>, 500 // 501 // Single to Double FP Convert 502 InstrItinData<IIC_fpCVTSD , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 503 InstrStage<1, [A9_MUX0], 0>, 504 InstrStage<1, [A9_DRegsVFP], 0, Required>, 505 InstrStage<5, [A9_DRegsN], 0, Reserved>, 506 InstrStage<1, [A9_NPipe]>], 507 [4, 1]>, 508 // 509 // Double to Single FP Convert 510 InstrItinData<IIC_fpCVTDS , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 511 InstrStage<1, [A9_MUX0], 0>, 512 InstrStage<1, [A9_DRegsVFP], 0, Required>, 513 InstrStage<5, [A9_DRegsN], 0, Reserved>, 514 InstrStage<1, [A9_NPipe]>], 515 [4, 1]>, 516 517 // 518 // Single to Half FP Convert 519 InstrItinData<IIC_fpCVTSH , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 520 InstrStage<1, [A9_MUX0], 0>, 521 InstrStage<1, [A9_DRegsVFP], 0, Required>, 522 InstrStage<5, [A9_DRegsN], 0, Reserved>, 523 InstrStage<1, [A9_NPipe]>], 524 [4, 1]>, 525 // 526 // Half to Single FP Convert 527 InstrItinData<IIC_fpCVTHS , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 528 InstrStage<1, [A9_MUX0], 0>, 529 InstrStage<1, [A9_DRegsVFP], 0, Required>, 530 InstrStage<3, [A9_DRegsN], 0, Reserved>, 531 InstrStage<1, [A9_NPipe]>], 532 [2, 1]>, 533 534 // 535 // Single-Precision FP to Integer Convert 536 InstrItinData<IIC_fpCVTSI , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 537 InstrStage<1, [A9_MUX0], 0>, 538 InstrStage<1, [A9_DRegsVFP], 0, Required>, 539 InstrStage<5, [A9_DRegsN], 0, Reserved>, 540 InstrStage<1, [A9_NPipe]>], 541 [4, 1]>, 542 // 543 // Double-Precision FP to Integer Convert 544 InstrItinData<IIC_fpCVTDI , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 545 InstrStage<1, [A9_MUX0], 0>, 546 InstrStage<1, [A9_DRegsVFP], 0, Required>, 547 InstrStage<5, [A9_DRegsN], 0, Reserved>, 548 InstrStage<1, [A9_NPipe]>], 549 [4, 1]>, 550 // 551 // Integer to Single-Precision FP Convert 552 InstrItinData<IIC_fpCVTIS , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 553 InstrStage<1, [A9_MUX0], 0>, 554 InstrStage<1, [A9_DRegsVFP], 0, Required>, 555 InstrStage<5, [A9_DRegsN], 0, Reserved>, 556 InstrStage<1, [A9_NPipe]>], 557 [4, 1]>, 558 // 559 // Integer to Double-Precision FP Convert 560 InstrItinData<IIC_fpCVTID , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 561 InstrStage<1, [A9_MUX0], 0>, 562 InstrStage<1, [A9_DRegsVFP], 0, Required>, 563 InstrStage<5, [A9_DRegsN], 0, Reserved>, 564 InstrStage<1, [A9_NPipe]>], 565 [4, 1]>, 566 // 567 // Single-precision FP ALU 568 InstrItinData<IIC_fpALU32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 569 InstrStage<1, [A9_MUX0], 0>, 570 InstrStage<1, [A9_DRegsVFP], 0, Required>, 571 InstrStage<5, [A9_DRegsN], 0, Reserved>, 572 InstrStage<1, [A9_NPipe]>], 573 [4, 1, 1]>, 574 // 575 // Double-precision FP ALU 576 InstrItinData<IIC_fpALU64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 577 InstrStage<1, [A9_MUX0], 0>, 578 InstrStage<1, [A9_DRegsVFP], 0, Required>, 579 InstrStage<5, [A9_DRegsN], 0, Reserved>, 580 InstrStage<1, [A9_NPipe]>], 581 [4, 1, 1]>, 582 // 583 // Single-precision FP Multiply 584 InstrItinData<IIC_fpMUL32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 585 InstrStage<1, [A9_MUX0], 0>, 586 InstrStage<1, [A9_DRegsVFP], 0, Required>, 587 InstrStage<6, [A9_DRegsN], 0, Reserved>, 588 InstrStage<1, [A9_NPipe]>], 589 [5, 1, 1]>, 590 // 591 // Double-precision FP Multiply 592 InstrItinData<IIC_fpMUL64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 593 InstrStage<1, [A9_MUX0], 0>, 594 InstrStage<1, [A9_DRegsVFP], 0, Required>, 595 InstrStage<7, [A9_DRegsN], 0, Reserved>, 596 InstrStage<2, [A9_NPipe]>], 597 [6, 1, 1]>, 598 // 599 // Single-precision FP MAC 600 InstrItinData<IIC_fpMAC32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 601 InstrStage<1, [A9_MUX0], 0>, 602 InstrStage<1, [A9_DRegsVFP], 0, Required>, 603 InstrStage<9, [A9_DRegsN], 0, Reserved>, 604 InstrStage<1, [A9_NPipe]>], 605 [8, 1, 1, 1]>, 606 // 607 // Double-precision FP MAC 608 InstrItinData<IIC_fpMAC64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 609 InstrStage<1, [A9_MUX0], 0>, 610 InstrStage<1, [A9_DRegsVFP], 0, Required>, 611 InstrStage<10, [A9_DRegsN], 0, Reserved>, 612 InstrStage<2, [A9_NPipe]>], 613 [9, 1, 1, 1]>, 614 // 615 // Single-precision Fused FP MAC 616 InstrItinData<IIC_fpFMAC32, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 617 InstrStage<1, [A9_MUX0], 0>, 618 InstrStage<1, [A9_DRegsVFP], 0, Required>, 619 InstrStage<9, [A9_DRegsN], 0, Reserved>, 620 InstrStage<1, [A9_NPipe]>], 621 [8, 1, 1, 1]>, 622 // 623 // Double-precision Fused FP MAC 624 InstrItinData<IIC_fpFMAC64, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 625 InstrStage<1, [A9_MUX0], 0>, 626 InstrStage<1, [A9_DRegsVFP], 0, Required>, 627 InstrStage<10, [A9_DRegsN], 0, Reserved>, 628 InstrStage<2, [A9_NPipe]>], 629 [9, 1, 1, 1]>, 630 // 631 // Single-precision FP DIV 632 InstrItinData<IIC_fpDIV32 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 633 InstrStage<1, [A9_MUX0], 0>, 634 InstrStage<1, [A9_DRegsVFP], 0, Required>, 635 InstrStage<16, [A9_DRegsN], 0, Reserved>, 636 InstrStage<10, [A9_NPipe]>], 637 [15, 1, 1]>, 638 // 639 // Double-precision FP DIV 640 InstrItinData<IIC_fpDIV64 , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 641 InstrStage<1, [A9_MUX0], 0>, 642 InstrStage<1, [A9_DRegsVFP], 0, Required>, 643 InstrStage<26, [A9_DRegsN], 0, Reserved>, 644 InstrStage<20, [A9_NPipe]>], 645 [25, 1, 1]>, 646 // 647 // Single-precision FP SQRT 648 InstrItinData<IIC_fpSQRT32, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 649 InstrStage<1, [A9_MUX0], 0>, 650 InstrStage<1, [A9_DRegsVFP], 0, Required>, 651 InstrStage<18, [A9_DRegsN], 0, Reserved>, 652 InstrStage<13, [A9_NPipe]>], 653 [17, 1]>, 654 // 655 // Double-precision FP SQRT 656 InstrItinData<IIC_fpSQRT64, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 657 InstrStage<1, [A9_MUX0], 0>, 658 InstrStage<1, [A9_DRegsVFP], 0, Required>, 659 InstrStage<33, [A9_DRegsN], 0, Reserved>, 660 InstrStage<28, [A9_NPipe]>], 661 [32, 1]>, 662 663 // 664 // Integer to Single-precision Move 665 InstrItinData<IIC_fpMOVIS, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 666 InstrStage<1, [A9_MUX0], 0>, 667 InstrStage<1, [A9_DRegsVFP], 0, Required>, 668 // Extra 1 latency cycle since wbck is 2 cycles 669 InstrStage<3, [A9_DRegsN], 0, Reserved>, 670 InstrStage<1, [A9_NPipe]>], 671 [1, 1]>, 672 // 673 // Integer to Double-precision Move 674 InstrItinData<IIC_fpMOVID, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 675 InstrStage<1, [A9_MUX0], 0>, 676 InstrStage<1, [A9_DRegsVFP], 0, Required>, 677 // Extra 1 latency cycle since wbck is 2 cycles 678 InstrStage<3, [A9_DRegsN], 0, Reserved>, 679 InstrStage<1, [A9_NPipe]>], 680 [1, 1, 1]>, 681 // 682 // Single-precision to Integer Move 683 // 684 // On A9 move-from-VFP is free to issue with no stall if other VFP 685 // operations are in flight. I assume it still can't dual-issue though. 686 InstrItinData<IIC_fpMOVSI, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 687 InstrStage<1, [A9_MUX0], 0>], 688 [2, 1]>, 689 // 690 // Double-precision to Integer Move 691 // 692 // On A9 move-from-VFP is free to issue with no stall if other VFP 693 // operations are in flight. I assume it still can't dual-issue though. 694 InstrItinData<IIC_fpMOVDI, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 695 InstrStage<1, [A9_MUX0], 0>], 696 [2, 1, 1]>, 697 // 698 // Single-precision FP Load 699 InstrItinData<IIC_fpLoad32, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 700 InstrStage<1, [A9_MUX0], 0>, 701 InstrStage<1, [A9_DRegsVFP], 0, Required>, 702 InstrStage<2, [A9_DRegsN], 0, Reserved>, 703 InstrStage<1, [A9_NPipe], 0>, 704 InstrStage<1, [A9_LSUnit]>], 705 [1, 1]>, 706 // 707 // Double-precision FP Load 708 // FIXME: Result latency is 1 if address is 64-bit aligned. 709 InstrItinData<IIC_fpLoad64, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 710 InstrStage<1, [A9_MUX0], 0>, 711 InstrStage<1, [A9_DRegsVFP], 0, Required>, 712 InstrStage<2, [A9_DRegsN], 0, Reserved>, 713 InstrStage<1, [A9_NPipe], 0>, 714 InstrStage<1, [A9_LSUnit]>], 715 [2, 1]>, 716 // 717 // FP Load Multiple 718 // FIXME: assumes 2 doubles which requires 2 LS cycles. 719 InstrItinData<IIC_fpLoad_m, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 720 InstrStage<1, [A9_MUX0], 0>, 721 InstrStage<1, [A9_DRegsVFP], 0, Required>, 722 InstrStage<2, [A9_DRegsN], 0, Reserved>, 723 InstrStage<1, [A9_NPipe], 0>, 724 InstrStage<2, [A9_LSUnit]>], 725 [1, 1, 1, 1], [], -1>, // dynamic uops 726 // 727 // FP Load Multiple + update 728 // FIXME: assumes 2 doubles which requires 2 LS cycles. 729 InstrItinData<IIC_fpLoad_mu,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 730 InstrStage<1, [A9_MUX0], 0>, 731 InstrStage<1, [A9_DRegsVFP], 0, Required>, 732 InstrStage<2, [A9_DRegsN], 0, Reserved>, 733 InstrStage<1, [A9_NPipe], 0>, 734 InstrStage<2, [A9_LSUnit]>], 735 [2, 1, 1, 1], [], -1>, // dynamic uops 736 // 737 // Single-precision FP Store 738 InstrItinData<IIC_fpStore32,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 739 InstrStage<1, [A9_MUX0], 0>, 740 InstrStage<1, [A9_DRegsVFP], 0, Required>, 741 InstrStage<2, [A9_DRegsN], 0, Reserved>, 742 InstrStage<1, [A9_NPipe], 0>, 743 InstrStage<1, [A9_LSUnit]>], 744 [1, 1]>, 745 // 746 // Double-precision FP Store 747 InstrItinData<IIC_fpStore64,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 748 InstrStage<1, [A9_MUX0], 0>, 749 InstrStage<1, [A9_DRegsVFP], 0, Required>, 750 InstrStage<2, [A9_DRegsN], 0, Reserved>, 751 InstrStage<1, [A9_NPipe], 0>, 752 InstrStage<1, [A9_LSUnit]>], 753 [1, 1]>, 754 // 755 // FP Store Multiple 756 // FIXME: assumes 2 doubles which requires 2 LS cycles. 757 InstrItinData<IIC_fpStore_m,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 758 InstrStage<1, [A9_MUX0], 0>, 759 InstrStage<1, [A9_DRegsVFP], 0, Required>, 760 InstrStage<2, [A9_DRegsN], 0, Reserved>, 761 InstrStage<1, [A9_NPipe], 0>, 762 InstrStage<2, [A9_LSUnit]>], 763 [1, 1, 1, 1], [], -1>, // dynamic uops 764 // 765 // FP Store Multiple + update 766 // FIXME: assumes 2 doubles which requires 2 LS cycles. 767 InstrItinData<IIC_fpStore_mu,[InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 768 InstrStage<1, [A9_MUX0], 0>, 769 InstrStage<1, [A9_DRegsVFP], 0, Required>, 770 InstrStage<2, [A9_DRegsN], 0, Reserved>, 771 InstrStage<1, [A9_NPipe], 0>, 772 InstrStage<2, [A9_LSUnit]>], 773 [2, 1, 1, 1], [], -1>, // dynamic uops 774 // NEON 775 // VLD1 776 InstrItinData<IIC_VLD1, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 777 InstrStage<1, [A9_MUX0], 0>, 778 InstrStage<1, [A9_DRegsN], 0, Required>, 779 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 780 InstrStage<1, [A9_NPipe], 0>, 781 InstrStage<1, [A9_LSUnit]>], 782 [1, 1]>, 783 // VLD1x2 784 InstrItinData<IIC_VLD1x2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 785 InstrStage<1, [A9_MUX0], 0>, 786 InstrStage<1, [A9_DRegsN], 0, Required>, 787 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 788 InstrStage<1, [A9_NPipe], 0>, 789 InstrStage<1, [A9_LSUnit]>], 790 [1, 1, 1]>, 791 // VLD1x3 792 InstrItinData<IIC_VLD1x3, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 793 InstrStage<1, [A9_MUX0], 0>, 794 InstrStage<1, [A9_DRegsN], 0, Required>, 795 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 796 InstrStage<2, [A9_NPipe], 0>, 797 InstrStage<2, [A9_LSUnit]>], 798 [1, 1, 2, 1]>, 799 // VLD1x4 800 InstrItinData<IIC_VLD1x4, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 801 InstrStage<1, [A9_MUX0], 0>, 802 InstrStage<1, [A9_DRegsN], 0, Required>, 803 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 804 InstrStage<2, [A9_NPipe], 0>, 805 InstrStage<2, [A9_LSUnit]>], 806 [1, 1, 2, 2, 1]>, 807 // VLD1u 808 InstrItinData<IIC_VLD1u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 809 InstrStage<1, [A9_MUX0], 0>, 810 InstrStage<1, [A9_DRegsN], 0, Required>, 811 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 812 InstrStage<1, [A9_NPipe], 0>, 813 InstrStage<1, [A9_LSUnit]>], 814 [1, 2, 1]>, 815 // VLD1x2u 816 InstrItinData<IIC_VLD1x2u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 817 InstrStage<1, [A9_MUX0], 0>, 818 InstrStage<1, [A9_DRegsN], 0, Required>, 819 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 820 InstrStage<1, [A9_NPipe], 0>, 821 InstrStage<1, [A9_LSUnit]>], 822 [1, 1, 2, 1]>, 823 // VLD1x3u 824 InstrItinData<IIC_VLD1x3u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 825 InstrStage<1, [A9_MUX0], 0>, 826 InstrStage<1, [A9_DRegsN], 0, Required>, 827 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 828 InstrStage<2, [A9_NPipe], 0>, 829 InstrStage<2, [A9_LSUnit]>], 830 [1, 1, 2, 2, 1]>, 831 // VLD1x4u 832 InstrItinData<IIC_VLD1x4u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 833 InstrStage<1, [A9_MUX0], 0>, 834 InstrStage<1, [A9_DRegsN], 0, Required>, 835 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 836 InstrStage<2, [A9_NPipe], 0>, 837 InstrStage<2, [A9_LSUnit]>], 838 [1, 1, 2, 2, 2, 1]>, 839 // 840 // VLD1ln 841 InstrItinData<IIC_VLD1ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 842 InstrStage<1, [A9_MUX0], 0>, 843 InstrStage<1, [A9_DRegsN], 0, Required>, 844 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 845 InstrStage<2, [A9_NPipe], 0>, 846 InstrStage<2, [A9_LSUnit]>], 847 [3, 1, 1, 1]>, 848 // 849 // VLD1lnu 850 InstrItinData<IIC_VLD1lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 851 InstrStage<1, [A9_MUX0], 0>, 852 InstrStage<1, [A9_DRegsN], 0, Required>, 853 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 854 InstrStage<2, [A9_NPipe], 0>, 855 InstrStage<2, [A9_LSUnit]>], 856 [3, 2, 1, 1, 1, 1]>, 857 // 858 // VLD1dup 859 InstrItinData<IIC_VLD1dup, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 860 InstrStage<1, [A9_MUX0], 0>, 861 InstrStage<1, [A9_DRegsN], 0, Required>, 862 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 863 InstrStage<1, [A9_NPipe], 0>, 864 InstrStage<1, [A9_LSUnit]>], 865 [2, 1]>, 866 // 867 // VLD1dupu 868 InstrItinData<IIC_VLD1dupu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 869 InstrStage<1, [A9_MUX0], 0>, 870 InstrStage<1, [A9_DRegsN], 0, Required>, 871 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 872 InstrStage<1, [A9_NPipe], 0>, 873 InstrStage<1, [A9_LSUnit]>], 874 [2, 2, 1, 1]>, 875 // 876 // VLD2 877 InstrItinData<IIC_VLD2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 878 InstrStage<1, [A9_MUX0], 0>, 879 InstrStage<1, [A9_DRegsN], 0, Required>, 880 // Extra latency cycles since wbck is 7 cycles 881 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 882 InstrStage<1, [A9_NPipe], 0>, 883 InstrStage<1, [A9_LSUnit]>], 884 [2, 2, 1]>, 885 // 886 // VLD2x2 887 InstrItinData<IIC_VLD2x2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 888 InstrStage<1, [A9_MUX0], 0>, 889 InstrStage<1, [A9_DRegsN], 0, Required>, 890 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 891 InstrStage<2, [A9_NPipe], 0>, 892 InstrStage<2, [A9_LSUnit]>], 893 [2, 3, 2, 3, 1]>, 894 // 895 // VLD2ln 896 InstrItinData<IIC_VLD2ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 897 InstrStage<1, [A9_MUX0], 0>, 898 InstrStage<1, [A9_DRegsN], 0, Required>, 899 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 900 InstrStage<2, [A9_NPipe], 0>, 901 InstrStage<2, [A9_LSUnit]>], 902 [3, 3, 1, 1, 1, 1]>, 903 // 904 // VLD2u 905 InstrItinData<IIC_VLD2u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 906 InstrStage<1, [A9_MUX0], 0>, 907 InstrStage<1, [A9_DRegsN], 0, Required>, 908 // Extra latency cycles since wbck is 7 cycles 909 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 910 InstrStage<1, [A9_NPipe], 0>, 911 InstrStage<1, [A9_LSUnit]>], 912 [2, 2, 2, 1, 1, 1]>, 913 // 914 // VLD2x2u 915 InstrItinData<IIC_VLD2x2u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 916 InstrStage<1, [A9_MUX0], 0>, 917 InstrStage<1, [A9_DRegsN], 0, Required>, 918 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 919 InstrStage<2, [A9_NPipe], 0>, 920 InstrStage<2, [A9_LSUnit]>], 921 [2, 3, 2, 3, 2, 1]>, 922 // 923 // VLD2lnu 924 InstrItinData<IIC_VLD2lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 925 InstrStage<1, [A9_MUX0], 0>, 926 InstrStage<1, [A9_DRegsN], 0, Required>, 927 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 928 InstrStage<2, [A9_NPipe], 0>, 929 InstrStage<2, [A9_LSUnit]>], 930 [3, 3, 2, 1, 1, 1, 1, 1]>, 931 // 932 // VLD2dup 933 InstrItinData<IIC_VLD2dup, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 934 InstrStage<1, [A9_MUX0], 0>, 935 InstrStage<1, [A9_DRegsN], 0, Required>, 936 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 937 InstrStage<1, [A9_NPipe], 0>, 938 InstrStage<1, [A9_LSUnit]>], 939 [2, 2, 1]>, 940 // 941 // VLD2dupu 942 InstrItinData<IIC_VLD2dupu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 943 InstrStage<1, [A9_MUX0], 0>, 944 InstrStage<1, [A9_DRegsN], 0, Required>, 945 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 946 InstrStage<1, [A9_NPipe], 0>, 947 InstrStage<1, [A9_LSUnit]>], 948 [2, 2, 2, 1, 1]>, 949 // 950 // VLD3 951 InstrItinData<IIC_VLD3, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 952 InstrStage<1, [A9_MUX0], 0>, 953 InstrStage<1, [A9_DRegsN], 0, Required>, 954 InstrStage<9,[A9_DRegsVFP], 0, Reserved>, 955 InstrStage<3, [A9_NPipe], 0>, 956 InstrStage<3, [A9_LSUnit]>], 957 [3, 3, 4, 1]>, 958 // 959 // VLD3ln 960 InstrItinData<IIC_VLD3ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 961 InstrStage<1, [A9_MUX0], 0>, 962 InstrStage<1, [A9_DRegsN], 0, Required>, 963 InstrStage<11,[A9_DRegsVFP], 0, Reserved>, 964 InstrStage<5, [A9_NPipe], 0>, 965 InstrStage<5, [A9_LSUnit]>], 966 [5, 5, 6, 1, 1, 1, 1, 2]>, 967 // 968 // VLD3u 969 InstrItinData<IIC_VLD3u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 970 InstrStage<1, [A9_MUX0], 0>, 971 InstrStage<1, [A9_DRegsN], 0, Required>, 972 InstrStage<9,[A9_DRegsVFP], 0, Reserved>, 973 InstrStage<3, [A9_NPipe], 0>, 974 InstrStage<3, [A9_LSUnit]>], 975 [3, 3, 4, 2, 1]>, 976 // 977 // VLD3lnu 978 InstrItinData<IIC_VLD3lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 979 InstrStage<1, [A9_MUX0], 0>, 980 InstrStage<1, [A9_DRegsN], 0, Required>, 981 InstrStage<11,[A9_DRegsVFP], 0, Reserved>, 982 InstrStage<5, [A9_NPipe], 0>, 983 InstrStage<5, [A9_LSUnit]>], 984 [5, 5, 6, 2, 1, 1, 1, 1, 1, 2]>, 985 // 986 // VLD3dup 987 InstrItinData<IIC_VLD3dup, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 988 InstrStage<1, [A9_MUX0], 0>, 989 InstrStage<1, [A9_DRegsN], 0, Required>, 990 InstrStage<9, [A9_DRegsVFP], 0, Reserved>, 991 InstrStage<3, [A9_NPipe], 0>, 992 InstrStage<3, [A9_LSUnit]>], 993 [3, 3, 4, 1]>, 994 // 995 // VLD3dupu 996 InstrItinData<IIC_VLD3dupu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 997 InstrStage<1, [A9_MUX0], 0>, 998 InstrStage<1, [A9_DRegsN], 0, Required>, 999 InstrStage<9, [A9_DRegsVFP], 0, Reserved>, 1000 InstrStage<3, [A9_NPipe], 0>, 1001 InstrStage<3, [A9_LSUnit]>], 1002 [3, 3, 4, 2, 1, 1]>, 1003 // 1004 // VLD4 1005 InstrItinData<IIC_VLD4, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1006 InstrStage<1, [A9_MUX0], 0>, 1007 InstrStage<1, [A9_DRegsN], 0, Required>, 1008 InstrStage<9,[A9_DRegsVFP], 0, Reserved>, 1009 InstrStage<3, [A9_NPipe], 0>, 1010 InstrStage<3, [A9_LSUnit]>], 1011 [3, 3, 4, 4, 1]>, 1012 // 1013 // VLD4ln 1014 InstrItinData<IIC_VLD4ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1015 InstrStage<1, [A9_MUX0], 0>, 1016 InstrStage<1, [A9_DRegsN], 0, Required>, 1017 InstrStage<10,[A9_DRegsVFP], 0, Reserved>, 1018 InstrStage<4, [A9_NPipe], 0>, 1019 InstrStage<4, [A9_LSUnit]>], 1020 [4, 4, 5, 5, 1, 1, 1, 1, 2, 2]>, 1021 // 1022 // VLD4u 1023 InstrItinData<IIC_VLD4u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1024 InstrStage<1, [A9_MUX0], 0>, 1025 InstrStage<1, [A9_DRegsN], 0, Required>, 1026 InstrStage<9,[A9_DRegsVFP], 0, Reserved>, 1027 InstrStage<3, [A9_NPipe], 0>, 1028 InstrStage<3, [A9_LSUnit]>], 1029 [3, 3, 4, 4, 2, 1]>, 1030 // 1031 // VLD4lnu 1032 InstrItinData<IIC_VLD4lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1033 InstrStage<1, [A9_MUX0], 0>, 1034 InstrStage<1, [A9_DRegsN], 0, Required>, 1035 InstrStage<10,[A9_DRegsVFP], 0, Reserved>, 1036 InstrStage<4, [A9_NPipe], 0>, 1037 InstrStage<4, [A9_LSUnit]>], 1038 [4, 4, 5, 5, 2, 1, 1, 1, 1, 1, 2, 2]>, 1039 // 1040 // VLD4dup 1041 InstrItinData<IIC_VLD4dup, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1042 InstrStage<1, [A9_MUX0], 0>, 1043 InstrStage<1, [A9_DRegsN], 0, Required>, 1044 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1045 InstrStage<2, [A9_NPipe], 0>, 1046 InstrStage<2, [A9_LSUnit]>], 1047 [2, 2, 3, 3, 1]>, 1048 // 1049 // VLD4dupu 1050 InstrItinData<IIC_VLD4dupu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1051 InstrStage<1, [A9_MUX0], 0>, 1052 InstrStage<1, [A9_DRegsN], 0, Required>, 1053 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1054 InstrStage<2, [A9_NPipe], 0>, 1055 InstrStage<2, [A9_LSUnit]>], 1056 [2, 2, 3, 3, 2, 1, 1]>, 1057 // 1058 // VST1 1059 InstrItinData<IIC_VST1, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1060 InstrStage<1, [A9_MUX0], 0>, 1061 InstrStage<1, [A9_DRegsN], 0, Required>, 1062 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1063 InstrStage<1, [A9_NPipe], 0>, 1064 InstrStage<1, [A9_LSUnit]>], 1065 [1, 1, 1]>, 1066 // 1067 // VST1x2 1068 InstrItinData<IIC_VST1x2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1069 InstrStage<1, [A9_MUX0], 0>, 1070 InstrStage<1, [A9_DRegsN], 0, Required>, 1071 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1072 InstrStage<1, [A9_NPipe], 0>, 1073 InstrStage<1, [A9_LSUnit]>], 1074 [1, 1, 1, 1]>, 1075 // 1076 // VST1x3 1077 InstrItinData<IIC_VST1x3, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1078 InstrStage<1, [A9_MUX0], 0>, 1079 InstrStage<1, [A9_DRegsN], 0, Required>, 1080 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1081 InstrStage<2, [A9_NPipe], 0>, 1082 InstrStage<2, [A9_LSUnit]>], 1083 [1, 1, 1, 1, 2]>, 1084 // 1085 // VST1x4 1086 InstrItinData<IIC_VST1x4, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1087 InstrStage<1, [A9_MUX0], 0>, 1088 InstrStage<1, [A9_DRegsN], 0, Required>, 1089 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1090 InstrStage<2, [A9_NPipe], 0>, 1091 InstrStage<2, [A9_LSUnit]>], 1092 [1, 1, 1, 1, 2, 2]>, 1093 // 1094 // VST1u 1095 InstrItinData<IIC_VST1u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1096 InstrStage<1, [A9_MUX0], 0>, 1097 InstrStage<1, [A9_DRegsN], 0, Required>, 1098 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1099 InstrStage<1, [A9_NPipe], 0>, 1100 InstrStage<1, [A9_LSUnit]>], 1101 [2, 1, 1, 1, 1]>, 1102 // 1103 // VST1x2u 1104 InstrItinData<IIC_VST1x2u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1105 InstrStage<1, [A9_MUX0], 0>, 1106 InstrStage<1, [A9_DRegsN], 0, Required>, 1107 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1108 InstrStage<1, [A9_NPipe], 0>, 1109 InstrStage<1, [A9_LSUnit]>], 1110 [2, 1, 1, 1, 1, 1]>, 1111 // 1112 // VST1x3u 1113 InstrItinData<IIC_VST1x3u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1114 InstrStage<1, [A9_MUX0], 0>, 1115 InstrStage<1, [A9_DRegsN], 0, Required>, 1116 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1117 InstrStage<2, [A9_NPipe], 0>, 1118 InstrStage<2, [A9_LSUnit]>], 1119 [2, 1, 1, 1, 1, 1, 2]>, 1120 // 1121 // VST1x4u 1122 InstrItinData<IIC_VST1x4u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1123 InstrStage<1, [A9_MUX0], 0>, 1124 InstrStage<1, [A9_DRegsN], 0, Required>, 1125 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1126 InstrStage<2, [A9_NPipe], 0>, 1127 InstrStage<2, [A9_LSUnit]>], 1128 [2, 1, 1, 1, 1, 1, 2, 2]>, 1129 // 1130 // VST1ln 1131 InstrItinData<IIC_VST1ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1132 InstrStage<1, [A9_MUX0], 0>, 1133 InstrStage<1, [A9_DRegsN], 0, Required>, 1134 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1135 InstrStage<1, [A9_NPipe], 0>, 1136 InstrStage<1, [A9_LSUnit]>], 1137 [1, 1, 1]>, 1138 // 1139 // VST1lnu 1140 InstrItinData<IIC_VST1lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1141 InstrStage<1, [A9_MUX0], 0>, 1142 InstrStage<1, [A9_DRegsN], 0, Required>, 1143 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1144 InstrStage<1, [A9_NPipe], 0>, 1145 InstrStage<1, [A9_LSUnit]>], 1146 [2, 1, 1, 1, 1]>, 1147 // 1148 // VST2 1149 InstrItinData<IIC_VST2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1150 InstrStage<1, [A9_MUX0], 0>, 1151 InstrStage<1, [A9_DRegsN], 0, Required>, 1152 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1153 InstrStage<1, [A9_NPipe], 0>, 1154 InstrStage<1, [A9_LSUnit]>], 1155 [1, 1, 1, 1]>, 1156 // 1157 // VST2x2 1158 InstrItinData<IIC_VST2x2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1159 InstrStage<1, [A9_MUX0], 0>, 1160 InstrStage<1, [A9_DRegsN], 0, Required>, 1161 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1162 InstrStage<3, [A9_NPipe], 0>, 1163 InstrStage<3, [A9_LSUnit]>], 1164 [1, 1, 1, 1, 2, 2]>, 1165 // 1166 // VST2u 1167 InstrItinData<IIC_VST2u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1168 InstrStage<1, [A9_MUX0], 0>, 1169 InstrStage<1, [A9_DRegsN], 0, Required>, 1170 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1171 InstrStage<1, [A9_NPipe], 0>, 1172 InstrStage<1, [A9_LSUnit]>], 1173 [2, 1, 1, 1, 1, 1]>, 1174 // 1175 // VST2x2u 1176 InstrItinData<IIC_VST2x2u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1177 InstrStage<1, [A9_MUX0], 0>, 1178 InstrStage<1, [A9_DRegsN], 0, Required>, 1179 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1180 InstrStage<3, [A9_NPipe], 0>, 1181 InstrStage<3, [A9_LSUnit]>], 1182 [2, 1, 1, 1, 1, 1, 2, 2]>, 1183 // 1184 // VST2ln 1185 InstrItinData<IIC_VST2ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1186 InstrStage<1, [A9_MUX0], 0>, 1187 InstrStage<1, [A9_DRegsN], 0, Required>, 1188 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1189 InstrStage<1, [A9_NPipe], 0>, 1190 InstrStage<1, [A9_LSUnit]>], 1191 [1, 1, 1, 1]>, 1192 // 1193 // VST2lnu 1194 InstrItinData<IIC_VST2lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1195 InstrStage<1, [A9_MUX0], 0>, 1196 InstrStage<1, [A9_DRegsN], 0, Required>, 1197 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1198 InstrStage<1, [A9_NPipe], 0>, 1199 InstrStage<1, [A9_LSUnit]>], 1200 [2, 1, 1, 1, 1, 1]>, 1201 // 1202 // VST3 1203 InstrItinData<IIC_VST3, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1204 InstrStage<1, [A9_MUX0], 0>, 1205 InstrStage<1, [A9_DRegsN], 0, Required>, 1206 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1207 InstrStage<2, [A9_NPipe], 0>, 1208 InstrStage<2, [A9_LSUnit]>], 1209 [1, 1, 1, 1, 2]>, 1210 // 1211 // VST3u 1212 InstrItinData<IIC_VST3u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1213 InstrStage<1, [A9_MUX0], 0>, 1214 InstrStage<1, [A9_DRegsN], 0, Required>, 1215 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1216 InstrStage<2, [A9_NPipe], 0>, 1217 InstrStage<2, [A9_LSUnit]>], 1218 [2, 1, 1, 1, 1, 1, 2]>, 1219 // 1220 // VST3ln 1221 InstrItinData<IIC_VST3ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1222 InstrStage<1, [A9_MUX0], 0>, 1223 InstrStage<1, [A9_DRegsN], 0, Required>, 1224 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1225 InstrStage<3, [A9_NPipe], 0>, 1226 InstrStage<3, [A9_LSUnit]>], 1227 [1, 1, 1, 1, 2]>, 1228 // 1229 // VST3lnu 1230 InstrItinData<IIC_VST3lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1231 InstrStage<1, [A9_MUX0], 0>, 1232 InstrStage<1, [A9_DRegsN], 0, Required>, 1233 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1234 InstrStage<3, [A9_NPipe], 0>, 1235 InstrStage<3, [A9_LSUnit]>], 1236 [2, 1, 1, 1, 1, 1, 2]>, 1237 // 1238 // VST4 1239 InstrItinData<IIC_VST4, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1240 InstrStage<1, [A9_MUX0], 0>, 1241 InstrStage<1, [A9_DRegsN], 0, Required>, 1242 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1243 InstrStage<2, [A9_NPipe], 0>, 1244 InstrStage<2, [A9_LSUnit]>], 1245 [1, 1, 1, 1, 2, 2]>, 1246 // 1247 // VST4u 1248 InstrItinData<IIC_VST4u, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1249 InstrStage<1, [A9_MUX0], 0>, 1250 InstrStage<1, [A9_DRegsN], 0, Required>, 1251 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1252 InstrStage<2, [A9_NPipe], 0>, 1253 InstrStage<2, [A9_LSUnit]>], 1254 [2, 1, 1, 1, 1, 1, 2, 2]>, 1255 // 1256 // VST4ln 1257 InstrItinData<IIC_VST4ln, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1258 InstrStage<1, [A9_MUX0], 0>, 1259 InstrStage<1, [A9_DRegsN], 0, Required>, 1260 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1261 InstrStage<2, [A9_NPipe], 0>, 1262 InstrStage<2, [A9_LSUnit]>], 1263 [1, 1, 1, 1, 2, 2]>, 1264 // 1265 // VST4lnu 1266 InstrItinData<IIC_VST4lnu, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1267 InstrStage<1, [A9_MUX0], 0>, 1268 InstrStage<1, [A9_DRegsN], 0, Required>, 1269 InstrStage<2, [A9_DRegsVFP], 0, Reserved>, 1270 InstrStage<2, [A9_NPipe], 0>, 1271 InstrStage<2, [A9_LSUnit]>], 1272 [2, 1, 1, 1, 1, 1, 2, 2]>, 1273 1274 // 1275 // Double-register Integer Unary 1276 InstrItinData<IIC_VUNAiD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1277 InstrStage<1, [A9_MUX0], 0>, 1278 InstrStage<1, [A9_DRegsN], 0, Required>, 1279 // Extra latency cycles since wbck is 6 cycles 1280 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1281 InstrStage<1, [A9_NPipe]>], 1282 [4, 2]>, 1283 // 1284 // Quad-register Integer Unary 1285 InstrItinData<IIC_VUNAiQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1286 InstrStage<1, [A9_MUX0], 0>, 1287 InstrStage<1, [A9_DRegsN], 0, Required>, 1288 // Extra latency cycles since wbck is 6 cycles 1289 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1290 InstrStage<1, [A9_NPipe]>], 1291 [4, 2]>, 1292 // 1293 // Double-register Integer Q-Unary 1294 InstrItinData<IIC_VQUNAiD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1295 InstrStage<1, [A9_MUX0], 0>, 1296 InstrStage<1, [A9_DRegsN], 0, Required>, 1297 // Extra latency cycles since wbck is 6 cycles 1298 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1299 InstrStage<1, [A9_NPipe]>], 1300 [4, 1]>, 1301 // 1302 // Quad-register Integer CountQ-Unary 1303 InstrItinData<IIC_VQUNAiQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1304 InstrStage<1, [A9_MUX0], 0>, 1305 InstrStage<1, [A9_DRegsN], 0, Required>, 1306 // Extra latency cycles since wbck is 6 cycles 1307 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1308 InstrStage<1, [A9_NPipe]>], 1309 [4, 1]>, 1310 // 1311 // Double-register Integer Binary 1312 InstrItinData<IIC_VBINiD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1313 InstrStage<1, [A9_MUX0], 0>, 1314 InstrStage<1, [A9_DRegsN], 0, Required>, 1315 // Extra latency cycles since wbck is 6 cycles 1316 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1317 InstrStage<1, [A9_NPipe]>], 1318 [3, 2, 2]>, 1319 // 1320 // Quad-register Integer Binary 1321 InstrItinData<IIC_VBINiQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1322 InstrStage<1, [A9_MUX0], 0>, 1323 InstrStage<1, [A9_DRegsN], 0, Required>, 1324 // Extra latency cycles since wbck is 6 cycles 1325 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1326 InstrStage<1, [A9_NPipe]>], 1327 [3, 2, 2]>, 1328 // 1329 // Double-register Integer Subtract 1330 InstrItinData<IIC_VSUBiD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1331 InstrStage<1, [A9_MUX0], 0>, 1332 InstrStage<1, [A9_DRegsN], 0, Required>, 1333 // Extra latency cycles since wbck is 6 cycles 1334 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1335 InstrStage<1, [A9_NPipe]>], 1336 [3, 2, 1]>, 1337 // 1338 // Quad-register Integer Subtract 1339 InstrItinData<IIC_VSUBiQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1340 InstrStage<1, [A9_MUX0], 0>, 1341 InstrStage<1, [A9_DRegsN], 0, Required>, 1342 // Extra latency cycles since wbck is 6 cycles 1343 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1344 InstrStage<1, [A9_NPipe]>], 1345 [3, 2, 1]>, 1346 // 1347 // Double-register Integer Shift 1348 InstrItinData<IIC_VSHLiD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1349 InstrStage<1, [A9_MUX0], 0>, 1350 InstrStage<1, [A9_DRegsN], 0, Required>, 1351 // Extra latency cycles since wbck is 6 cycles 1352 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1353 InstrStage<1, [A9_NPipe]>], 1354 [3, 1, 1]>, 1355 // 1356 // Quad-register Integer Shift 1357 InstrItinData<IIC_VSHLiQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1358 InstrStage<1, [A9_MUX0], 0>, 1359 InstrStage<1, [A9_DRegsN], 0, Required>, 1360 // Extra latency cycles since wbck is 6 cycles 1361 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1362 InstrStage<1, [A9_NPipe]>], 1363 [3, 1, 1]>, 1364 // 1365 // Double-register Integer Shift (4 cycle) 1366 InstrItinData<IIC_VSHLi4D, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1367 InstrStage<1, [A9_MUX0], 0>, 1368 InstrStage<1, [A9_DRegsN], 0, Required>, 1369 // Extra latency cycles since wbck is 6 cycles 1370 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1371 InstrStage<1, [A9_NPipe]>], 1372 [4, 1, 1]>, 1373 // 1374 // Quad-register Integer Shift (4 cycle) 1375 InstrItinData<IIC_VSHLi4Q, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1376 InstrStage<1, [A9_MUX0], 0>, 1377 InstrStage<1, [A9_DRegsN], 0, Required>, 1378 // Extra latency cycles since wbck is 6 cycles 1379 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1380 InstrStage<1, [A9_NPipe]>], 1381 [4, 1, 1]>, 1382 // 1383 // Double-register Integer Binary (4 cycle) 1384 InstrItinData<IIC_VBINi4D, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1385 InstrStage<1, [A9_MUX0], 0>, 1386 InstrStage<1, [A9_DRegsN], 0, Required>, 1387 // Extra latency cycles since wbck is 6 cycles 1388 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1389 InstrStage<1, [A9_NPipe]>], 1390 [4, 2, 2]>, 1391 // 1392 // Quad-register Integer Binary (4 cycle) 1393 InstrItinData<IIC_VBINi4Q, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1394 InstrStage<1, [A9_MUX0], 0>, 1395 InstrStage<1, [A9_DRegsN], 0, Required>, 1396 // Extra latency cycles since wbck is 6 cycles 1397 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1398 InstrStage<1, [A9_NPipe]>], 1399 [4, 2, 2]>, 1400 // 1401 // Double-register Integer Subtract (4 cycle) 1402 InstrItinData<IIC_VSUBi4D, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1403 InstrStage<1, [A9_MUX0], 0>, 1404 InstrStage<1, [A9_DRegsN], 0, Required>, 1405 // Extra latency cycles since wbck is 6 cycles 1406 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1407 InstrStage<1, [A9_NPipe]>], 1408 [4, 2, 1]>, 1409 // 1410 // Quad-register Integer Subtract (4 cycle) 1411 InstrItinData<IIC_VSUBi4Q, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1412 InstrStage<1, [A9_MUX0], 0>, 1413 InstrStage<1, [A9_DRegsN], 0, Required>, 1414 // Extra latency cycles since wbck is 6 cycles 1415 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1416 InstrStage<1, [A9_NPipe]>], 1417 [4, 2, 1]>, 1418 1419 // 1420 // Double-register Integer Count 1421 InstrItinData<IIC_VCNTiD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1422 InstrStage<1, [A9_MUX0], 0>, 1423 InstrStage<1, [A9_DRegsN], 0, Required>, 1424 // Extra latency cycles since wbck is 6 cycles 1425 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1426 InstrStage<1, [A9_NPipe]>], 1427 [3, 2, 2]>, 1428 // 1429 // Quad-register Integer Count 1430 // Result written in N3, but that is relative to the last cycle of multicycle, 1431 // so we use 4 for those cases 1432 InstrItinData<IIC_VCNTiQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1433 InstrStage<1, [A9_MUX0], 0>, 1434 InstrStage<1, [A9_DRegsN], 0, Required>, 1435 // Extra latency cycles since wbck is 7 cycles 1436 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1437 InstrStage<2, [A9_NPipe]>], 1438 [4, 2, 2]>, 1439 // 1440 // Double-register Absolute Difference and Accumulate 1441 InstrItinData<IIC_VABAD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1442 InstrStage<1, [A9_MUX0], 0>, 1443 InstrStage<1, [A9_DRegsN], 0, Required>, 1444 // Extra latency cycles since wbck is 6 cycles 1445 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1446 InstrStage<1, [A9_NPipe]>], 1447 [6, 3, 2, 1]>, 1448 // 1449 // Quad-register Absolute Difference and Accumulate 1450 InstrItinData<IIC_VABAQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1451 InstrStage<1, [A9_MUX0], 0>, 1452 InstrStage<1, [A9_DRegsN], 0, Required>, 1453 // Extra latency cycles since wbck is 6 cycles 1454 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1455 InstrStage<2, [A9_NPipe]>], 1456 [6, 3, 2, 1]>, 1457 // 1458 // Double-register Integer Pair Add Long 1459 InstrItinData<IIC_VPALiD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1460 InstrStage<1, [A9_MUX0], 0>, 1461 InstrStage<1, [A9_DRegsN], 0, Required>, 1462 // Extra latency cycles since wbck is 6 cycles 1463 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1464 InstrStage<1, [A9_NPipe]>], 1465 [6, 3, 1]>, 1466 // 1467 // Quad-register Integer Pair Add Long 1468 InstrItinData<IIC_VPALiQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1469 InstrStage<1, [A9_MUX0], 0>, 1470 InstrStage<1, [A9_DRegsN], 0, Required>, 1471 // Extra latency cycles since wbck is 6 cycles 1472 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1473 InstrStage<2, [A9_NPipe]>], 1474 [6, 3, 1]>, 1475 1476 // 1477 // Double-register Integer Multiply (.8, .16) 1478 InstrItinData<IIC_VMULi16D, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1479 InstrStage<1, [A9_MUX0], 0>, 1480 InstrStage<1, [A9_DRegsN], 0, Required>, 1481 // Extra latency cycles since wbck is 6 cycles 1482 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1483 InstrStage<1, [A9_NPipe]>], 1484 [6, 2, 2]>, 1485 // 1486 // Quad-register Integer Multiply (.8, .16) 1487 InstrItinData<IIC_VMULi16Q, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1488 InstrStage<1, [A9_MUX0], 0>, 1489 InstrStage<1, [A9_DRegsN], 0, Required>, 1490 // Extra latency cycles since wbck is 7 cycles 1491 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1492 InstrStage<2, [A9_NPipe]>], 1493 [7, 2, 2]>, 1494 1495 // 1496 // Double-register Integer Multiply (.32) 1497 InstrItinData<IIC_VMULi32D, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1498 InstrStage<1, [A9_MUX0], 0>, 1499 InstrStage<1, [A9_DRegsN], 0, Required>, 1500 // Extra latency cycles since wbck is 7 cycles 1501 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1502 InstrStage<2, [A9_NPipe]>], 1503 [7, 2, 1]>, 1504 // 1505 // Quad-register Integer Multiply (.32) 1506 InstrItinData<IIC_VMULi32Q, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1507 InstrStage<1, [A9_MUX0], 0>, 1508 InstrStage<1, [A9_DRegsN], 0, Required>, 1509 // Extra latency cycles since wbck is 9 cycles 1510 InstrStage<10, [A9_DRegsVFP], 0, Reserved>, 1511 InstrStage<4, [A9_NPipe]>], 1512 [9, 2, 1]>, 1513 // 1514 // Double-register Integer Multiply-Accumulate (.8, .16) 1515 InstrItinData<IIC_VMACi16D, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1516 InstrStage<1, [A9_MUX0], 0>, 1517 InstrStage<1, [A9_DRegsN], 0, Required>, 1518 // Extra latency cycles since wbck is 6 cycles 1519 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1520 InstrStage<1, [A9_NPipe]>], 1521 [6, 3, 2, 2]>, 1522 // 1523 // Double-register Integer Multiply-Accumulate (.32) 1524 InstrItinData<IIC_VMACi32D, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1525 InstrStage<1, [A9_MUX0], 0>, 1526 InstrStage<1, [A9_DRegsN], 0, Required>, 1527 // Extra latency cycles since wbck is 7 cycles 1528 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1529 InstrStage<2, [A9_NPipe]>], 1530 [7, 3, 2, 1]>, 1531 // 1532 // Quad-register Integer Multiply-Accumulate (.8, .16) 1533 InstrItinData<IIC_VMACi16Q, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1534 InstrStage<1, [A9_MUX0], 0>, 1535 InstrStage<1, [A9_DRegsN], 0, Required>, 1536 // Extra latency cycles since wbck is 7 cycles 1537 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1538 InstrStage<2, [A9_NPipe]>], 1539 [7, 3, 2, 2]>, 1540 // 1541 // Quad-register Integer Multiply-Accumulate (.32) 1542 InstrItinData<IIC_VMACi32Q, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1543 InstrStage<1, [A9_MUX0], 0>, 1544 InstrStage<1, [A9_DRegsN], 0, Required>, 1545 // Extra latency cycles since wbck is 9 cycles 1546 InstrStage<10, [A9_DRegsVFP], 0, Reserved>, 1547 InstrStage<4, [A9_NPipe]>], 1548 [9, 3, 2, 1]>, 1549 1550 // 1551 // Move 1552 InstrItinData<IIC_VMOV, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1553 InstrStage<1, [A9_MUX0], 0>, 1554 InstrStage<1, [A9_DRegsN], 0, Required>, 1555 InstrStage<1, [A9_DRegsVFP], 0, Reserved>, 1556 InstrStage<1, [A9_NPipe]>], 1557 [1,1]>, 1558 // 1559 // Move Immediate 1560 InstrItinData<IIC_VMOVImm, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1561 InstrStage<1, [A9_MUX0], 0>, 1562 InstrStage<1, [A9_DRegsN], 0, Required>, 1563 // Extra latency cycles since wbck is 6 cycles 1564 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1565 InstrStage<1, [A9_NPipe]>], 1566 [3]>, 1567 // 1568 // Double-register Permute Move 1569 InstrItinData<IIC_VMOVD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1570 InstrStage<1, [A9_MUX0], 0>, 1571 InstrStage<1, [A9_DRegsN], 0, Required>, 1572 // Extra latency cycles since wbck is 6 cycles 1573 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1574 InstrStage<1, [A9_NPipe]>], 1575 [2, 1]>, 1576 // 1577 // Quad-register Permute Move 1578 InstrItinData<IIC_VMOVQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1579 InstrStage<1, [A9_MUX0], 0>, 1580 InstrStage<1, [A9_DRegsN], 0, Required>, 1581 // Extra latency cycles since wbck is 6 cycles 1582 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1583 InstrStage<1, [A9_NPipe]>], 1584 [2, 1]>, 1585 // 1586 // Integer to Single-precision Move 1587 InstrItinData<IIC_VMOVIS , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1588 InstrStage<1, [A9_MUX0], 0>, 1589 InstrStage<1, [A9_DRegsN], 0, Required>, 1590 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1591 InstrStage<1, [A9_NPipe]>], 1592 [1, 1]>, 1593 // 1594 // Integer to Double-precision Move 1595 InstrItinData<IIC_VMOVID , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1596 InstrStage<1, [A9_MUX0], 0>, 1597 InstrStage<1, [A9_DRegsN], 0, Required>, 1598 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1599 InstrStage<1, [A9_NPipe]>], 1600 [1, 1, 1]>, 1601 // 1602 // Single-precision to Integer Move 1603 InstrItinData<IIC_VMOVSI , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1604 InstrStage<1, [A9_MUX0], 0>, 1605 InstrStage<1, [A9_DRegsN], 0, Required>, 1606 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1607 InstrStage<1, [A9_NPipe]>], 1608 [2, 1]>, 1609 // 1610 // Double-precision to Integer Move 1611 InstrItinData<IIC_VMOVDI , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1612 InstrStage<1, [A9_MUX0], 0>, 1613 InstrStage<1, [A9_DRegsN], 0, Required>, 1614 InstrStage<3, [A9_DRegsVFP], 0, Reserved>, 1615 InstrStage<1, [A9_NPipe]>], 1616 [2, 2, 1]>, 1617 // 1618 // Integer to Lane Move 1619 InstrItinData<IIC_VMOVISL , [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1620 InstrStage<1, [A9_MUX0], 0>, 1621 InstrStage<1, [A9_DRegsN], 0, Required>, 1622 InstrStage<4, [A9_DRegsVFP], 0, Reserved>, 1623 InstrStage<2, [A9_NPipe]>], 1624 [3, 1, 1]>, 1625 1626 // 1627 // Vector narrow move 1628 InstrItinData<IIC_VMOVN, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1629 InstrStage<1, [A9_MUX0], 0>, 1630 InstrStage<1, [A9_DRegsN], 0, Required>, 1631 // Extra latency cycles since wbck is 6 cycles 1632 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1633 InstrStage<1, [A9_NPipe]>], 1634 [3, 1]>, 1635 // 1636 // Double-register FP Unary 1637 InstrItinData<IIC_VUNAD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1638 InstrStage<1, [A9_MUX0], 0>, 1639 InstrStage<1, [A9_DRegsN], 0, Required>, 1640 // Extra latency cycles since wbck is 6 cycles 1641 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1642 InstrStage<1, [A9_NPipe]>], 1643 [5, 2]>, 1644 // 1645 // Quad-register FP Unary 1646 // Result written in N5, but that is relative to the last cycle of multicycle, 1647 // so we use 6 for those cases 1648 InstrItinData<IIC_VUNAQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1649 InstrStage<1, [A9_MUX0], 0>, 1650 InstrStage<1, [A9_DRegsN], 0, Required>, 1651 // Extra latency cycles since wbck is 7 cycles 1652 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1653 InstrStage<2, [A9_NPipe]>], 1654 [6, 2]>, 1655 // 1656 // Double-register FP Binary 1657 // FIXME: We're using this itin for many instructions and [2, 2] here is too 1658 // optimistic. 1659 InstrItinData<IIC_VBIND, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1660 InstrStage<1, [A9_MUX0], 0>, 1661 InstrStage<1, [A9_DRegsN], 0, Required>, 1662 // Extra latency cycles since wbck is 6 cycles 1663 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1664 InstrStage<1, [A9_NPipe]>], 1665 [5, 2, 2]>, 1666 1667 // 1668 // VPADD, etc. 1669 InstrItinData<IIC_VPBIND, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1670 InstrStage<1, [A9_MUX0], 0>, 1671 InstrStage<1, [A9_DRegsN], 0, Required>, 1672 // Extra latency cycles since wbck is 6 cycles 1673 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1674 InstrStage<1, [A9_NPipe]>], 1675 [5, 1, 1]>, 1676 // 1677 // Double-register FP VMUL 1678 InstrItinData<IIC_VFMULD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1679 InstrStage<1, [A9_MUX0], 0>, 1680 InstrStage<1, [A9_DRegsN], 0, Required>, 1681 // Extra latency cycles since wbck is 6 cycles 1682 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1683 InstrStage<1, [A9_NPipe]>], 1684 [5, 2, 1]>, 1685 // 1686 // Quad-register FP Binary 1687 // Result written in N5, but that is relative to the last cycle of multicycle, 1688 // so we use 6 for those cases 1689 // FIXME: We're using this itin for many instructions and [2, 2] here is too 1690 // optimistic. 1691 InstrItinData<IIC_VBINQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1692 InstrStage<1, [A9_MUX0], 0>, 1693 InstrStage<1, [A9_DRegsN], 0, Required>, 1694 // Extra latency cycles since wbck is 7 cycles 1695 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1696 InstrStage<2, [A9_NPipe]>], 1697 [6, 2, 2]>, 1698 // 1699 // Quad-register FP VMUL 1700 InstrItinData<IIC_VFMULQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1701 InstrStage<1, [A9_MUX0], 0>, 1702 InstrStage<1, [A9_DRegsN], 0, Required>, 1703 // Extra latency cycles since wbck is 7 cycles 1704 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1705 InstrStage<1, [A9_NPipe]>], 1706 [6, 2, 1]>, 1707 // 1708 // Double-register FP Multiple-Accumulate 1709 InstrItinData<IIC_VMACD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1710 InstrStage<1, [A9_MUX0], 0>, 1711 InstrStage<1, [A9_DRegsN], 0, Required>, 1712 // Extra latency cycles since wbck is 7 cycles 1713 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1714 InstrStage<2, [A9_NPipe]>], 1715 [6, 3, 2, 1]>, 1716 // 1717 // Quad-register FP Multiple-Accumulate 1718 // Result written in N9, but that is relative to the last cycle of multicycle, 1719 // so we use 10 for those cases 1720 InstrItinData<IIC_VMACQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1721 InstrStage<1, [A9_MUX0], 0>, 1722 InstrStage<1, [A9_DRegsN], 0, Required>, 1723 // Extra latency cycles since wbck is 9 cycles 1724 InstrStage<10, [A9_DRegsVFP], 0, Reserved>, 1725 InstrStage<4, [A9_NPipe]>], 1726 [8, 4, 2, 1]>, 1727 // 1728 // Double-register Fused FP Multiple-Accumulate 1729 InstrItinData<IIC_VFMACD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1730 InstrStage<1, [A9_MUX0], 0>, 1731 InstrStage<1, [A9_DRegsN], 0, Required>, 1732 // Extra latency cycles since wbck is 7 cycles 1733 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1734 InstrStage<2, [A9_NPipe]>], 1735 [6, 3, 2, 1]>, 1736 // 1737 // Quad-register Fused FP Multiple-Accumulate 1738 // Result written in N9, but that is relative to the last cycle of multicycle, 1739 // so we use 10 for those cases 1740 InstrItinData<IIC_VFMACQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1741 InstrStage<1, [A9_MUX0], 0>, 1742 InstrStage<1, [A9_DRegsN], 0, Required>, 1743 // Extra latency cycles since wbck is 9 cycles 1744 InstrStage<10, [A9_DRegsVFP], 0, Reserved>, 1745 InstrStage<4, [A9_NPipe]>], 1746 [8, 4, 2, 1]>, 1747 // 1748 // Double-register Reciprical Step 1749 InstrItinData<IIC_VRECSD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1750 InstrStage<1, [A9_MUX0], 0>, 1751 InstrStage<1, [A9_DRegsN], 0, Required>, 1752 // Extra latency cycles since wbck is 10 cycles 1753 InstrStage<11, [A9_DRegsVFP], 0, Reserved>, 1754 InstrStage<1, [A9_NPipe]>], 1755 [9, 2, 2]>, 1756 // 1757 // Quad-register Reciprical Step 1758 InstrItinData<IIC_VRECSQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1759 InstrStage<1, [A9_MUX0], 0>, 1760 InstrStage<1, [A9_DRegsN], 0, Required>, 1761 // Extra latency cycles since wbck is 11 cycles 1762 InstrStage<12, [A9_DRegsVFP], 0, Reserved>, 1763 InstrStage<2, [A9_NPipe]>], 1764 [10, 2, 2]>, 1765 // 1766 // Double-register Permute 1767 InstrItinData<IIC_VPERMD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1768 InstrStage<1, [A9_MUX0], 0>, 1769 InstrStage<1, [A9_DRegsN], 0, Required>, 1770 // Extra latency cycles since wbck is 6 cycles 1771 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1772 InstrStage<1, [A9_NPipe]>], 1773 [2, 2, 1, 1]>, 1774 // 1775 // Quad-register Permute 1776 // Result written in N2, but that is relative to the last cycle of multicycle, 1777 // so we use 3 for those cases 1778 InstrItinData<IIC_VPERMQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1779 InstrStage<1, [A9_MUX0], 0>, 1780 InstrStage<1, [A9_DRegsN], 0, Required>, 1781 // Extra latency cycles since wbck is 7 cycles 1782 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1783 InstrStage<2, [A9_NPipe]>], 1784 [3, 3, 1, 1]>, 1785 // 1786 // Quad-register Permute (3 cycle issue) 1787 // Result written in N2, but that is relative to the last cycle of multicycle, 1788 // so we use 4 for those cases 1789 InstrItinData<IIC_VPERMQ3, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1790 InstrStage<1, [A9_MUX0], 0>, 1791 InstrStage<1, [A9_DRegsN], 0, Required>, 1792 // Extra latency cycles since wbck is 8 cycles 1793 InstrStage<9, [A9_DRegsVFP], 0, Reserved>, 1794 InstrStage<3, [A9_NPipe]>], 1795 [4, 4, 1, 1]>, 1796 1797 // 1798 // Double-register VEXT 1799 InstrItinData<IIC_VEXTD, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1800 InstrStage<1, [A9_MUX0], 0>, 1801 InstrStage<1, [A9_DRegsN], 0, Required>, 1802 // Extra latency cycles since wbck is 6 cycles 1803 InstrStage<7, [A9_DRegsVFP], 0, Reserved>, 1804 InstrStage<1, [A9_NPipe]>], 1805 [2, 1, 1]>, 1806 // 1807 // Quad-register VEXT 1808 InstrItinData<IIC_VEXTQ, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1809 InstrStage<1, [A9_MUX0], 0>, 1810 InstrStage<1, [A9_DRegsN], 0, Required>, 1811 // Extra latency cycles since wbck is 7 cycles 1812 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1813 InstrStage<2, [A9_NPipe]>], 1814 [3, 1, 2]>, 1815 // 1816 // VTB 1817 InstrItinData<IIC_VTB1, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1818 InstrStage<1, [A9_MUX0], 0>, 1819 InstrStage<1, [A9_DRegsN], 0, Required>, 1820 // Extra latency cycles since wbck is 7 cycles 1821 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1822 InstrStage<2, [A9_NPipe]>], 1823 [3, 2, 1]>, 1824 InstrItinData<IIC_VTB2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1825 InstrStage<1, [A9_MUX0], 0>, 1826 InstrStage<2, [A9_DRegsN], 0, Required>, 1827 // Extra latency cycles since wbck is 7 cycles 1828 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1829 InstrStage<2, [A9_NPipe]>], 1830 [3, 2, 2, 1]>, 1831 InstrItinData<IIC_VTB3, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1832 InstrStage<1, [A9_MUX0], 0>, 1833 InstrStage<2, [A9_DRegsN], 0, Required>, 1834 // Extra latency cycles since wbck is 8 cycles 1835 InstrStage<9, [A9_DRegsVFP], 0, Reserved>, 1836 InstrStage<3, [A9_NPipe]>], 1837 [4, 2, 2, 3, 1]>, 1838 InstrItinData<IIC_VTB4, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1839 InstrStage<1, [A9_MUX0], 0>, 1840 InstrStage<1, [A9_DRegsN], 0, Required>, 1841 // Extra latency cycles since wbck is 8 cycles 1842 InstrStage<9, [A9_DRegsVFP], 0, Reserved>, 1843 InstrStage<3, [A9_NPipe]>], 1844 [4, 2, 2, 3, 3, 1]>, 1845 // 1846 // VTBX 1847 InstrItinData<IIC_VTBX1, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1848 InstrStage<1, [A9_MUX0], 0>, 1849 InstrStage<1, [A9_DRegsN], 0, Required>, 1850 // Extra latency cycles since wbck is 7 cycles 1851 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1852 InstrStage<2, [A9_NPipe]>], 1853 [3, 1, 2, 1]>, 1854 InstrItinData<IIC_VTBX2, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1855 InstrStage<1, [A9_MUX0], 0>, 1856 InstrStage<1, [A9_DRegsN], 0, Required>, 1857 // Extra latency cycles since wbck is 7 cycles 1858 InstrStage<8, [A9_DRegsVFP], 0, Reserved>, 1859 InstrStage<2, [A9_NPipe]>], 1860 [3, 1, 2, 2, 1]>, 1861 InstrItinData<IIC_VTBX3, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1862 InstrStage<1, [A9_MUX0], 0>, 1863 InstrStage<1, [A9_DRegsN], 0, Required>, 1864 // Extra latency cycles since wbck is 8 cycles 1865 InstrStage<9, [A9_DRegsVFP], 0, Reserved>, 1866 InstrStage<3, [A9_NPipe]>], 1867 [4, 1, 2, 2, 3, 1]>, 1868 InstrItinData<IIC_VTBX4, [InstrStage<1, [A9_Issue0, A9_Issue1], 0>, 1869 InstrStage<1, [A9_MUX0], 0>, 1870 InstrStage<1, [A9_DRegsN], 0, Required>, 1871 // Extra latency cycles since wbck is 8 cycles 1872 InstrStage<9, [A9_DRegsVFP], 0, Reserved>, 1873 InstrStage<2, [A9_NPipe]>], 1874 [4, 1, 2, 2, 3, 3, 1]> 1875]>; 1876 1877// ===---------------------------------------------------------------------===// 1878// The following definitions describe the simpler per-operand machine model. 1879// This works with MachineScheduler and will eventually replace itineraries. 1880 1881class A9WriteLMOpsListType<list<WriteSequence> writes> { 1882 list <WriteSequence> Writes = writes; 1883 SchedMachineModel SchedModel = ?; 1884} 1885 1886// Cortex-A9 machine model for scheduling and other instruction cost heuristics. 1887def CortexA9Model : SchedMachineModel { 1888 let IssueWidth = 2; // 2 micro-ops are dispatched per cycle. 1889 let MicroOpBufferSize = 56; // Based on available renamed registers. 1890 let LoadLatency = 2; // Optimistic load latency assuming bypass. 1891 // This is overriden by OperandCycles if the 1892 // Itineraries are queried instead. 1893 let MispredictPenalty = 8; // Based on estimate of pipeline depth. 1894 1895 let Itineraries = CortexA9Itineraries; 1896 1897 // FIXME: Many vector operations were never given an itinerary. We 1898 // haven't mapped these to the new model either. 1899 let CompleteModel = 0; 1900 1901 // FIXME: Remove when all errors have been fixed. 1902 let FullInstRWOverlapCheck = 0; 1903} 1904 1905//===----------------------------------------------------------------------===// 1906// Define each kind of processor resource and number available. 1907// 1908// The AGU unit has BufferSize=1 so that the latency between operations 1909// that use it are considered to stall other operations. 1910// 1911// The FP unit has BufferSize=0 so that it is a hard dispatch 1912// hazard. No instruction may be dispatched while the unit is reserved. 1913 1914let SchedModel = CortexA9Model in { 1915 1916def A9UnitALU : ProcResource<2>; 1917def A9UnitMul : ProcResource<1> { let Super = A9UnitALU; } 1918def A9UnitAGU : ProcResource<1> { let BufferSize = 1; } 1919def A9UnitLS : ProcResource<1>; 1920def A9UnitFP : ProcResource<1> { let BufferSize = 0; } 1921def A9UnitB : ProcResource<1>; 1922 1923//===----------------------------------------------------------------------===// 1924// Define scheduler read/write types with their resources and latency on A9. 1925 1926// Consume an issue slot, but no processor resources. This is useful when all 1927// other writes associated with the operand have NumMicroOps = 0. 1928def A9WriteIssue : SchedWriteRes<[]> { let Latency = 0; } 1929 1930// Write an integer register. 1931def A9WriteI : SchedWriteRes<[A9UnitALU]>; 1932// Write an integer shifted-by register 1933def A9WriteIsr : SchedWriteRes<[A9UnitALU]> { let Latency = 2; } 1934 1935// Basic ALU. 1936def A9WriteALU : SchedWriteRes<[A9UnitALU]>; 1937// ALU with operand shifted by immediate. 1938def : WriteRes<WriteALUsi, [A9UnitALU]> { let Latency = 2; } 1939// ALU with operand shifted by register. 1940def A9WriteALUsr : SchedWriteRes<[A9UnitALU]> { let Latency = 3; } 1941 1942// Multiplication 1943def A9WriteM : SchedWriteRes<[A9UnitMul, A9UnitMul]> { let Latency = 4; } 1944def A9WriteMHi : SchedWriteRes<[A9UnitMul]> { let Latency = 5; 1945 let NumMicroOps = 0; } 1946def A9WriteM16 : SchedWriteRes<[A9UnitMul]> { let Latency = 3; } 1947def A9WriteM16Hi : SchedWriteRes<[A9UnitMul]> { let Latency = 4; 1948 let NumMicroOps = 0; } 1949def : SchedAlias<WriteMUL16, A9WriteM16>; 1950def : SchedAlias<WriteMUL32, A9WriteM>; 1951def : SchedAlias<WriteMUL64Lo, A9WriteM>; 1952def : SchedAlias<WriteMUL64Hi, A9WriteMHi>; 1953def : SchedAlias<WriteMAC16, A9WriteM16>; 1954def : SchedAlias<WriteMAC32, A9WriteM>; 1955def : SchedAlias<WriteMAC64Lo, A9WriteM>; 1956def : SchedAlias<WriteMAC64Hi, A9WriteMHi>; 1957def : ReadAdvance<ReadMUL, 0>; 1958def : ReadAdvance<ReadMAC, 0>; 1959 1960// Floating-point 1961// Only one FP or AGU instruction may issue per cycle. We model this 1962// by having FP instructions consume the AGU resource. 1963def A9WriteF : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 4; } 1964def A9WriteFMov : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 1; } 1965def A9WriteFMulS : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 5; } 1966def A9WriteFMulD : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 6; } 1967def A9WriteFMAS : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 8; } 1968 1969def A9WriteFMAD : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 9; } 1970def A9WriteFDivS : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 15; } 1971def A9WriteFDivD : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 25; } 1972def A9WriteFSqrtS : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 17; } 1973def A9WriteFSqrtD : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 32; } 1974 1975// NEON has an odd mix of latencies. Simply name the write types by latency. 1976def A9WriteV1 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 1; } 1977def A9WriteV2 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 2; } 1978def A9WriteV3 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 3; } 1979def A9WriteV4 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 4; } 1980def A9WriteV5 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 5; } 1981def A9WriteV6 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 6; } 1982def A9WriteV7 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 7; } 1983def A9WriteV9 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 9; } 1984def A9WriteV10 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { let Latency = 10; } 1985 1986def : WriteRes<WriteVLD1, []>; 1987def : WriteRes<WriteVLD2, []>; 1988def : WriteRes<WriteVLD3, []>; 1989def : WriteRes<WriteVLD4, []>; 1990def : WriteRes<WriteVST1, []>; 1991def : WriteRes<WriteVST2, []>; 1992def : WriteRes<WriteVST3, []>; 1993def : WriteRes<WriteVST4, []>; 1994 1995// Reserve A9UnitFP for 2 consecutive cycles. 1996def A9Write2V4 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { 1997 let Latency = 4; 1998 let ReleaseAtCycles = [2, 1]; 1999} 2000def A9Write2V7 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { 2001 let Latency = 7; 2002 let ReleaseAtCycles = [2, 1]; 2003} 2004def A9Write2V9 : SchedWriteRes<[A9UnitFP, A9UnitAGU]> { 2005 let Latency = 9; 2006 let ReleaseAtCycles = [2, 1]; 2007} 2008 2009// Branches don't have a def operand but still consume resources. 2010def A9WriteB : SchedWriteRes<[A9UnitB]>; 2011 2012// Address generation. 2013def A9WriteAdr : SchedWriteRes<[A9UnitAGU]> { let NumMicroOps = 0; } 2014 2015// Load Integer. 2016def A9WriteL : SchedWriteRes<[A9UnitLS]> { let Latency = 3; } 2017def : SchedAlias<WriteLd, A9WriteL>; 2018// Load the upper 32-bits using the same micro-op. 2019def A9WriteLHi : SchedWriteRes<[]> { let Latency = 3; 2020 let NumMicroOps = 0; } 2021// Offset shifted by register. 2022def A9WriteLsi : SchedWriteRes<[A9UnitLS]> { let Latency = 4; } 2023// Load (and zero extend) a byte. 2024def A9WriteLb : SchedWriteRes<[A9UnitLS]> { let Latency = 4; } 2025def A9WriteLbsi : SchedWriteRes<[A9UnitLS]> { let Latency = 5; } 2026 2027// Load or Store Float, aligned. 2028def A9WriteLSfp : SchedWriteRes<[A9UnitLS, A9UnitFP]> { let Latency = 1; } 2029 2030// Store Integer. 2031def A9WriteS : SchedWriteRes<[A9UnitLS]>; 2032 2033//===----------------------------------------------------------------------===// 2034// Define resources dynamically for load multiple variants. 2035 2036// Define helpers for extra latency without consuming resources. 2037def A9WriteCycle1 : SchedWriteRes<[]> { let Latency = 1; let NumMicroOps = 0; } 2038foreach NumCycles = 2-8 in { 2039def A9WriteCycle#NumCycles : WriteSequence<[A9WriteCycle1], NumCycles>; 2040} // foreach NumCycles 2041 2042// Define address generation sequences and predicates for 8 flavors of LDMs. 2043foreach NumAddr = 1-8 in { 2044 2045// Define A9WriteAdr1-8 as a sequence of A9WriteAdr with additive 2046// latency for instructions that generate multiple loads or stores. 2047def A9WriteAdr#NumAddr : WriteSequence<[A9WriteAdr], NumAddr>; 2048 2049// Define a predicate to select the LDM based on number of memory addresses. 2050def A9LMAdr#NumAddr#Pred : 2051 SchedPredicate<"(TII->getNumLDMAddresses(*MI)+1)/2 == "#NumAddr>; 2052 2053} // foreach NumAddr 2054 2055// Fall-back for unknown LDMs. 2056def A9LMUnknownPred : SchedPredicate<"TII->getNumLDMAddresses(*MI) == 0">; 2057 2058// LDM/VLDM/VLDn address generation latency & resources. 2059// Dynamically select the A9WriteAdrN sequence using a predicate. 2060def A9WriteLMAdr : SchedWriteVariant<[ 2061 SchedVar<A9LMAdr1Pred, [A9WriteAdr1]>, 2062 SchedVar<A9LMAdr2Pred, [A9WriteAdr2]>, 2063 SchedVar<A9LMAdr3Pred, [A9WriteAdr3]>, 2064 SchedVar<A9LMAdr4Pred, [A9WriteAdr4]>, 2065 SchedVar<A9LMAdr5Pred, [A9WriteAdr5]>, 2066 SchedVar<A9LMAdr6Pred, [A9WriteAdr6]>, 2067 SchedVar<A9LMAdr7Pred, [A9WriteAdr7]>, 2068 SchedVar<A9LMAdr8Pred, [A9WriteAdr8]>, 2069 // For unknown LDM/VLDM/VSTM, assume 2 32-bit registers. 2070 SchedVar<A9LMUnknownPred, [A9WriteAdr2]>]>; 2071 2072// Define LDM Resources. 2073// These take no issue resource, so they can be combined with other 2074// writes like WriteB. 2075// A9WriteLMLo takes a single LS resource and 2 cycles. 2076def A9WriteLMLo : SchedWriteRes<[A9UnitLS]> { let Latency = 2; 2077 let NumMicroOps = 0; } 2078// Assuming aligned access, the upper half of each pair is free with 2079// the same latency. 2080def A9WriteLMHi : SchedWriteRes<[]> { let Latency = 2; 2081 let NumMicroOps = 0; } 2082// Each A9WriteL#N variant adds N cycles of latency without consuming 2083// additional resources. 2084foreach NumAddr = 1-8 in { 2085def A9WriteL#NumAddr : WriteSequence< 2086 [A9WriteLMLo, !cast<SchedWrite>("A9WriteCycle"#NumAddr)]>; 2087def A9WriteL#NumAddr#Hi : WriteSequence< 2088 [A9WriteLMHi, !cast<SchedWrite>("A9WriteCycle"#NumAddr)]>; 2089} 2090 2091//===----------------------------------------------------------------------===// 2092// LDM: Load multiple into 32-bit integer registers. 2093 2094def A9WriteLMOpsList : A9WriteLMOpsListType< 2095 [A9WriteL1, A9WriteL1Hi, 2096 A9WriteL2, A9WriteL2Hi, 2097 A9WriteL3, A9WriteL3Hi, 2098 A9WriteL4, A9WriteL4Hi, 2099 A9WriteL5, A9WriteL5Hi, 2100 A9WriteL6, A9WriteL6Hi, 2101 A9WriteL7, A9WriteL7Hi, 2102 A9WriteL8, A9WriteL8Hi]>; 2103 2104// A9WriteLM variants expand into a pair of writes for each 64-bit 2105// value loaded. When the number of registers is odd, the last 2106// A9WriteLnHi is naturally ignored because the instruction has no 2107// following def operands. These variants take no issue resource, so 2108// they may need to be part of a WriteSequence that includes A9WriteIssue. 2109def A9WriteLM : SchedWriteVariant<[ 2110 SchedVar<A9LMAdr1Pred, A9WriteLMOpsList.Writes[0-1]>, 2111 SchedVar<A9LMAdr2Pred, A9WriteLMOpsList.Writes[0-3]>, 2112 SchedVar<A9LMAdr3Pred, A9WriteLMOpsList.Writes[0-5]>, 2113 SchedVar<A9LMAdr4Pred, A9WriteLMOpsList.Writes[0-7]>, 2114 SchedVar<A9LMAdr5Pred, A9WriteLMOpsList.Writes[0-9]>, 2115 SchedVar<A9LMAdr6Pred, A9WriteLMOpsList.Writes[0-11]>, 2116 SchedVar<A9LMAdr7Pred, A9WriteLMOpsList.Writes[0-13]>, 2117 SchedVar<A9LMAdr8Pred, A9WriteLMOpsList.Writes[0-15]>, 2118 // For unknown LDMs, define the maximum number of writes, but only 2119 // make the first two consume resources. 2120 SchedVar<A9LMUnknownPred, [A9WriteL1, A9WriteL1Hi, 2121 A9WriteL2, A9WriteL2Hi, 2122 A9WriteL3Hi, A9WriteL3Hi, 2123 A9WriteL4Hi, A9WriteL4Hi, 2124 A9WriteL5Hi, A9WriteL5Hi, 2125 A9WriteL6Hi, A9WriteL6Hi, 2126 A9WriteL7Hi, A9WriteL7Hi, 2127 A9WriteL8Hi, A9WriteL8Hi]>]> { 2128 let Variadic = 1; 2129} 2130 2131//===----------------------------------------------------------------------===// 2132// VFP Load/Store Multiple Variants, and NEON VLDn/VSTn support. 2133 2134// A9WriteLfpOp is the same as A9WriteLSfp but takes no issue resources 2135// so can be used in WriteSequences for in single-issue instructions that 2136// encapsulate multiple loads. 2137def A9WriteLfpOp : SchedWriteRes<[A9UnitLS, A9UnitFP]> { 2138 let Latency = 1; 2139 let NumMicroOps = 0; 2140} 2141 2142foreach NumAddr = 1-8 in { 2143 2144// Helper for A9WriteLfp1-8: A sequence of fp loads with no micro-ops. 2145def A9WriteLfp#NumAddr#Seq : WriteSequence<[A9WriteLfpOp], NumAddr>; 2146 2147// A9WriteLfp1-8 definitions are statically expanded into a sequence of 2148// A9WriteLfpOps with additive latency that takes a single issue slot. 2149// Used directly to describe NEON VLDn. 2150def A9WriteLfp#NumAddr : WriteSequence< 2151 [A9WriteIssue, !cast<SchedWrite>("A9WriteLfp"#NumAddr#Seq)]>; 2152 2153// A9WriteLfp1-8Mov adds a cycle of latency and FP resource for 2154// permuting loaded values. 2155def A9WriteLfp#NumAddr#Mov : WriteSequence< 2156 [A9WriteF, !cast<SchedWrite>("A9WriteLfp"#NumAddr#Seq)]>; 2157 2158} // foreach NumAddr 2159 2160// Define VLDM/VSTM PreRA resources. 2161// A9WriteLMfpPreRA are dynamically expanded into the correct 2162// A9WriteLfp1-8 sequence based on a predicate. This supports the 2163// preRA VLDM variants in which all 64-bit loads are written to the 2164// same tuple of either single or double precision registers. 2165def A9WriteLMfpPreRA : SchedWriteVariant<[ 2166 SchedVar<A9LMAdr1Pred, [A9WriteLfp1]>, 2167 SchedVar<A9LMAdr2Pred, [A9WriteLfp2]>, 2168 SchedVar<A9LMAdr3Pred, [A9WriteLfp3]>, 2169 SchedVar<A9LMAdr4Pred, [A9WriteLfp4]>, 2170 SchedVar<A9LMAdr5Pred, [A9WriteLfp5]>, 2171 SchedVar<A9LMAdr6Pred, [A9WriteLfp6]>, 2172 SchedVar<A9LMAdr7Pred, [A9WriteLfp7]>, 2173 SchedVar<A9LMAdr8Pred, [A9WriteLfp8]>, 2174 // For unknown VLDM/VSTM PreRA, assume 2xS registers. 2175 SchedVar<A9LMUnknownPred, [A9WriteLfp2]>]>; 2176 2177// Define VLDM/VSTM PostRA Resources. 2178// A9WriteLMfpLo takes a LS and FP resource and one issue slot but no latency. 2179def A9WriteLMfpLo : SchedWriteRes<[A9UnitLS, A9UnitFP]> { let Latency = 0; } 2180 2181foreach NumAddr = 1-8 in { 2182 2183// Each A9WriteL#N variant adds N cycles of latency without consuming 2184// additional resources. 2185def A9WriteLMfp#NumAddr : WriteSequence< 2186 [A9WriteLMfpLo, !cast<SchedWrite>("A9WriteCycle"#NumAddr)]>; 2187 2188// Assuming aligned access, the upper half of each pair is free with 2189// the same latency. 2190def A9WriteLMfp#NumAddr#Hi : WriteSequence< 2191 [A9WriteLMHi, !cast<SchedWrite>("A9WriteCycle"#NumAddr)]>; 2192 2193} // foreach NumAddr 2194 2195// VLDM PostRA Variants. These variants expand A9WriteLMfpPostRA into a 2196// pair of writes for each 64-bit data loaded. When the number of 2197// registers is odd, the last WriteLMfpnHi is naturally ignored because 2198// the instruction has no following def operands. 2199 2200def A9WriteLMfpPostRAOpsList : A9WriteLMOpsListType< 2201 [A9WriteLMfp1, A9WriteLMfp2, // 0-1 2202 A9WriteLMfp3, A9WriteLMfp4, // 2-3 2203 A9WriteLMfp5, A9WriteLMfp6, // 4-5 2204 A9WriteLMfp7, A9WriteLMfp8, // 6-7 2205 A9WriteLMfp1Hi, // 8-8 2206 A9WriteLMfp2Hi, A9WriteLMfp2Hi, // 9-10 2207 A9WriteLMfp3Hi, A9WriteLMfp3Hi, // 11-12 2208 A9WriteLMfp4Hi, A9WriteLMfp4Hi, // 13-14 2209 A9WriteLMfp5Hi, A9WriteLMfp5Hi, // 15-16 2210 A9WriteLMfp6Hi, A9WriteLMfp6Hi, // 17-18 2211 A9WriteLMfp7Hi, A9WriteLMfp7Hi, // 19-20 2212 A9WriteLMfp8Hi, A9WriteLMfp8Hi]>; // 21-22 2213 2214def A9WriteLMfpPostRA : SchedWriteVariant<[ 2215 SchedVar<A9LMAdr1Pred, A9WriteLMfpPostRAOpsList.Writes[0-0, 8-8]>, 2216 SchedVar<A9LMAdr2Pred, A9WriteLMfpPostRAOpsList.Writes[0-1, 9-10]>, 2217 SchedVar<A9LMAdr3Pred, A9WriteLMfpPostRAOpsList.Writes[0-2, 10-12]>, 2218 SchedVar<A9LMAdr4Pred, A9WriteLMfpPostRAOpsList.Writes[0-3, 11-14]>, 2219 SchedVar<A9LMAdr5Pred, A9WriteLMfpPostRAOpsList.Writes[0-4, 12-16]>, 2220 SchedVar<A9LMAdr6Pred, A9WriteLMfpPostRAOpsList.Writes[0-5, 13-18]>, 2221 SchedVar<A9LMAdr7Pred, A9WriteLMfpPostRAOpsList.Writes[0-6, 14-20]>, 2222 SchedVar<A9LMAdr8Pred, A9WriteLMfpPostRAOpsList.Writes[0-7, 15-22]>, 2223 // For unknown LDMs, define the maximum number of writes, but only 2224 // make the first two consume resources. We are optimizing for the case 2225 // where the operands are DPRs, and this determines the first eight 2226 // types. The remaining eight types are filled to cover the case 2227 // where the operands are SPRs. 2228 SchedVar<A9LMUnknownPred, [A9WriteLMfp1, A9WriteLMfp2, 2229 A9WriteLMfp3Hi, A9WriteLMfp4Hi, 2230 A9WriteLMfp5Hi, A9WriteLMfp6Hi, 2231 A9WriteLMfp7Hi, A9WriteLMfp8Hi, 2232 A9WriteLMfp5Hi, A9WriteLMfp5Hi, 2233 A9WriteLMfp6Hi, A9WriteLMfp6Hi, 2234 A9WriteLMfp7Hi, A9WriteLMfp7Hi, 2235 A9WriteLMfp8Hi, A9WriteLMfp8Hi]>]> { 2236 let Variadic = 1; 2237} 2238 2239// Distinguish between our multiple MI-level forms of the same 2240// VLDM/VSTM instructions. 2241def A9PreRA : SchedPredicate< 2242 "MI->getOperand(0).getReg().isVirtual()">; 2243def A9PostRA : SchedPredicate< 2244 "MI->getOperand(0).getReg().isPhysical()">; 2245 2246// VLDM represents all destination registers as a single register 2247// tuple, unlike LDM. So the number of write operands is not variadic. 2248def A9WriteLMfp : SchedWriteVariant<[ 2249 SchedVar<A9PreRA, [A9WriteLMfpPreRA]>, 2250 SchedVar<A9PostRA, [A9WriteLMfpPostRA]>]>; 2251 2252//===----------------------------------------------------------------------===// 2253// Resources for other (non-LDM/VLDM) Variants. 2254 2255// These mov immediate writers are unconditionally expanded with 2256// additive latency. 2257def A9WriteI2 : WriteSequence<[A9WriteI, A9WriteI]>; 2258def A9WriteI2pc : WriteSequence<[A9WriteI, A9WriteI, WriteALU]>; 2259def A9WriteI2ld : WriteSequence<[A9WriteI, A9WriteI, A9WriteL]>; 2260 2261// Some ALU operations can read loaded integer values one cycle early. 2262def A9ReadALU : SchedReadAdvance<1, 2263 [A9WriteL, A9WriteLHi, A9WriteLsi, A9WriteLb, A9WriteLbsi, 2264 A9WriteL1, A9WriteL2, A9WriteL3, A9WriteL4, 2265 A9WriteL5, A9WriteL6, A9WriteL7, A9WriteL8, 2266 A9WriteL1Hi, A9WriteL2Hi, A9WriteL3Hi, A9WriteL4Hi, 2267 A9WriteL5Hi, A9WriteL6Hi, A9WriteL7Hi, A9WriteL8Hi]>; 2268 2269// Read types for operands that are unconditionally read in cycle N 2270// after the instruction issues, decreases producer latency by N-1. 2271def A9Read2 : SchedReadAdvance<1>; 2272def A9Read3 : SchedReadAdvance<2>; 2273def A9Read4 : SchedReadAdvance<3>; 2274 2275//===----------------------------------------------------------------------===// 2276// Map itinerary classes to scheduler read/write resources per operand. 2277// 2278// For ARM, we piggyback scheduler resources on the Itinerary classes 2279// to avoid perturbing the existing instruction definitions. 2280 2281// This table follows the ARM Cortex-A9 Technical Reference Manuals, 2282// mostly in order. 2283 2284def :ItinRW<[WriteALU], [IIC_iMOVi,IIC_iMOVr,IIC_iMOVsi, 2285 IIC_iMVNi,IIC_iMVNsi, 2286 IIC_iCMOVi,IIC_iCMOVr,IIC_iCMOVsi]>; 2287def :ItinRW<[WriteALU, A9ReadALU],[IIC_iMVNr]>; 2288def :ItinRW<[A9WriteIsr], [IIC_iMOVsr,IIC_iMVNsr,IIC_iCMOVsr]>; 2289 2290def :ItinRW<[A9WriteI2], [IIC_iMOVix2,IIC_iCMOVix2]>; 2291def :ItinRW<[A9WriteI2pc], [IIC_iMOVix2addpc]>; 2292def :ItinRW<[A9WriteI2ld], [IIC_iMOVix2ld]>; 2293 2294def :ItinRW<[WriteALU], [IIC_iBITi,IIC_iBITr,IIC_iUNAr,IIC_iTSTi,IIC_iTSTr]>; 2295def :ItinRW<[WriteALU, A9ReadALU], [IIC_iALUi, IIC_iCMPi, IIC_iCMPsi]>; 2296def :ItinRW<[WriteALU, A9ReadALU, A9ReadALU],[IIC_iALUr,IIC_iCMPr]>; 2297def :ItinRW<[WriteALUsi], [IIC_iBITsi,IIC_iUNAsi,IIC_iEXTr,IIC_iTSTsi]>; 2298def :ItinRW<[WriteALUsi, A9ReadALU], [IIC_iALUsi]>; 2299def :ItinRW<[WriteALUsi, ReadDefault, A9ReadALU], [IIC_iALUsir]>; // RSB 2300def :ItinRW<[A9WriteALUsr], [IIC_iBITsr,IIC_iTSTsr,IIC_iEXTAr,IIC_iEXTAsr]>; 2301def :ItinRW<[A9WriteALUsr, A9ReadALU], [IIC_iALUsr,IIC_iCMPsr]>; 2302 2303// A9WriteHi ignored for MUL32. 2304def :ItinRW<[A9WriteM, A9WriteMHi], [IIC_iMUL32,IIC_iMAC32, 2305 IIC_iMUL64,IIC_iMAC64]>; 2306// FIXME: SMLALxx needs itin classes 2307def :ItinRW<[A9WriteM16, A9WriteM16Hi], [IIC_iMUL16,IIC_iMAC16]>; 2308 2309// TODO: For floating-point ops, we model the pipeline forwarding 2310// latencies here. WAW latencies are sometimes longer. 2311 2312def :ItinRW<[A9WriteFMov], [IIC_fpSTAT, IIC_fpMOVIS, IIC_fpMOVID, IIC_fpMOVSI, 2313 IIC_fpUNA32, IIC_fpUNA64, 2314 IIC_fpCMP32, IIC_fpCMP64]>; 2315def :ItinRW<[A9WriteFMov, A9WriteFMov], [IIC_fpMOVDI]>; 2316def :ItinRW<[A9WriteF], [IIC_fpCVTSD, IIC_fpCVTDS, IIC_fpCVTSH, IIC_fpCVTHS, 2317 IIC_fpCVTIS, IIC_fpCVTID, IIC_fpCVTSI, IIC_fpCVTDI, 2318 IIC_fpALU32, IIC_fpALU64]>; 2319def :ItinRW<[A9WriteFMulS], [IIC_fpMUL32]>; 2320def :ItinRW<[A9WriteFMulD], [IIC_fpMUL64]>; 2321def :ItinRW<[A9WriteFMAS], [IIC_fpMAC32]>; 2322def :ItinRW<[A9WriteFMAD], [IIC_fpMAC64]>; 2323def :ItinRW<[A9WriteFDivS], [IIC_fpDIV32]>; 2324def :ItinRW<[A9WriteFDivD], [IIC_fpDIV64]>; 2325def :ItinRW<[A9WriteFSqrtS], [IIC_fpSQRT32]>; 2326def :ItinRW<[A9WriteFSqrtD], [IIC_fpSQRT64]>; 2327 2328def :ItinRW<[A9WriteB], [IIC_Br]>; 2329 2330// A9 PLD is processed in a dedicated unit. 2331def :ItinRW<[], [IIC_Preload]>; 2332 2333// Note: We must assume that loads are aligned, since the machine 2334// model cannot know this statically and A9 ignores alignment hints. 2335 2336// A9WriteAdr consumes AGU regardless address writeback. But it's 2337// latency is only relevant for users of an updated address. 2338def :ItinRW<[A9WriteL, A9WriteAdr], [IIC_iLoad_i,IIC_iLoad_r, 2339 IIC_iLoad_iu,IIC_iLoad_ru]>; 2340def :ItinRW<[A9WriteLsi, A9WriteAdr], [IIC_iLoad_si,IIC_iLoad_siu]>; 2341def :ItinRW<[A9WriteLb, A9WriteAdr2], [IIC_iLoad_bh_i,IIC_iLoad_bh_r, 2342 IIC_iLoad_bh_iu,IIC_iLoad_bh_ru]>; 2343def :ItinRW<[A9WriteLbsi, A9WriteAdr2], [IIC_iLoad_bh_si,IIC_iLoad_bh_siu]>; 2344def :ItinRW<[A9WriteL, A9WriteLHi, A9WriteAdr], [IIC_iLoad_d_i,IIC_iLoad_d_r, 2345 IIC_iLoad_d_ru]>; 2346// Store either has no def operands, or the one def for address writeback. 2347def :ItinRW<[A9WriteAdr, A9WriteS], [IIC_iStore_i, IIC_iStore_r, 2348 IIC_iStore_iu, IIC_iStore_ru, 2349 IIC_iStore_d_i, IIC_iStore_d_r, 2350 IIC_iStore_d_ru]>; 2351def :ItinRW<[A9WriteAdr2, A9WriteS], [IIC_iStore_si, IIC_iStore_siu, 2352 IIC_iStore_bh_i, IIC_iStore_bh_r, 2353 IIC_iStore_bh_iu, IIC_iStore_bh_ru]>; 2354def :ItinRW<[A9WriteAdr3, A9WriteS], [IIC_iStore_bh_si, IIC_iStore_bh_siu]>; 2355 2356// A9WriteML will be expanded into a separate write for each def 2357// operand. Address generation consumes resources, but A9WriteLMAdr 2358// is listed after all def operands, so has no effective latency. 2359// 2360// Note: A9WriteLM expands into an even number of def operands. The 2361// actual number of def operands may be less by one. 2362def :ItinRW<[A9WriteLM, A9WriteLMAdr, A9WriteIssue], [IIC_iLoad_m, IIC_iPop]>; 2363 2364// Load multiple with address writeback has an extra def operand in 2365// front of the loaded registers. 2366// 2367// Reuse the load-multiple variants for store-multiple because the 2368// resources are identical, For stores only the address writeback 2369// has a def operand so the WriteL latencies are unused. 2370def :ItinRW<[A9WriteLMAdr, A9WriteLM, A9WriteIssue], [IIC_iLoad_mu, 2371 IIC_iStore_m, 2372 IIC_iStore_mu]>; 2373def :ItinRW<[A9WriteLM, A9WriteLMAdr, A9WriteB], [IIC_iLoad_mBr, IIC_iPop_Br]>; 2374def :ItinRW<[A9WriteL, A9WriteAdr, WriteALU], [IIC_iLoadiALU]>; 2375 2376def :ItinRW<[A9WriteLSfp, A9WriteAdr], [IIC_fpLoad32, IIC_fpLoad64]>; 2377 2378def :ItinRW<[A9WriteLMfp, A9WriteLMAdr], [IIC_fpLoad_m]>; 2379def :ItinRW<[A9WriteLMAdr, A9WriteLMfp], [IIC_fpLoad_mu]>; 2380def :ItinRW<[A9WriteAdr, A9WriteLSfp], [IIC_fpStore32, IIC_fpStore64, 2381 IIC_fpStore_m, IIC_fpStore_mu]>; 2382 2383// Note: Unlike VLDM, VLD1 expects the writeback operand after the 2384// normal writes. 2385def :ItinRW<[A9WriteLfp1, A9WriteAdr1], [IIC_VLD1, IIC_VLD1u, 2386 IIC_VLD1x2, IIC_VLD1x2u]>; 2387def :ItinRW<[A9WriteLfp2, A9WriteAdr2], [IIC_VLD1x3, IIC_VLD1x3u, 2388 IIC_VLD1x4, IIC_VLD1x4u, 2389 IIC_VLD4dup, IIC_VLD4dupu]>; 2390def :ItinRW<[A9WriteLfp1Mov, A9WriteAdr1], [IIC_VLD1dup, IIC_VLD1dupu, 2391 IIC_VLD2, IIC_VLD2u, 2392 IIC_VLD2dup, IIC_VLD2dupu]>; 2393def :ItinRW<[A9WriteLfp2Mov, A9WriteAdr1], [IIC_VLD1ln, IIC_VLD1lnu, 2394 IIC_VLD2x2, IIC_VLD2x2u, 2395 IIC_VLD2ln, IIC_VLD2lnu]>; 2396def :ItinRW<[A9WriteLfp3Mov, A9WriteAdr3], [IIC_VLD3, IIC_VLD3u, 2397 IIC_VLD3dup, IIC_VLD3dupu]>; 2398def :ItinRW<[A9WriteLfp4Mov, A9WriteAdr4], [IIC_VLD4, IIC_VLD4u, 2399 IIC_VLD4ln, IIC_VLD4lnu]>; 2400def :ItinRW<[A9WriteLfp5Mov, A9WriteAdr5], [IIC_VLD3ln, IIC_VLD3lnu]>; 2401 2402// Vector stores use similar resources to vector loads, so use the 2403// same write types. The address write must be first for stores with 2404// address writeback. 2405def :ItinRW<[A9WriteAdr1, A9WriteLfp1], [IIC_VST1, IIC_VST1u, 2406 IIC_VST1x2, IIC_VST1x2u, 2407 IIC_VST1ln, IIC_VST1lnu, 2408 IIC_VST2, IIC_VST2u, 2409 IIC_VST2x2, IIC_VST2x2u, 2410 IIC_VST2ln, IIC_VST2lnu]>; 2411def :ItinRW<[A9WriteAdr2, A9WriteLfp2], [IIC_VST1x3, IIC_VST1x3u, 2412 IIC_VST1x4, IIC_VST1x4u, 2413 IIC_VST3, IIC_VST3u, 2414 IIC_VST3ln, IIC_VST3lnu, 2415 IIC_VST4, IIC_VST4u, 2416 IIC_VST4ln, IIC_VST4lnu]>; 2417 2418// NEON moves. 2419def :ItinRW<[A9WriteV2], [IIC_VMOVSI, IIC_VMOVDI, IIC_VMOVD, IIC_VMOVQ]>; 2420def :ItinRW<[A9WriteV1], [IIC_VMOV, IIC_VMOVIS, IIC_VMOVID]>; 2421def :ItinRW<[A9WriteV3], [IIC_VMOVISL, IIC_VMOVN]>; 2422 2423// NEON integer arithmetic 2424// 2425// VADD/VAND/VORR/VEOR/VBIC/VORN/VBIT/VBIF/VBSL 2426def :ItinRW<[A9WriteV3, A9Read2, A9Read2], [IIC_VBINiD, IIC_VBINiQ]>; 2427// VSUB/VMVN/VCLSD/VCLZD/VCNTD 2428def :ItinRW<[A9WriteV3, A9Read2], [IIC_VSUBiD, IIC_VSUBiQ, IIC_VCNTiD]>; 2429// VADDL/VSUBL/VNEG are mapped later under IIC_SHLi. 2430// ... 2431// VHADD/VRHADD/VQADD/VTST/VADH/VRADH 2432def :ItinRW<[A9WriteV4, A9Read2, A9Read2], [IIC_VBINi4D, IIC_VBINi4Q]>; 2433 2434// VSBH/VRSBH/VHSUB/VQSUB/VABD/VCEQ/VCGE/VCGT/VMAX/VMIN/VPMAX/VPMIN/VABDL 2435def :ItinRW<[A9WriteV4, A9Read2], [IIC_VSUBi4D, IIC_VSUBi4Q]>; 2436// VQNEG/VQABS 2437def :ItinRW<[A9WriteV4], [IIC_VQUNAiD, IIC_VQUNAiQ]>; 2438// VABS 2439def :ItinRW<[A9WriteV4, A9Read2], [IIC_VUNAiD, IIC_VUNAiQ]>; 2440// VPADD/VPADDL are mapped later under IIC_SHLi. 2441// ... 2442// VCLSQ/VCLZQ/VCNTQ, takes two cycles. 2443def :ItinRW<[A9Write2V4, A9Read3], [IIC_VCNTiQ]>; 2444// VMOVimm/VMVNimm/VORRimm/VBICimm 2445def :ItinRW<[A9WriteV3], [IIC_VMOVImm]>; 2446def :ItinRW<[A9WriteV6, A9Read3, A9Read2], [IIC_VABAD, IIC_VABAQ]>; 2447def :ItinRW<[A9WriteV6, A9Read3], [IIC_VPALiD, IIC_VPALiQ]>; 2448 2449// NEON integer multiply 2450// 2451// Note: these don't quite match the timing docs, but they do match 2452// the original A9 itinerary. 2453def :ItinRW<[A9WriteV6, A9Read2, A9Read2], [IIC_VMULi16D]>; 2454def :ItinRW<[A9WriteV7, A9Read2, A9Read2], [IIC_VMULi16Q]>; 2455def :ItinRW<[A9Write2V7, A9Read2], [IIC_VMULi32D]>; 2456def :ItinRW<[A9Write2V9, A9Read2], [IIC_VMULi32Q]>; 2457def :ItinRW<[A9WriteV6, A9Read3, A9Read2, A9Read2], [IIC_VMACi16D]>; 2458def :ItinRW<[A9WriteV7, A9Read3, A9Read2, A9Read2], [IIC_VMACi16Q]>; 2459def :ItinRW<[A9Write2V7, A9Read3, A9Read2], [IIC_VMACi32D]>; 2460def :ItinRW<[A9Write2V9, A9Read3, A9Read2], [IIC_VMACi32Q]>; 2461 2462// NEON integer shift 2463// TODO: Q,Q,Q shifts should actually reserve FP for 2 cycles. 2464def :ItinRW<[A9WriteV3], [IIC_VSHLiD, IIC_VSHLiQ]>; 2465def :ItinRW<[A9WriteV4], [IIC_VSHLi4D, IIC_VSHLi4Q]>; 2466 2467// NEON permute 2468def :ItinRW<[A9WriteV2, A9WriteV2], [IIC_VPERMD, IIC_VPERMQ, IIC_VEXTD]>; 2469def :ItinRW<[A9WriteV3, A9WriteV4, ReadDefault, A9Read2], 2470 [IIC_VPERMQ3, IIC_VEXTQ]>; 2471def :ItinRW<[A9WriteV3, A9Read2], [IIC_VTB1]>; 2472def :ItinRW<[A9WriteV3, A9Read2, A9Read2], [IIC_VTB2]>; 2473def :ItinRW<[A9WriteV4, A9Read2, A9Read2, A9Read3], [IIC_VTB3]>; 2474def :ItinRW<[A9WriteV4, A9Read2, A9Read2, A9Read3, A9Read3], [IIC_VTB4]>; 2475def :ItinRW<[A9WriteV3, ReadDefault, A9Read2], [IIC_VTBX1]>; 2476def :ItinRW<[A9WriteV3, ReadDefault, A9Read2, A9Read2], [IIC_VTBX2]>; 2477def :ItinRW<[A9WriteV4, ReadDefault, A9Read2, A9Read2, A9Read3], [IIC_VTBX3]>; 2478def :ItinRW<[A9WriteV4, ReadDefault, A9Read2, A9Read2, A9Read3, A9Read3], 2479 [IIC_VTBX4]>; 2480 2481// NEON floating-point 2482def :ItinRW<[A9WriteV5, A9Read2, A9Read2], [IIC_VBIND]>; 2483def :ItinRW<[A9WriteV6, A9Read2, A9Read2], [IIC_VBINQ]>; 2484def :ItinRW<[A9WriteV5, A9Read2], [IIC_VUNAD, IIC_VFMULD]>; 2485def :ItinRW<[A9WriteV6, A9Read2], [IIC_VUNAQ, IIC_VFMULQ]>; 2486def :ItinRW<[A9WriteV9, A9Read3, A9Read2], [IIC_VMACD, IIC_VFMACD]>; 2487def :ItinRW<[A9WriteV10, A9Read3, A9Read2], [IIC_VMACQ, IIC_VFMACQ]>; 2488def :ItinRW<[A9WriteV9, A9Read2, A9Read2], [IIC_VRECSD]>; 2489def :ItinRW<[A9WriteV10, A9Read2, A9Read2], [IIC_VRECSQ]>; 2490 2491// Map SchedRWs that are identical for cortexa9 to existing resources. 2492def : SchedAlias<WriteALU, A9WriteALU>; 2493def : SchedAlias<WriteALUsr, A9WriteALUsr>; 2494def : SchedAlias<WriteALUSsr, A9WriteALUsr>; 2495def : SchedAlias<ReadALU, A9ReadALU>; 2496def : SchedAlias<ReadALUsr, A9ReadALU>; 2497def : SchedAlias<WriteST, A9WriteS>; 2498 2499// ===---------------------------------------------------------------------===// 2500// Floating-point. Map target defined SchedReadWrite to processor specific ones 2501// 2502def : WriteRes<WriteFPCVT, [A9UnitFP, A9UnitAGU]> { let Latency = 4; } 2503def : SchedAlias<WriteFPMOV, A9WriteFMov>; 2504 2505def : SchedAlias<WriteFPALU32, A9WriteF>; 2506def : SchedAlias<WriteFPALU64, A9WriteF>; 2507 2508def : SchedAlias<WriteFPMUL32, A9WriteFMulS>; 2509def : SchedAlias<WriteFPMUL64, A9WriteFMulD>; 2510 2511def : SchedAlias<WriteFPMAC32, A9WriteFMAS>; 2512def : SchedAlias<WriteFPMAC64, A9WriteFMAD>; 2513 2514def : SchedAlias<WriteFPDIV32, A9WriteFDivS>; 2515def : SchedAlias<WriteFPDIV64, A9WriteFDivD>; 2516def : SchedAlias<WriteFPSQRT32, A9WriteFSqrtS>; 2517def : SchedAlias<WriteFPSQRT64, A9WriteFSqrtD>; 2518 2519def : ReadAdvance<ReadFPMUL, 0>; 2520def : ReadAdvance<ReadFPMAC, 0>; 2521 2522// ===---------------------------------------------------------------------===// 2523// Subtarget-specific overrides. Map opcodes to list of SchedReadWrite types. 2524// 2525def : InstRW< [WriteALU], 2526 (instregex "ANDri", "ORRri", "EORri", "BICri", "ANDrr", "ORRrr", "EORrr", 2527 "BICrr")>; 2528def : InstRW< [WriteALUsi], (instrs ANDrsi, ORRrsi, EORrsi, BICrsi)>; 2529def : InstRW< [WriteALUsr], (instrs ANDrsr, ORRrsr, EORrsr, BICrsr)>; 2530 2531 2532def : SchedAlias<WriteCMP, A9WriteALU>; 2533def : SchedAlias<WriteCMPsi, A9WriteALU>; 2534def : SchedAlias<WriteCMPsr, A9WriteALU>; 2535 2536def : InstRW< [A9WriteIsr], (instregex "MOVsr", "MOVsi", "MVNsr", "MOVCCsi", 2537 "MOVCCsr")>; 2538def : InstRW< [WriteALU, A9ReadALU], (instregex "MVNr")>; 2539def : InstRW< [A9WriteI2], (instregex "MOVCCi32imm", "MOVi32imm")>; 2540def : InstRW< [A9WriteI2pc], (instregex "MOV_ga_pcrel")>; 2541def : InstRW< [A9WriteI2ld], (instregex "MOV_ga_pcrel_ldr")>; 2542 2543def : InstRW< [WriteALU], (instregex "SEL")>; 2544 2545def : InstRW< [WriteALUsi], (instregex "BFC", "BFI", "UBFX", "SBFX")>; 2546 2547def : InstRW< [A9WriteM], 2548 (instregex "MUL", "MULv5", "SMMUL", "SMMULR", "MLA", "MLAv5", "MLS", 2549 "SMMLA", "SMMLAR", "SMMLS", "SMMLSR")>; 2550def : InstRW< [A9WriteM, A9WriteMHi], 2551 (instregex "SMULL", "SMULLv5", "UMULL", "UMULLv5", "SMLAL$", "UMLAL", 2552 "UMAAL", "SMLALv5", "UMLALv5", "SMLALBB", "SMLALBT", "SMLALTB", 2553 "SMLALTT")>; 2554// FIXME: These instructions used to have NoItinerary. Just copied the one from above. 2555def : InstRW< [A9WriteM, A9WriteMHi], 2556 (instregex "SMLAD", "SMLADX", "SMLALD", "SMLALDX", "SMLSD", "SMLSDX", 2557 "SMLSLD", "SMLSLDX", "SMUAD", "SMUADX", "SMUSD", "SMUSDX")>; 2558 2559def : InstRW<[A9WriteM16, A9WriteM16Hi], 2560 (instregex "SMULBB", "SMULBT", "SMULTB", "SMULTT", "SMULWB", "SMULWT")>; 2561def : InstRW<[A9WriteM16, A9WriteM16Hi], 2562 (instregex "SMLABB", "SMLABT", "SMLATB", "SMLATT", "SMLAWB", "SMLAWT")>; 2563 2564def : InstRW<[A9WriteL], (instregex "LDRi12", "PICLDR$")>; 2565def : InstRW<[A9WriteLsi], (instregex "LDRrs")>; 2566def : InstRW<[A9WriteLb], 2567 (instregex "LDRBi12", "PICLDRH", "PICLDRB", "PICLDRSH", "PICLDRSB", 2568 "LDRH", "LDRSH", "LDRSB")>; 2569def : InstRW<[A9WriteLbsi], (instregex "LDRrs")>; 2570 2571def : WriteRes<WriteDIV, []> { let Latency = 0; } 2572 2573def : WriteRes<WriteBr, [A9UnitB]>; 2574def : WriteRes<WriteBrL, [A9UnitB]>; 2575def : WriteRes<WriteBrTbl, [A9UnitB]>; 2576def : WriteRes<WritePreLd, []>; 2577def : WriteRes<WriteNoop, []> { let Latency = 0; let NumMicroOps = 0; } 2578} // SchedModel = CortexA9Model 2579