| # NOTE: Assertions have been autogenerated by utils/update_mca_test_checks.py | 
 | # RUN: llvm-mca -mtriple=x86_64-unknown-unknown -mcpu=znver1 -instruction-tables < %s | FileCheck %s | 
 |  | 
 | pabsb       %mm0, %mm2 | 
 | pabsb       (%rax), %mm2 | 
 |  | 
 | pabsb       %xmm0, %xmm2 | 
 | pabsb       (%rax), %xmm2 | 
 |  | 
 | pabsd       %mm0, %mm2 | 
 | pabsd       (%rax), %mm2 | 
 |  | 
 | pabsd       %xmm0, %xmm2 | 
 | pabsd       (%rax), %xmm2 | 
 |  | 
 | pabsw       %mm0, %mm2 | 
 | pabsw       (%rax), %mm2 | 
 |  | 
 | pabsw       %xmm0, %xmm2 | 
 | pabsw       (%rax), %xmm2 | 
 |  | 
 | palignr     $1, %mm0, %mm2 | 
 | palignr     $1, (%rax), %mm2 | 
 |  | 
 | palignr     $1, %xmm0, %xmm2 | 
 | palignr     $1, (%rax), %xmm2 | 
 |  | 
 | phaddd      %mm0, %mm2 | 
 | phaddd      (%rax), %mm2 | 
 |  | 
 | phaddd      %xmm0, %xmm2 | 
 | phaddd      (%rax), %xmm2 | 
 |  | 
 | phaddsw     %mm0, %mm2 | 
 | phaddsw     (%rax), %mm2 | 
 |  | 
 | phaddsw     %xmm0, %xmm2 | 
 | phaddsw     (%rax), %xmm2 | 
 |  | 
 | phaddw      %mm0, %mm2 | 
 | phaddw      (%rax), %mm2 | 
 |  | 
 | phaddw      %xmm0, %xmm2 | 
 | phaddw      (%rax), %xmm2 | 
 |  | 
 | phsubd      %mm0, %mm2 | 
 | phsubd      (%rax), %mm2 | 
 |  | 
 | phsubd      %xmm0, %xmm2 | 
 | phsubd      (%rax), %xmm2 | 
 |  | 
 | phsubsw     %mm0, %mm2 | 
 | phsubsw     (%rax), %mm2 | 
 |  | 
 | phsubsw     %xmm0, %xmm2 | 
 | phsubsw     (%rax), %xmm2 | 
 |  | 
 | phsubw      %mm0, %mm2 | 
 | phsubw      (%rax), %mm2 | 
 |  | 
 | phsubw      %xmm0, %xmm2 | 
 | phsubw      (%rax), %xmm2 | 
 |  | 
 | pmaddubsw   %mm0, %mm2 | 
 | pmaddubsw   (%rax), %mm2 | 
 |  | 
 | pmaddubsw   %xmm0, %xmm2 | 
 | pmaddubsw   (%rax), %xmm2 | 
 |  | 
 | pmulhrsw    %mm0, %mm2 | 
 | pmulhrsw    (%rax), %mm2 | 
 |  | 
 | pmulhrsw    %xmm0, %xmm2 | 
 | pmulhrsw    (%rax), %xmm2 | 
 |  | 
 | pshufb      %mm0, %mm2 | 
 | pshufb      (%rax), %mm2 | 
 |  | 
 | pshufb      %xmm0, %xmm2 | 
 | pshufb      (%rax), %xmm2 | 
 |  | 
 | psignb      %mm0, %mm2 | 
 | psignb      (%rax), %mm2 | 
 |  | 
 | psignb      %xmm0, %xmm2 | 
 | psignb      (%rax), %xmm2 | 
 |  | 
 | psignd      %mm0, %mm2 | 
 | psignd      (%rax), %mm2 | 
 |  | 
 | psignd      %xmm0, %xmm2 | 
 | psignd      (%rax), %xmm2 | 
 |  | 
 | psignw      %mm0, %mm2 | 
 | psignw      (%rax), %mm2 | 
 |  | 
 | psignw      %xmm0, %xmm2 | 
 | psignw      (%rax), %xmm2 | 
 |  | 
 | # CHECK:      Instruction Info: | 
 | # CHECK-NEXT: [1]: #uOps | 
 | # CHECK-NEXT: [2]: Latency | 
 | # CHECK-NEXT: [3]: RThroughput | 
 | # CHECK-NEXT: [4]: MayLoad | 
 | # CHECK-NEXT: [5]: MayStore | 
 | # CHECK-NEXT: [6]: HasSideEffects (U) | 
 |  | 
 | # CHECK:      [1]    [2]    [3]    [4]    [5]    [6]    Instructions: | 
 | # CHECK-NEXT:  1      1     0.33                        pabsb	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pabsb	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.33                        pabsb	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pabsb	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      1     0.33                        pabsd	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pabsd	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.33                        pabsd	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pabsd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      1     0.33                        pabsw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pabsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.33                        pabsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pabsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      1     0.50                        palignr	$1, %mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   palignr	$1, (%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.50                        palignr	$1, %xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   palignr	$1, (%rax), %xmm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phaddd	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phaddd	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phaddd	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phaddd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phaddsw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phaddsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phaddsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phaddsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phaddw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phaddw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phaddw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phaddw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phsubd	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phsubd	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phsubd	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phsubd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phsubsw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phsubsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phsubsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phsubsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phsubw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phsubw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      3     0.25                        phsubw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      10    0.50    *                   phsubw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      4     1.00                        pmaddubsw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      11    1.00    *                   pmaddubsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      4     1.00                        pmaddubsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      11    1.00    *                   pmaddubsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      4     1.00                        pmulhrsw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      11    1.00    *                   pmulhrsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      4     1.00                        pmulhrsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      11    1.00    *                   pmulhrsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      1     0.50                        pshufb	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pshufb	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.50                        pshufb	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   pshufb	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      1     0.33                        psignb	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   psignb	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.33                        psignb	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   psignb	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      1     0.33                        psignd	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   psignd	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.33                        psignd	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   psignd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  1      1     0.33                        psignw	%mm0, %mm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   psignw	(%rax), %mm2 | 
 | # CHECK-NEXT:  1      1     0.33                        psignw	%xmm0, %xmm2 | 
 | # CHECK-NEXT:  1      8     0.50    *                   psignw	(%rax), %xmm2 | 
 |  | 
 | # CHECK:      Resources: | 
 | # CHECK-NEXT: [0]   - ZnAGU0 | 
 | # CHECK-NEXT: [1]   - ZnAGU1 | 
 | # CHECK-NEXT: [2]   - ZnALU0 | 
 | # CHECK-NEXT: [3]   - ZnALU1 | 
 | # CHECK-NEXT: [4]   - ZnALU2 | 
 | # CHECK-NEXT: [5]   - ZnALU3 | 
 | # CHECK-NEXT: [6]   - ZnDivider | 
 | # CHECK-NEXT: [7]   - ZnFPU0 | 
 | # CHECK-NEXT: [8]   - ZnFPU1 | 
 | # CHECK-NEXT: [9]   - ZnFPU2 | 
 | # CHECK-NEXT: [10]  - ZnFPU3 | 
 | # CHECK-NEXT: [11]  - ZnMultiplier | 
 |  | 
 | # CHECK:      Resource pressure per iteration: | 
 | # CHECK-NEXT: [0]    [1]    [2]    [3]    [4]    [5]    [6]    [7]    [8]    [9]    [10]   [11] | 
 | # CHECK-NEXT: 16.00  16.00   -      -      -      -      -     16.00  12.00  4.00   8.00    - | 
 |  | 
 | # CHECK:      Resource pressure by instruction: | 
 | # CHECK-NEXT: [0]    [1]    [2]    [3]    [4]    [5]    [6]    [7]    [8]    [9]    [10]   [11]   Instructions: | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     pabsb	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     pabsb	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     pabsb	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     pabsb	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     pabsd	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     pabsd	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     pabsd	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     pabsd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     pabsw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     pabsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     pabsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     pabsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -     0.50   0.50    -      -     palignr	$1, %mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -     0.50   0.50    -      -     palignr	$1, (%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -     0.50   0.50    -      -     palignr	$1, %xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -     0.50   0.50    -      -     palignr	$1, (%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phaddd	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phaddd	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phaddd	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phaddd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phaddsw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phaddsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phaddsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phaddsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phaddw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phaddw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phaddw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phaddw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phsubd	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phsubd	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phsubd	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phsubd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phsubsw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phsubsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phsubsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phsubsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phsubw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phsubw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -      -      -      -      -     phsubw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -      -      -      -      -     phsubw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     1.00    -      -      -      -     pmaddubsw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     1.00    -      -      -      -     pmaddubsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     1.00    -      -      -      -     pmaddubsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     1.00    -      -      -      -     pmaddubsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     1.00    -      -      -      -     pmulhrsw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     1.00    -      -      -      -     pmulhrsw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     1.00    -      -      -      -     pmulhrsw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     1.00    -      -      -      -     pmulhrsw	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -     0.50   0.50    -      -     pshufb	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -     0.50   0.50    -      -     pshufb	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -      -     0.50   0.50    -      -     pshufb	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -      -     0.50   0.50    -      -     pshufb	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     psignb	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     psignb	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     psignb	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     psignb	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     psignd	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     psignd	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     psignd	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     psignd	(%rax), %xmm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     psignw	%mm0, %mm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     psignw	(%rax), %mm2 | 
 | # CHECK-NEXT:  -      -      -      -      -      -      -     0.33   0.33    -     0.33    -     psignw	%xmm0, %xmm2 | 
 | # CHECK-NEXT: 0.50   0.50    -      -      -      -      -     0.33   0.33    -     0.33    -     psignw	(%rax), %xmm2 |