1# NOTE: Assertions have been autogenerated by utils/update_mca_test_checks.py 2# RUN: llvm-mca -mtriple=x86_64-unknown-unknown -mcpu=znver3 -iterations=100 -timeline -register-file-stats < %s | FileCheck %s 3 4movq %mm0, %mm1 5movq %mm1, %mm2 6movq %mm2, %mm3 7movq %mm3, %mm4 8movq %mm4, %mm5 9movq %mm5, %mm6 10movq %mm6, %mm7 11movq %mm7, %mm0 12 13# CHECK: Iterations: 100 14# CHECK-NEXT: Instructions: 800 15# CHECK-NEXT: Total Cycles: 803 16# CHECK-NEXT: Total uOps: 800 17 18# CHECK: Dispatch Width: 6 19# CHECK-NEXT: uOps Per Cycle: 1.00 20# CHECK-NEXT: IPC: 1.00 21# CHECK-NEXT: Block RThroughput: 2.0 22 23# CHECK: Instruction Info: 24# CHECK-NEXT: [1]: #uOps 25# CHECK-NEXT: [2]: Latency 26# CHECK-NEXT: [3]: RThroughput 27# CHECK-NEXT: [4]: MayLoad 28# CHECK-NEXT: [5]: MayStore 29# CHECK-NEXT: [6]: HasSideEffects (U) 30 31# CHECK: [1] [2] [3] [4] [5] [6] Instructions: 32# CHECK-NEXT: 1 1 0.25 movq %mm0, %mm1 33# CHECK-NEXT: 1 1 0.25 movq %mm1, %mm2 34# CHECK-NEXT: 1 1 0.25 movq %mm2, %mm3 35# CHECK-NEXT: 1 1 0.25 movq %mm3, %mm4 36# CHECK-NEXT: 1 1 0.25 movq %mm4, %mm5 37# CHECK-NEXT: 1 1 0.25 movq %mm5, %mm6 38# CHECK-NEXT: 1 1 0.25 movq %mm6, %mm7 39# CHECK-NEXT: 1 1 0.25 movq %mm7, %mm0 40 41# CHECK: Register File statistics: 42# CHECK-NEXT: Total number of mappings created: 800 43# CHECK-NEXT: Max number of mappings used: 66 44 45# CHECK: * Register File #1 -- Zn3FpPRF: 46# CHECK-NEXT: Number of physical registers: 160 47# CHECK-NEXT: Total number of mappings created: 800 48# CHECK-NEXT: Max number of mappings used: 66 49 50# CHECK: * Register File #2 -- Zn3IntegerPRF: 51# CHECK-NEXT: Number of physical registers: 192 52# CHECK-NEXT: Total number of mappings created: 0 53# CHECK-NEXT: Max number of mappings used: 0 54 55# CHECK: Resources: 56# CHECK-NEXT: [0] - Zn3AGU0 57# CHECK-NEXT: [1] - Zn3AGU1 58# CHECK-NEXT: [2] - Zn3AGU2 59# CHECK-NEXT: [3] - Zn3ALU0 60# CHECK-NEXT: [4] - Zn3ALU1 61# CHECK-NEXT: [5] - Zn3ALU2 62# CHECK-NEXT: [6] - Zn3ALU3 63# CHECK-NEXT: [7] - Zn3BRU1 64# CHECK-NEXT: [8] - Zn3FP0 65# CHECK-NEXT: [9] - Zn3FP1 66# CHECK-NEXT: [10] - Zn3FP2 67# CHECK-NEXT: [11] - Zn3FP3 68# CHECK-NEXT: [12.0] - Zn3FP45 69# CHECK-NEXT: [12.1] - Zn3FP45 70# CHECK-NEXT: [13] - Zn3FPSt 71# CHECK-NEXT: [14.0] - Zn3LSU 72# CHECK-NEXT: [14.1] - Zn3LSU 73# CHECK-NEXT: [14.2] - Zn3LSU 74# CHECK-NEXT: [15.0] - Zn3Load 75# CHECK-NEXT: [15.1] - Zn3Load 76# CHECK-NEXT: [15.2] - Zn3Load 77# CHECK-NEXT: [16.0] - Zn3Store 78# CHECK-NEXT: [16.1] - Zn3Store 79 80# CHECK: Resource pressure per iteration: 81# CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12.0] [12.1] [13] [14.0] [14.1] [14.2] [15.0] [15.1] [15.2] [16.0] [16.1] 82# CHECK-NEXT: - - - - - - - - 2.00 2.00 2.00 2.00 - - - - - - - - - - - 83 84# CHECK: Resource pressure by instruction: 85# CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12.0] [12.1] [13] [14.0] [14.1] [14.2] [15.0] [15.1] [15.2] [16.0] [16.1] Instructions: 86# CHECK-NEXT: - - - - - - - - - - - 1.00 - - - - - - - - - - - movq %mm0, %mm1 87# CHECK-NEXT: - - - - - - - - - - 1.00 - - - - - - - - - - - - movq %mm1, %mm2 88# CHECK-NEXT: - - - - - - - - - 1.00 - - - - - - - - - - - - - movq %mm2, %mm3 89# CHECK-NEXT: - - - - - - - - 1.00 - - - - - - - - - - - - - - movq %mm3, %mm4 90# CHECK-NEXT: - - - - - - - - - - - 1.00 - - - - - - - - - - - movq %mm4, %mm5 91# CHECK-NEXT: - - - - - - - - - - 1.00 - - - - - - - - - - - - movq %mm5, %mm6 92# CHECK-NEXT: - - - - - - - - - 1.00 - - - - - - - - - - - - - movq %mm6, %mm7 93# CHECK-NEXT: - - - - - - - - 1.00 - - - - - - - - - - - - - - movq %mm7, %mm0 94 95# CHECK: Timeline view: 96# CHECK-NEXT: 0123456789 0123456789 0123456789 0123456789 97# CHECK-NEXT: Index 0123456789 0123456789 0123456789 0123456789 98 99# CHECK: [0,0] DeER . . . . . . . . . . . . . . . . movq %mm0, %mm1 100# CHECK-NEXT: [0,1] D=eER. . . . . . . . . . . . . . . . movq %mm1, %mm2 101# CHECK-NEXT: [0,2] D==eER . . . . . . . . . . . . . . . movq %mm2, %mm3 102# CHECK-NEXT: [0,3] D===eER . . . . . . . . . . . . . . . movq %mm3, %mm4 103# CHECK-NEXT: [0,4] D====eER . . . . . . . . . . . . . . . movq %mm4, %mm5 104# CHECK-NEXT: [0,5] D=====eER . . . . . . . . . . . . . . . movq %mm5, %mm6 105# CHECK-NEXT: [0,6] .D=====eER. . . . . . . . . . . . . . . movq %mm6, %mm7 106# CHECK-NEXT: [0,7] .D======eER . . . . . . . . . . . . . . movq %mm7, %mm0 107# CHECK-NEXT: [1,0] .D=======eER . . . . . . . . . . . . . . movq %mm0, %mm1 108# CHECK-NEXT: [1,1] .D========eER . . . . . . . . . . . . . . movq %mm1, %mm2 109# CHECK-NEXT: [1,2] .D=========eER . . . . . . . . . . . . . . movq %mm2, %mm3 110# CHECK-NEXT: [1,3] .D==========eER. . . . . . . . . . . . . . movq %mm3, %mm4 111# CHECK-NEXT: [1,4] . D==========eER . . . . . . . . . . . . . movq %mm4, %mm5 112# CHECK-NEXT: [1,5] . D===========eER . . . . . . . . . . . . . movq %mm5, %mm6 113# CHECK-NEXT: [1,6] . D============eER . . . . . . . . . . . . . movq %mm6, %mm7 114# CHECK-NEXT: [1,7] . D=============eER . . . . . . . . . . . . . movq %mm7, %mm0 115# CHECK-NEXT: [2,0] . D==============eER. . . . . . . . . . . . . movq %mm0, %mm1 116# CHECK-NEXT: [2,1] . D===============eER . . . . . . . . . . . . movq %mm1, %mm2 117# CHECK-NEXT: [2,2] . D===============eER . . . . . . . . . . . . movq %mm2, %mm3 118# CHECK-NEXT: [2,3] . D================eER . . . . . . . . . . . . movq %mm3, %mm4 119# CHECK-NEXT: [2,4] . D=================eER . . . . . . . . . . . . movq %mm4, %mm5 120# CHECK-NEXT: [2,5] . D==================eER. . . . . . . . . . . . movq %mm5, %mm6 121# CHECK-NEXT: [2,6] . D===================eER . . . . . . . . . . . movq %mm6, %mm7 122# CHECK-NEXT: [2,7] . D====================eER . . . . . . . . . . . movq %mm7, %mm0 123# CHECK-NEXT: [3,0] . D====================eER . . . . . . . . . . . movq %mm0, %mm1 124# CHECK-NEXT: [3,1] . D=====================eER . . . . . . . . . . . movq %mm1, %mm2 125# CHECK-NEXT: [3,2] . D======================eER. . . . . . . . . . . movq %mm2, %mm3 126# CHECK-NEXT: [3,3] . D=======================eER . . . . . . . . . . movq %mm3, %mm4 127# CHECK-NEXT: [3,4] . D========================eER . . . . . . . . . . movq %mm4, %mm5 128# CHECK-NEXT: [3,5] . D=========================eER . . . . . . . . . . movq %mm5, %mm6 129# CHECK-NEXT: [3,6] . D=========================eER . . . . . . . . . . movq %mm6, %mm7 130# CHECK-NEXT: [3,7] . D==========================eER. . . . . . . . . . movq %mm7, %mm0 131# CHECK-NEXT: [4,0] . D===========================eER . . . . . . . . . movq %mm0, %mm1 132# CHECK-NEXT: [4,1] . D============================eER . . . . . . . . . movq %mm1, %mm2 133# CHECK-NEXT: [4,2] . D=============================eER . . . . . . . . . movq %mm2, %mm3 134# CHECK-NEXT: [4,3] . D==============================eER . . . . . . . . . movq %mm3, %mm4 135# CHECK-NEXT: [4,4] . .D==============================eER. . . . . . . . . movq %mm4, %mm5 136# CHECK-NEXT: [4,5] . .D===============================eER . . . . . . . . movq %mm5, %mm6 137# CHECK-NEXT: [4,6] . .D================================eER . . . . . . . . movq %mm6, %mm7 138# CHECK-NEXT: [4,7] . .D=================================eER . . . . . . . . movq %mm7, %mm0 139# CHECK-NEXT: [5,0] . .D==================================eER . . . . . . . . movq %mm0, %mm1 140# CHECK-NEXT: [5,1] . .D===================================eER. . . . . . . . movq %mm1, %mm2 141# CHECK-NEXT: [5,2] . . D===================================eER . . . . . . . movq %mm2, %mm3 142# CHECK-NEXT: [5,3] . . D====================================eER . . . . . . . movq %mm3, %mm4 143# CHECK-NEXT: [5,4] . . D=====================================eER . . . . . . . movq %mm4, %mm5 144# CHECK-NEXT: [5,5] . . D======================================eER . . . . . . . movq %mm5, %mm6 145# CHECK-NEXT: [5,6] . . D=======================================eER. . . . . . . movq %mm6, %mm7 146# CHECK-NEXT: [5,7] . . D========================================eER . . . . . . movq %mm7, %mm0 147# CHECK-NEXT: [6,0] . . D========================================eER . . . . . . movq %mm0, %mm1 148# CHECK-NEXT: [6,1] . . D=========================================eER . . . . . . movq %mm1, %mm2 149# CHECK-NEXT: [6,2] . . D==========================================eER . . . . . . movq %mm2, %mm3 150# CHECK-NEXT: [6,3] . . D===========================================eER. . . . . . movq %mm3, %mm4 151# CHECK-NEXT: [6,4] . . D============================================eER . . . . . movq %mm4, %mm5 152# CHECK-NEXT: [6,5] . . D=============================================eER . . . . . movq %mm5, %mm6 153# CHECK-NEXT: [6,6] . . D=============================================eER . . . . . movq %mm6, %mm7 154# CHECK-NEXT: [6,7] . . D==============================================eER . . . . . movq %mm7, %mm0 155# CHECK-NEXT: [7,0] . . D===============================================eER. . . . . movq %mm0, %mm1 156# CHECK-NEXT: [7,1] . . D================================================eER . . . . movq %mm1, %mm2 157# CHECK-NEXT: [7,2] . . D=================================================eER . . . . movq %mm2, %mm3 158# CHECK-NEXT: [7,3] . . D==================================================eER . . . . movq %mm3, %mm4 159# CHECK-NEXT: [7,4] . . D==================================================eER . . . . movq %mm4, %mm5 160# CHECK-NEXT: [7,5] . . D===================================================eER. . . . movq %mm5, %mm6 161# CHECK-NEXT: [7,6] . . D====================================================eER . . . movq %mm6, %mm7 162# CHECK-NEXT: [7,7] . . D=====================================================eER . . . movq %mm7, %mm0 163# CHECK-NEXT: [8,0] . . D======================================================eER . . . movq %mm0, %mm1 164# CHECK-NEXT: [8,1] . . D=======================================================eER . . . movq %mm1, %mm2 165# CHECK-NEXT: [8,2] . . .D=======================================================eER. . . movq %mm2, %mm3 166# CHECK-NEXT: [8,3] . . .D========================================================eER . . movq %mm3, %mm4 167# CHECK-NEXT: [8,4] . . .D=========================================================eER . . movq %mm4, %mm5 168# CHECK-NEXT: [8,5] . . .D==========================================================eER . . movq %mm5, %mm6 169# CHECK-NEXT: [8,6] . . .D===========================================================eER . . movq %mm6, %mm7 170# CHECK-NEXT: [8,7] . . .D============================================================eER. . movq %mm7, %mm0 171# CHECK-NEXT: [9,0] . . . D============================================================eER . movq %mm0, %mm1 172# CHECK-NEXT: [9,1] . . . D=============================================================eER . movq %mm1, %mm2 173# CHECK-NEXT: [9,2] . . . D==============================================================eER . movq %mm2, %mm3 174# CHECK-NEXT: [9,3] . . . D===============================================================eER. movq %mm3, %mm4 175# CHECK-NEXT: [9,4] . . . D===============================================================eER movq %mm4, %mm5 176# CHECK-NEXT: Truncated display due to cycle limit 177 178# CHECK: Average Wait times (based on the timeline view): 179# CHECK-NEXT: [0]: Executions 180# CHECK-NEXT: [1]: Average time spent waiting in a scheduler's queue 181# CHECK-NEXT: [2]: Average time spent waiting in a scheduler's queue while ready 182# CHECK-NEXT: [3]: Average time elapsed from WB until retire stage 183 184# CHECK: [0] [1] [2] [3] 185# CHECK-NEXT: 0. 10 31.3 0.1 0.0 movq %mm0, %mm1 186# CHECK-NEXT: 1. 10 32.3 0.0 0.0 movq %mm1, %mm2 187# CHECK-NEXT: 2. 10 33.0 0.0 0.0 movq %mm2, %mm3 188# CHECK-NEXT: 3. 10 34.0 0.0 0.0 movq %mm3, %mm4 189# CHECK-NEXT: 4. 10 34.6 0.0 0.0 movq %mm4, %mm5 190# CHECK-NEXT: 5. 10 35.5 0.0 0.0 movq %mm5, %mm6 191# CHECK-NEXT: 6. 10 36.1 0.0 0.0 movq %mm6, %mm7 192# CHECK-NEXT: 7. 10 37.0 0.0 0.0 movq %mm7, %mm0 193# CHECK-NEXT: 10 34.2 0.0 0.0 <total> 194