1//=- AArch64SchedA57WriteRes.td - ARM Cortex-A57 Write Res ---*- tablegen -*-=// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9// 10// Contains all of the Cortex-A57 specific SchedWriteRes types. The approach 11// below is to define a generic SchedWriteRes for every combination of 12// latency and microOps. The naming conventions is to use a prefix, one field 13// for latency, and one or more microOp count/type designators. 14// Prefix: A57Write 15// Latency: #cyc 16// MicroOp Count/Types: #(B|I|M|L|S|X|W|V) 17// 18// e.g. A57Write_6cyc_1I_6S_4V means the total latency is 6 and there are 19// 11 micro-ops to be issued down one I pipe, six S pipes and four V pipes. 20// 21//===----------------------------------------------------------------------===// 22 23//===----------------------------------------------------------------------===// 24// Define Generic 1 micro-op types 25 26def A57Write_5cyc_1L : SchedWriteRes<[A57UnitL]> { let Latency = 5; } 27def A57Write_5cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 5; } 28def A57Write_5cyc_1V : SchedWriteRes<[A57UnitV]> { let Latency = 5; } 29def A57Write_5cyc_1W : SchedWriteRes<[A57UnitW]> { let Latency = 5; } 30def A57Write_10cyc_1V : SchedWriteRes<[A57UnitV]> { let Latency = 10; } 31def A57Write_18cyc_1X : SchedWriteRes<[A57UnitX]> { let Latency = 18; 32 let ResourceCycles = [18]; } 33def A57Write_19cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 19; 34 let ResourceCycles = [19]; } 35def A57Write_1cyc_1B : SchedWriteRes<[A57UnitB]> { let Latency = 1; } 36def A57Write_1cyc_1I : SchedWriteRes<[A57UnitI]> { let Latency = 1; } 37def A57Write_1cyc_1S : SchedWriteRes<[A57UnitS]> { let Latency = 1; } 38def A57Write_2cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 2; } 39def A57Write_32cyc_1X : SchedWriteRes<[A57UnitX]> { let Latency = 32; 40 let ResourceCycles = [32]; } 41def A57Write_35cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 35; 42 let ResourceCycles = [35]; } 43def A57Write_3cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 3; } 44def A57Write_3cyc_1V : SchedWriteRes<[A57UnitV]> { let Latency = 3; } 45def A57Write_3cyc_1W : SchedWriteRes<[A57UnitW]> { let Latency = 3; } 46def A57Write_3cyc_1X : SchedWriteRes<[A57UnitX]> { let Latency = 3; } 47def A57Write_4cyc_1L : SchedWriteRes<[A57UnitL]> { let Latency = 4; } 48def A57Write_4cyc_1X : SchedWriteRes<[A57UnitX]> { let Latency = 4; } 49def A57Write_9cyc_1V : SchedWriteRes<[A57UnitV]> { let Latency = 9; } 50def A57Write_6cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 6; } 51def A57Write_6cyc_1V : SchedWriteRes<[A57UnitV]> { let Latency = 6; } 52 53 54//===----------------------------------------------------------------------===// 55// Define Generic 2 micro-op types 56 57def A57Write_64cyc_2X : SchedWriteRes<[A57UnitX, A57UnitX]> { 58 let Latency = 64; 59 let NumMicroOps = 2; 60 let ResourceCycles = [32, 32]; 61} 62def A57Write_6cyc_1I_1L : SchedWriteRes<[A57UnitI, 63 A57UnitL]> { 64 let Latency = 6; 65 let NumMicroOps = 2; 66} 67def A57Write_7cyc_1V_1X : SchedWriteRes<[A57UnitV, 68 A57UnitX]> { 69 let Latency = 7; 70 let NumMicroOps = 2; 71} 72def A57Write_8cyc_1L_1V : SchedWriteRes<[A57UnitL, 73 A57UnitV]> { 74 let Latency = 8; 75 let NumMicroOps = 2; 76} 77def A57Write_9cyc_2V : SchedWriteRes<[A57UnitV, A57UnitV]> { 78 let Latency = 9; 79 let NumMicroOps = 2; 80} 81def A57Write_8cyc_2X : SchedWriteRes<[A57UnitX, A57UnitX]> { 82 let Latency = 8; 83 let NumMicroOps = 2; 84} 85def A57Write_6cyc_2L : SchedWriteRes<[A57UnitL, A57UnitL]> { 86 let Latency = 6; 87 let NumMicroOps = 2; 88} 89def A57Write_6cyc_2V : SchedWriteRes<[A57UnitV, A57UnitV]> { 90 let Latency = 6; 91 let NumMicroOps = 2; 92} 93def A57Write_6cyc_2W : SchedWriteRes<[A57UnitW, A57UnitW]> { 94 let Latency = 6; 95 let NumMicroOps = 2; 96} 97def A57Write_5cyc_1I_1L : SchedWriteRes<[A57UnitI, 98 A57UnitL]> { 99 let Latency = 5; 100 let NumMicroOps = 2; 101} 102def A57Write_5cyc_2V : SchedWriteRes<[A57UnitV, A57UnitV]> { 103 let Latency = 5; 104 let NumMicroOps = 2; 105} 106def A57Write_5cyc_2X : SchedWriteRes<[A57UnitX, A57UnitX]> { 107 let Latency = 5; 108 let NumMicroOps = 2; 109} 110def A57Write_10cyc_1L_1V : SchedWriteRes<[A57UnitL, 111 A57UnitV]> { 112 let Latency = 10; 113 let NumMicroOps = 2; 114} 115def A57Write_10cyc_2V : SchedWriteRes<[A57UnitV, A57UnitV]> { 116 let Latency = 10; 117 let NumMicroOps = 2; 118} 119def A57Write_1cyc_1B_1I : SchedWriteRes<[A57UnitB, 120 A57UnitI]> { 121 let Latency = 1; 122 let NumMicroOps = 2; 123} 124def A57Write_1cyc_1I_1S : SchedWriteRes<[A57UnitI, 125 A57UnitS]> { 126 let Latency = 1; 127 let NumMicroOps = 2; 128} 129def A57Write_2cyc_1B_1I : SchedWriteRes<[A57UnitB, 130 A57UnitI]> { 131 let Latency = 2; 132 let NumMicroOps = 2; 133} 134def A57Write_2cyc_2S : SchedWriteRes<[A57UnitS, A57UnitS]> { 135 let Latency = 2; 136 let NumMicroOps = 2; 137} 138def A57Write_2cyc_2V : SchedWriteRes<[A57UnitV, A57UnitV]> { 139 let Latency = 2; 140 let NumMicroOps = 2; 141} 142def A57Write_36cyc_2X : SchedWriteRes<[A57UnitX, A57UnitX]> { 143 let Latency = 36; 144 let NumMicroOps = 2; 145 let ResourceCycles = [18, 18]; 146} 147def A57Write_3cyc_1I_1M : SchedWriteRes<[A57UnitI, 148 A57UnitM]> { 149 let Latency = 3; 150 let NumMicroOps = 2; 151} 152def A57Write_3cyc_1I_1S : SchedWriteRes<[A57UnitI, 153 A57UnitS]> { 154 let Latency = 3; 155 let NumMicroOps = 2; 156} 157def A57Write_3cyc_1S_1V : SchedWriteRes<[A57UnitS, 158 A57UnitV]> { 159 let Latency = 3; 160 let NumMicroOps = 2; 161} 162def A57Write_3cyc_2V : SchedWriteRes<[A57UnitV, A57UnitV]> { 163 let Latency = 3; 164 let NumMicroOps = 2; 165} 166def A57Write_4cyc_1I_1L : SchedWriteRes<[A57UnitI, 167 A57UnitL]> { 168 let Latency = 4; 169 let NumMicroOps = 2; 170} 171def A57Write_4cyc_2X : SchedWriteRes<[A57UnitX, A57UnitX]> { 172 let Latency = 4; 173 let NumMicroOps = 2; 174} 175 176 177//===----------------------------------------------------------------------===// 178// Define Generic 3 micro-op types 179 180def A57Write_10cyc_3V : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> { 181 let Latency = 10; 182 let NumMicroOps = 3; 183} 184def A57Write_2cyc_1I_2S : SchedWriteRes<[A57UnitI, 185 A57UnitS, A57UnitS]> { 186 let Latency = 2; 187 let NumMicroOps = 3; 188} 189def A57Write_3cyc_1I_1S_1V : SchedWriteRes<[A57UnitI, 190 A57UnitS, 191 A57UnitV]> { 192 let Latency = 3; 193 let NumMicroOps = 3; 194} 195def A57Write_3cyc_1M_2S : SchedWriteRes<[A57UnitM, 196 A57UnitS, A57UnitS]> { 197 let Latency = 3; 198 let NumMicroOps = 3; 199} 200def A57Write_3cyc_3S : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS]> { 201 let Latency = 3; 202 let NumMicroOps = 3; 203} 204def A57Write_3cyc_2S_1V : SchedWriteRes<[A57UnitS, A57UnitS, 205 A57UnitV]> { 206 let Latency = 3; 207 let NumMicroOps = 3; 208} 209def A57Write_5cyc_1I_2L : SchedWriteRes<[A57UnitI, 210 A57UnitL, A57UnitL]> { 211 let Latency = 5; 212 let NumMicroOps = 3; 213} 214def A57Write_6cyc_1I_2L : SchedWriteRes<[A57UnitI, 215 A57UnitL, A57UnitL]> { 216 let Latency = 6; 217 let NumMicroOps = 3; 218} 219def A57Write_6cyc_3V : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> { 220 let Latency = 6; 221 let NumMicroOps = 3; 222} 223def A57Write_7cyc_3L : SchedWriteRes<[A57UnitL, A57UnitL, A57UnitL]> { 224 let Latency = 7; 225 let NumMicroOps = 3; 226} 227def A57Write_8cyc_1I_1L_1V : SchedWriteRes<[A57UnitI, 228 A57UnitL, 229 A57UnitV]> { 230 let Latency = 8; 231 let NumMicroOps = 3; 232} 233def A57Write_8cyc_1L_2V : SchedWriteRes<[A57UnitL, 234 A57UnitV, A57UnitV]> { 235 let Latency = 8; 236 let NumMicroOps = 3; 237} 238def A57Write_8cyc_3V : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> { 239 let Latency = 8; 240 let NumMicroOps = 3; 241} 242def A57Write_9cyc_3V : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> { 243 let Latency = 9; 244 let NumMicroOps = 3; 245} 246 247 248//===----------------------------------------------------------------------===// 249// Define Generic 4 micro-op types 250 251def A57Write_2cyc_2I_2S : SchedWriteRes<[A57UnitI, A57UnitI, 252 A57UnitS, A57UnitS]> { 253 let Latency = 2; 254 let NumMicroOps = 4; 255} 256def A57Write_3cyc_2I_2S : SchedWriteRes<[A57UnitI, A57UnitI, 257 A57UnitS, A57UnitS]> { 258 let Latency = 3; 259 let NumMicroOps = 4; 260} 261def A57Write_3cyc_1I_3S : SchedWriteRes<[A57UnitI, 262 A57UnitS, A57UnitS, A57UnitS]> { 263 let Latency = 3; 264 let NumMicroOps = 4; 265} 266def A57Write_3cyc_1I_2S_1V : SchedWriteRes<[A57UnitI, 267 A57UnitS, A57UnitS, 268 A57UnitV]> { 269 let Latency = 3; 270 let NumMicroOps = 4; 271} 272def A57Write_4cyc_4S : SchedWriteRes<[A57UnitS, A57UnitS, 273 A57UnitS, A57UnitS]> { 274 let Latency = 4; 275 let NumMicroOps = 4; 276} 277def A57Write_7cyc_1I_3L : SchedWriteRes<[A57UnitI, 278 A57UnitL, A57UnitL, A57UnitL]> { 279 let Latency = 7; 280 let NumMicroOps = 4; 281} 282def A57Write_5cyc_2I_2L : SchedWriteRes<[A57UnitI, A57UnitI, 283 A57UnitL, A57UnitL]> { 284 let Latency = 5; 285 let NumMicroOps = 4; 286} 287def A57Write_8cyc_1I_1L_2V : SchedWriteRes<[A57UnitI, 288 A57UnitL, 289 A57UnitV, A57UnitV]> { 290 let Latency = 8; 291 let NumMicroOps = 4; 292} 293def A57Write_8cyc_4L : SchedWriteRes<[A57UnitL, A57UnitL, 294 A57UnitL, A57UnitL]> { 295 let Latency = 8; 296 let NumMicroOps = 4; 297} 298def A57Write_9cyc_2L_2V : SchedWriteRes<[A57UnitL, A57UnitL, 299 A57UnitV, A57UnitV]> { 300 let Latency = 9; 301 let NumMicroOps = 4; 302} 303def A57Write_9cyc_1L_3V : SchedWriteRes<[A57UnitL, 304 A57UnitV, A57UnitV, A57UnitV]> { 305 let Latency = 9; 306 let NumMicroOps = 4; 307} 308def A57Write_12cyc_4V : SchedWriteRes<[A57UnitV, A57UnitV, 309 A57UnitV, A57UnitV]> { 310 let Latency = 12; 311 let NumMicroOps = 4; 312} 313 314 315//===----------------------------------------------------------------------===// 316// Define Generic 5 micro-op types 317 318def A57Write_3cyc_3S_2V : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS, 319 A57UnitV, A57UnitV]> { 320 let Latency = 3; 321 let NumMicroOps = 5; 322} 323def A57Write_8cyc_1I_4L : SchedWriteRes<[A57UnitI, 324 A57UnitL, A57UnitL, 325 A57UnitL, A57UnitL]> { 326 let Latency = 8; 327 let NumMicroOps = 5; 328} 329def A57Write_4cyc_1I_4S : SchedWriteRes<[A57UnitI, 330 A57UnitS, A57UnitS, 331 A57UnitS, A57UnitS]> { 332 let Latency = 4; 333 let NumMicroOps = 5; 334} 335def A57Write_9cyc_1I_2L_2V : SchedWriteRes<[A57UnitI, 336 A57UnitL, A57UnitL, 337 A57UnitV, A57UnitV]> { 338 let Latency = 9; 339 let NumMicroOps = 5; 340} 341def A57Write_9cyc_1I_1L_3V : SchedWriteRes<[A57UnitI, 342 A57UnitL, 343 A57UnitV, A57UnitV, A57UnitV]> { 344 let Latency = 9; 345 let NumMicroOps = 5; 346} 347def A57Write_9cyc_2L_3V : SchedWriteRes<[A57UnitL, A57UnitL, 348 A57UnitV, A57UnitV, A57UnitV]> { 349 let Latency = 9; 350 let NumMicroOps = 5; 351} 352def A57Write_9cyc_5V : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV, 353 A57UnitV, A57UnitV]> { 354 let Latency = 9; 355 let NumMicroOps = 5; 356} 357 358 359//===----------------------------------------------------------------------===// 360// Define Generic 6 micro-op types 361 362def A57Write_3cyc_1I_3S_2V : SchedWriteRes<[A57UnitI, 363 A57UnitS, A57UnitS, A57UnitS, 364 A57UnitV, A57UnitV]> { 365 let Latency = 3; 366 let NumMicroOps = 6; 367} 368def A57Write_4cyc_2I_4S : SchedWriteRes<[A57UnitI, A57UnitI, 369 A57UnitS, A57UnitS, 370 A57UnitS, A57UnitS]> { 371 let Latency = 4; 372 let NumMicroOps = 6; 373} 374def A57Write_4cyc_4S_2V : SchedWriteRes<[A57UnitS, A57UnitS, 375 A57UnitS, A57UnitS, 376 A57UnitV, A57UnitV]> { 377 let Latency = 4; 378 let NumMicroOps = 6; 379} 380def A57Write_6cyc_6S : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS, 381 A57UnitS, A57UnitS, A57UnitS]> { 382 let Latency = 6; 383 let NumMicroOps = 6; 384} 385def A57Write_9cyc_1I_2L_3V : SchedWriteRes<[A57UnitI, 386 A57UnitL, A57UnitL, 387 A57UnitV, A57UnitV, A57UnitV]> { 388 let Latency = 9; 389 let NumMicroOps = 6; 390} 391def A57Write_9cyc_1I_1L_4V : SchedWriteRes<[A57UnitI, 392 A57UnitL, 393 A57UnitV, A57UnitV, 394 A57UnitV, A57UnitV]> { 395 let Latency = 9; 396 let NumMicroOps = 6; 397} 398def A57Write_9cyc_2L_4V : SchedWriteRes<[A57UnitL, A57UnitL, 399 A57UnitV, A57UnitV, 400 A57UnitV, A57UnitV]> { 401 let Latency = 9; 402 let NumMicroOps = 6; 403} 404 405 406//===----------------------------------------------------------------------===// 407// Define Generic 7 micro-op types 408 409def A57Write_10cyc_3L_4V : SchedWriteRes<[A57UnitL, A57UnitL, A57UnitL, 410 A57UnitV, A57UnitV, 411 A57UnitV, A57UnitV]> { 412 let Latency = 10; 413 let NumMicroOps = 7; 414} 415def A57Write_4cyc_1I_4S_2V : SchedWriteRes<[A57UnitI, 416 A57UnitS, A57UnitS, 417 A57UnitS, A57UnitS, 418 A57UnitV, A57UnitV]> { 419 let Latency = 4; 420 let NumMicroOps = 7; 421} 422def A57Write_6cyc_1I_6S : SchedWriteRes<[A57UnitI, 423 A57UnitS, A57UnitS, A57UnitS, 424 A57UnitS, A57UnitS, A57UnitS]> { 425 let Latency = 6; 426 let NumMicroOps = 7; 427} 428def A57Write_9cyc_1I_2L_4V : SchedWriteRes<[A57UnitI, 429 A57UnitL, A57UnitL, 430 A57UnitV, A57UnitV, 431 A57UnitV, A57UnitV]> { 432 let Latency = 9; 433 let NumMicroOps = 7; 434} 435def A57Write_12cyc_7V : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV, 436 A57UnitV, A57UnitV, 437 A57UnitV, A57UnitV]> { 438 let Latency = 12; 439 let NumMicroOps = 7; 440} 441 442 443//===----------------------------------------------------------------------===// 444// Define Generic 8 micro-op types 445 446def A57Write_10cyc_1I_3L_4V : SchedWriteRes<[A57UnitI, 447 A57UnitL, A57UnitL, A57UnitL, 448 A57UnitV, A57UnitV, 449 A57UnitV, A57UnitV]> { 450 let Latency = 10; 451 let NumMicroOps = 8; 452} 453def A57Write_11cyc_4L_4V : SchedWriteRes<[A57UnitL, A57UnitL, 454 A57UnitL, A57UnitL, 455 A57UnitV, A57UnitV, 456 A57UnitV, A57UnitV]> { 457 let Latency = 11; 458 let NumMicroOps = 8; 459} 460def A57Write_8cyc_8S : SchedWriteRes<[A57UnitS, A57UnitS, 461 A57UnitS, A57UnitS, 462 A57UnitS, A57UnitS, 463 A57UnitS, A57UnitS]> { 464 let Latency = 8; 465 let NumMicroOps = 8; 466} 467 468 469//===----------------------------------------------------------------------===// 470// Define Generic 9 micro-op types 471 472def A57Write_8cyc_1I_8S : SchedWriteRes<[A57UnitI, 473 A57UnitS, A57UnitS, 474 A57UnitS, A57UnitS, 475 A57UnitS, A57UnitS, 476 A57UnitS, A57UnitS]> { 477 let Latency = 8; 478 let NumMicroOps = 9; 479} 480def A57Write_11cyc_1I_4L_4V : SchedWriteRes<[A57UnitI, 481 A57UnitL, A57UnitL, 482 A57UnitL, A57UnitL, 483 A57UnitV, A57UnitV, 484 A57UnitV, A57UnitV]> { 485 let Latency = 11; 486 let NumMicroOps = 9; 487} 488def A57Write_15cyc_9V : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV, 489 A57UnitV, A57UnitV, A57UnitV, 490 A57UnitV, A57UnitV, A57UnitV]> { 491 let Latency = 15; 492 let NumMicroOps = 9; 493} 494 495 496//===----------------------------------------------------------------------===// 497// Define Generic 10 micro-op types 498 499def A57Write_6cyc_6S_4V : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS, 500 A57UnitS, A57UnitS, A57UnitS, 501 A57UnitV, A57UnitV, 502 A57UnitV, A57UnitV]> { 503 let Latency = 6; 504 let NumMicroOps = 10; 505} 506 507 508//===----------------------------------------------------------------------===// 509// Define Generic 11 micro-op types 510 511def A57Write_6cyc_1I_6S_4V : SchedWriteRes<[A57UnitI, 512 A57UnitS, A57UnitS, A57UnitS, 513 A57UnitS, A57UnitS, A57UnitS, 514 A57UnitV, A57UnitV, 515 A57UnitV, A57UnitV]> { 516 let Latency = 6; 517 let NumMicroOps = 11; 518} 519 520 521//===----------------------------------------------------------------------===// 522// Define Generic 12 micro-op types 523 524def A57Write_8cyc_8S_4V : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS, A57UnitS, 525 A57UnitS, A57UnitS, A57UnitS, A57UnitS, 526 A57UnitV, A57UnitV, 527 A57UnitV, A57UnitV]> { 528 let Latency = 8; 529 let NumMicroOps = 12; 530} 531 532//===----------------------------------------------------------------------===// 533// Define Generic 13 micro-op types 534 535def A57Write_8cyc_1I_8S_4V : SchedWriteRes<[A57UnitI, 536 A57UnitS, A57UnitS, A57UnitS, 537 A57UnitS, A57UnitS, A57UnitS, 538 A57UnitS, A57UnitS, 539 A57UnitV, A57UnitV, 540 A57UnitV, A57UnitV]> { 541 let Latency = 8; 542 let NumMicroOps = 13; 543} 544 545