xref: /llvm-project/llvm/test/tools/llvm-mca/X86/BtVer2/add-sequence.s (revision a5e65c1cf793b36836d0939574488a2f9530ea85)
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