161c52af9SAndrea Di Biagio# NOTE: Assertions have been autogenerated by utils/update_mca_test_checks.py 261c52af9SAndrea Di Biagio# RUN: llvm-mca -mtriple=x86_64-unknown-unknown -mcpu=btver2 -iterations=1000 -timeline < %s | FileCheck %s 361c52af9SAndrea Di Biagio 461c52af9SAndrea Di Biagioadd %eax, %ecx 561c52af9SAndrea Di Biagioadd %esi, %eax 661c52af9SAndrea Di Biagioadd %eax, %edx 761c52af9SAndrea Di Biagio 861c52af9SAndrea Di Biagio# CHECK: Iterations: 1000 961c52af9SAndrea Di Biagio# CHECK-NEXT: Instructions: 3000 1061c52af9SAndrea Di Biagio# CHECK-NEXT: Total Cycles: 1506 11a2eee474SAndrea Di Biagio# CHECK-NEXT: Total uOps: 3000 12a2eee474SAndrea Di Biagio 13a2eee474SAndrea Di Biagio# CHECK: Dispatch Width: 2 14a2eee474SAndrea Di Biagio# CHECK-NEXT: uOps Per Cycle: 1.99 1561c52af9SAndrea Di Biagio# CHECK-NEXT: IPC: 1.99 1661c52af9SAndrea Di Biagio# CHECK-NEXT: Block RThroughput: 1.5 1761c52af9SAndrea Di Biagio 1861c52af9SAndrea Di Biagio# CHECK: Instruction Info: 1961c52af9SAndrea Di Biagio# CHECK-NEXT: [1]: #uOps 2061c52af9SAndrea Di Biagio# CHECK-NEXT: [2]: Latency 2161c52af9SAndrea Di Biagio# CHECK-NEXT: [3]: RThroughput 2261c52af9SAndrea Di Biagio# CHECK-NEXT: [4]: MayLoad 2361c52af9SAndrea Di Biagio# CHECK-NEXT: [5]: MayStore 24d2e2c053SAndrea Di Biagio# CHECK-NEXT: [6]: HasSideEffects (U) 2561c52af9SAndrea Di Biagio 2661c52af9SAndrea Di Biagio# CHECK: [1] [2] [3] [4] [5] [6] Instructions: 2761c52af9SAndrea Di Biagio# CHECK-NEXT: 1 1 0.50 addl %eax, %ecx 2861c52af9SAndrea Di Biagio# CHECK-NEXT: 1 1 0.50 addl %esi, %eax 2961c52af9SAndrea Di Biagio# CHECK-NEXT: 1 1 0.50 addl %eax, %edx 3061c52af9SAndrea Di Biagio 3161c52af9SAndrea Di Biagio# CHECK: Resources: 3261c52af9SAndrea Di Biagio# CHECK-NEXT: [0] - JALU0 3361c52af9SAndrea Di Biagio# CHECK-NEXT: [1] - JALU1 3461c52af9SAndrea Di Biagio# CHECK-NEXT: [2] - JDiv 3561c52af9SAndrea Di Biagio# CHECK-NEXT: [3] - JFPA 3661c52af9SAndrea Di Biagio# CHECK-NEXT: [4] - JFPM 3761c52af9SAndrea Di Biagio# CHECK-NEXT: [5] - JFPU0 3861c52af9SAndrea Di Biagio# CHECK-NEXT: [6] - JFPU1 3961c52af9SAndrea Di Biagio# CHECK-NEXT: [7] - JLAGU 4061c52af9SAndrea Di Biagio# CHECK-NEXT: [8] - JMul 4161c52af9SAndrea Di Biagio# CHECK-NEXT: [9] - JSAGU 4261c52af9SAndrea Di Biagio# CHECK-NEXT: [10] - JSTC 4361c52af9SAndrea Di Biagio# CHECK-NEXT: [11] - JVALU0 4461c52af9SAndrea Di Biagio# CHECK-NEXT: [12] - JVALU1 4561c52af9SAndrea Di Biagio# CHECK-NEXT: [13] - JVIMUL 4661c52af9SAndrea Di Biagio 4761c52af9SAndrea Di Biagio# CHECK: Resource pressure per iteration: 4861c52af9SAndrea Di Biagio# CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] 4961c52af9SAndrea Di Biagio# CHECK-NEXT: 1.50 1.50 - - - - - - - - - - - - 5061c52af9SAndrea Di Biagio 5161c52af9SAndrea Di Biagio# CHECK: Resource pressure by instruction: 5261c52af9SAndrea Di Biagio# CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] Instructions: 5361c52af9SAndrea Di Biagio# CHECK-NEXT: 0.50 0.50 - - - - - - - - - - - - addl %eax, %ecx 5461c52af9SAndrea Di Biagio# CHECK-NEXT: 0.50 0.50 - - - - - - - - - - - - addl %esi, %eax 5561c52af9SAndrea Di Biagio# CHECK-NEXT: 0.50 0.50 - - - - - - - - - - - - addl %eax, %edx 5661c52af9SAndrea Di Biagio 5761c52af9SAndrea Di Biagio# CHECK: Timeline view: 5861c52af9SAndrea Di Biagio# CHECK-NEXT: 0123456789 5961c52af9SAndrea Di Biagio# CHECK-NEXT: Index 0123456789 0 6061c52af9SAndrea Di Biagio 6161c52af9SAndrea Di Biagio# CHECK: [0,0] DeER . . . . addl %eax, %ecx 6261c52af9SAndrea Di Biagio# CHECK-NEXT: [0,1] DeER . . . . addl %esi, %eax 6361c52af9SAndrea Di Biagio# CHECK-NEXT: [0,2] .DeER. . . . addl %eax, %edx 6461c52af9SAndrea Di Biagio# CHECK-NEXT: [1,0] .DeER. . . . addl %eax, %ecx 6561c52af9SAndrea Di Biagio# CHECK-NEXT: [1,1] . DeER . . . addl %esi, %eax 6661c52af9SAndrea Di Biagio# CHECK-NEXT: [1,2] . D=eER . . . addl %eax, %edx 6761c52af9SAndrea Di Biagio# CHECK-NEXT: [2,0] . DeER . . . addl %eax, %ecx 6861c52af9SAndrea Di Biagio# CHECK-NEXT: [2,1] . D=eER . . . addl %esi, %eax 6961c52af9SAndrea Di Biagio# CHECK-NEXT: [2,2] . D=eER . . . addl %eax, %edx 7061c52af9SAndrea Di Biagio# CHECK-NEXT: [3,0] . D=eER . . . addl %eax, %ecx 7161c52af9SAndrea Di Biagio# CHECK-NEXT: [3,1] . D=eER. . . addl %esi, %eax 7261c52af9SAndrea Di Biagio# CHECK-NEXT: [3,2] . D==eER . . addl %eax, %edx 7361c52af9SAndrea Di Biagio# CHECK-NEXT: [4,0] . .D=eER . . addl %eax, %ecx 7461c52af9SAndrea Di Biagio# CHECK-NEXT: [4,1] . .D==eER . . addl %esi, %eax 7561c52af9SAndrea Di Biagio# CHECK-NEXT: [4,2] . . D==eER . . addl %eax, %edx 7661c52af9SAndrea Di Biagio# CHECK-NEXT: [5,0] . . D===eER . . addl %eax, %ecx 7761c52af9SAndrea Di Biagio# CHECK-NEXT: [5,1] . . D=eE-R . . addl %esi, %eax 7861c52af9SAndrea Di Biagio# CHECK-NEXT: [5,2] . . D==eE-R. . addl %eax, %edx 7961c52af9SAndrea Di Biagio# CHECK-NEXT: [6,0] . . D==eER. . addl %eax, %ecx 8061c52af9SAndrea Di Biagio# CHECK-NEXT: [6,1] . . D==eE-R . addl %esi, %eax 8161c52af9SAndrea Di Biagio# CHECK-NEXT: [6,2] . . D==eER . addl %eax, %edx 8261c52af9SAndrea Di Biagio# CHECK-NEXT: [7,0] . . D===eER . addl %eax, %ecx 8361c52af9SAndrea Di Biagio# CHECK-NEXT: [7,1] . . .D=eE-R . addl %esi, %eax 8461c52af9SAndrea Di Biagio# CHECK-NEXT: [7,2] . . .D==eE-R . addl %eax, %edx 8561c52af9SAndrea Di Biagio# CHECK-NEXT: [8,0] . . . D==eER . addl %eax, %ecx 8661c52af9SAndrea Di Biagio# CHECK-NEXT: [8,1] . . . D==eE-R . addl %esi, %eax 8761c52af9SAndrea Di Biagio# CHECK-NEXT: [8,2] . . . D==eER . addl %eax, %edx 8861c52af9SAndrea Di Biagio# CHECK-NEXT: [9,0] . . . D===eER. addl %eax, %ecx 8961c52af9SAndrea Di Biagio# CHECK-NEXT: [9,1] . . . D=eE-R. addl %esi, %eax 9061c52af9SAndrea Di Biagio# CHECK-NEXT: [9,2] . . . D==eE-R addl %eax, %edx 9161c52af9SAndrea Di Biagio 9261c52af9SAndrea Di Biagio# CHECK: Average Wait times (based on the timeline view): 9361c52af9SAndrea Di Biagio# CHECK-NEXT: [0]: Executions 9461c52af9SAndrea Di Biagio# CHECK-NEXT: [1]: Average time spent waiting in a scheduler's queue 9561c52af9SAndrea Di Biagio# CHECK-NEXT: [2]: Average time spent waiting in a scheduler's queue while ready 9661c52af9SAndrea Di Biagio# CHECK-NEXT: [3]: Average time elapsed from WB until retire stage 9761c52af9SAndrea Di Biagio 9861c52af9SAndrea Di Biagio# CHECK: [0] [1] [2] [3] 9961c52af9SAndrea Di Biagio# CHECK-NEXT: 0. 10 2.5 0.4 0.0 addl %eax, %ecx 10061c52af9SAndrea Di Biagio# CHECK-NEXT: 1. 10 2.1 0.7 0.5 addl %esi, %eax 10161c52af9SAndrea Di Biagio# CHECK-NEXT: 2. 10 2.6 0.0 0.3 addl %eax, %edx 102*a5e65c1cSRoman Lebedev# CHECK-NEXT: 10 2.4 0.4 0.3 <total> 103