1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-01-31 20:51:52 +01:00
llvm-mirror/test/MC/X86/avx512vl_bitalg-encoding.s
Craig Topper 12cdca9076 [X86] Remove checks for FeatureAVX512 from the X86 assembly parser. Remove mcpu/mattr from assembly test command lines.
Summary:
We should always be able to accept AVX512 registers and instructions in llvm-mc. The only subtarget mode that should be checked is 16-bit vs 32-bit vs 64-bit mode.

I've also removed all the mattr/mcpu lines from test RUN lines to be consistent with this. Most were due to AVX512, but a few were for other features.

Fixes PR36202

Reviewers: RKSimon, echristo, bkramer

Reviewed By: echristo

Subscribers: llvm-commits

Differential Revision: https://reviews.llvm.org/D42824

llvm-svn: 324106
2018-02-02 17:02:58 +00:00

339 lines
14 KiB
ArmAsm

// RUN: llvm-mc -triple x86_64-unknown-unknown --show-encoding < %s | FileCheck %s
// CHECK: vpopcntb %xmm23, %xmm21
// CHECK: encoding: [0x62,0xa2,0x7d,0x08,0x54,0xef]
vpopcntb %xmm23, %xmm21
// CHECK: vpopcntw %xmm23, %xmm21
// CHECK: encoding: [0x62,0xa2,0xfd,0x08,0x54,0xef]
vpopcntw %xmm23, %xmm21
// CHECK: vpopcntb %xmm3, %xmm1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x7d,0x0a,0x54,0xcb]
vpopcntb %xmm3, %xmm1 {%k2}
// CHECK: vpopcntw %xmm3, %xmm1 {%k2}
// CHECK: encoding: [0x62,0xf2,0xfd,0x0a,0x54,0xcb]
vpopcntw %xmm3, %xmm1 {%k2}
// CHECK: vpopcntb (%rcx), %xmm1
// CHECK: encoding: [0x62,0xf2,0x7d,0x08,0x54,0x09]
vpopcntb (%rcx), %xmm1
// CHECK: vpopcntb -64(%rsp), %xmm1
// CHECK: encoding: [0x62,0xf2,0x7d,0x08,0x54,0x4c,0x24,0xfc]
vpopcntb -64(%rsp), %xmm1
// CHECK: vpopcntb 64(%rsp), %xmm1
// CHECK: encoding: [0x62,0xf2,0x7d,0x08,0x54,0x4c,0x24,0x04]
vpopcntb 64(%rsp), %xmm1
// CHECK: vpopcntb 268435456(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x62,0xb2,0x7d,0x08,0x54,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpopcntb 268435456(%rcx,%r14,8), %xmm1
// CHECK: vpopcntb -536870912(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x62,0xb2,0x7d,0x08,0x54,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpopcntb -536870912(%rcx,%r14,8), %xmm1
// CHECK: vpopcntb -536870910(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x62,0xb2,0x7d,0x08,0x54,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpopcntb -536870910(%rcx,%r14,8), %xmm1
// CHECK: vpopcntw (%rcx), %xmm1
// CHECK: encoding: [0x62,0xf2,0xfd,0x08,0x54,0x09]
vpopcntw (%rcx), %xmm1
// CHECK: vpopcntw -64(%rsp), %xmm1
// CHECK: encoding: [0x62,0xf2,0xfd,0x08,0x54,0x4c,0x24,0xfc]
vpopcntw -64(%rsp), %xmm1
// CHECK: vpopcntw 64(%rsp), %xmm1
// CHECK: encoding: [0x62,0xf2,0xfd,0x08,0x54,0x4c,0x24,0x04]
vpopcntw 64(%rsp), %xmm1
// CHECK: vpopcntw 268435456(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x62,0xb2,0xfd,0x08,0x54,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpopcntw 268435456(%rcx,%r14,8), %xmm1
// CHECK: vpopcntw -536870912(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x62,0xb2,0xfd,0x08,0x54,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpopcntw -536870912(%rcx,%r14,8), %xmm1
// CHECK: vpopcntw -536870910(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x62,0xb2,0xfd,0x08,0x54,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpopcntw -536870910(%rcx,%r14,8), %xmm1
// CHECK: vpopcntb (%rcx), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0x7d,0x0a,0x54,0x29]
vpopcntb (%rcx), %xmm21 {%k2}
// CHECK: vpopcntb -64(%rsp), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0x7d,0x0a,0x54,0x6c,0x24,0xfc]
vpopcntb -64(%rsp), %xmm21 {%k2}
// CHECK: vpopcntb 64(%rsp), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0x7d,0x0a,0x54,0x6c,0x24,0x04]
vpopcntb 64(%rsp), %xmm21 {%k2}
// CHECK: vpopcntb 268435456(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0x7d,0x0a,0x54,0xac,0xf1,0x00,0x00,0x00,0x10]
vpopcntb 268435456(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: vpopcntb -536870912(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0x7d,0x0a,0x54,0xac,0xf1,0x00,0x00,0x00,0xe0]
vpopcntb -536870912(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: vpopcntb -536870910(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0x7d,0x0a,0x54,0xac,0xf1,0x02,0x00,0x00,0xe0]
vpopcntb -536870910(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: vpopcntw (%rcx), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0xfd,0x0a,0x54,0x29]
vpopcntw (%rcx), %xmm21 {%k2}
// CHECK: vpopcntw -64(%rsp), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0xfd,0x0a,0x54,0x6c,0x24,0xfc]
vpopcntw -64(%rsp), %xmm21 {%k2}
// CHECK: vpopcntw 64(%rsp), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0xfd,0x0a,0x54,0x6c,0x24,0x04]
vpopcntw 64(%rsp), %xmm21 {%k2}
// CHECK: vpopcntw 268435456(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0xfd,0x0a,0x54,0xac,0xf1,0x00,0x00,0x00,0x10]
vpopcntw 268435456(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: vpopcntw -536870912(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0xfd,0x0a,0x54,0xac,0xf1,0x00,0x00,0x00,0xe0]
vpopcntw -536870912(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: vpopcntw -536870910(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0xfd,0x0a,0x54,0xac,0xf1,0x02,0x00,0x00,0xe0]
vpopcntw -536870910(%rcx,%r14,8), %xmm21 {%k2}
// CHECK: vpopcntb %ymm23, %ymm21
// CHECK: encoding: [0x62,0xa2,0x7d,0x28,0x54,0xef]
vpopcntb %ymm23, %ymm21
// CHECK: vpopcntw %ymm23, %ymm21
// CHECK: encoding: [0x62,0xa2,0xfd,0x28,0x54,0xef]
vpopcntw %ymm23, %ymm21
// CHECK: vpopcntb %ymm3, %ymm1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x7d,0x2a,0x54,0xcb]
vpopcntb %ymm3, %ymm1 {%k2}
// CHECK: vpopcntw %ymm3, %ymm1 {%k2}
// CHECK: encoding: [0x62,0xf2,0xfd,0x2a,0x54,0xcb]
vpopcntw %ymm3, %ymm1 {%k2}
// CHECK: vpopcntb (%rcx), %ymm1
// CHECK: encoding: [0x62,0xf2,0x7d,0x28,0x54,0x09]
vpopcntb (%rcx), %ymm1
// CHECK: vpopcntb -128(%rsp), %ymm1
// CHECK: encoding: [0x62,0xf2,0x7d,0x28,0x54,0x4c,0x24,0xfc]
vpopcntb -128(%rsp), %ymm1
// CHECK: vpopcntb 128(%rsp), %ymm1
// CHECK: encoding: [0x62,0xf2,0x7d,0x28,0x54,0x4c,0x24,0x04]
vpopcntb 128(%rsp), %ymm1
// CHECK: vpopcntb 268435456(%rcx,%r14,8), %ymm1
// CHECK: encoding: [0x62,0xb2,0x7d,0x28,0x54,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpopcntb 268435456(%rcx,%r14,8), %ymm1
// CHECK: vpopcntb -536870912(%rcx,%r14,8), %ymm1
// CHECK: encoding: [0x62,0xb2,0x7d,0x28,0x54,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpopcntb -536870912(%rcx,%r14,8), %ymm1
// CHECK: vpopcntb -536870910(%rcx,%r14,8), %ymm1
// CHECK: encoding: [0x62,0xb2,0x7d,0x28,0x54,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpopcntb -536870910(%rcx,%r14,8), %ymm1
// CHECK: vpopcntw (%rcx), %ymm1
// CHECK: encoding: [0x62,0xf2,0xfd,0x28,0x54,0x09]
vpopcntw (%rcx), %ymm1
// CHECK: vpopcntw -128(%rsp), %ymm1
// CHECK: encoding: [0x62,0xf2,0xfd,0x28,0x54,0x4c,0x24,0xfc]
vpopcntw -128(%rsp), %ymm1
// CHECK: vpopcntw 128(%rsp), %ymm1
// CHECK: encoding: [0x62,0xf2,0xfd,0x28,0x54,0x4c,0x24,0x04]
vpopcntw 128(%rsp), %ymm1
// CHECK: vpopcntw 268435456(%rcx,%r14,8), %ymm1
// CHECK: encoding: [0x62,0xb2,0xfd,0x28,0x54,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpopcntw 268435456(%rcx,%r14,8), %ymm1
// CHECK: vpopcntw -536870912(%rcx,%r14,8), %ymm1
// CHECK: encoding: [0x62,0xb2,0xfd,0x28,0x54,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpopcntw -536870912(%rcx,%r14,8), %ymm1
// CHECK: vpopcntw -536870910(%rcx,%r14,8), %ymm1
// CHECK: encoding: [0x62,0xb2,0xfd,0x28,0x54,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpopcntw -536870910(%rcx,%r14,8), %ymm1
// CHECK: vpopcntb (%rcx), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0x7d,0x2a,0x54,0x29]
vpopcntb (%rcx), %ymm21 {%k2}
// CHECK: vpopcntb -128(%rsp), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0x7d,0x2a,0x54,0x6c,0x24,0xfc]
vpopcntb -128(%rsp), %ymm21 {%k2}
// CHECK: vpopcntb 128(%rsp), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0x7d,0x2a,0x54,0x6c,0x24,0x04]
vpopcntb 128(%rsp), %ymm21 {%k2}
// CHECK: vpopcntb 268435456(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0x7d,0x2a,0x54,0xac,0xf1,0x00,0x00,0x00,0x10]
vpopcntb 268435456(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: vpopcntb -536870912(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0x7d,0x2a,0x54,0xac,0xf1,0x00,0x00,0x00,0xe0]
vpopcntb -536870912(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: vpopcntb -536870910(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0x7d,0x2a,0x54,0xac,0xf1,0x02,0x00,0x00,0xe0]
vpopcntb -536870910(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: vpopcntw (%rcx), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0xfd,0x2a,0x54,0x29]
vpopcntw (%rcx), %ymm21 {%k2}
// CHECK: vpopcntw -128(%rsp), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0xfd,0x2a,0x54,0x6c,0x24,0xfc]
vpopcntw -128(%rsp), %ymm21 {%k2}
// CHECK: vpopcntw 128(%rsp), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xe2,0xfd,0x2a,0x54,0x6c,0x24,0x04]
vpopcntw 128(%rsp), %ymm21 {%k2}
// CHECK: vpopcntw 268435456(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0xfd,0x2a,0x54,0xac,0xf1,0x00,0x00,0x00,0x10]
vpopcntw 268435456(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: vpopcntw -536870912(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0xfd,0x2a,0x54,0xac,0xf1,0x00,0x00,0x00,0xe0]
vpopcntw -536870912(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: vpopcntw -536870910(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: encoding: [0x62,0xa2,0xfd,0x2a,0x54,0xac,0xf1,0x02,0x00,0x00,0xe0]
vpopcntw -536870910(%rcx,%r14,8), %ymm21 {%k2}
// CHECK: vpshufbitqmb %xmm2, %xmm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x00,0x8f,0xca]
vpshufbitqmb %xmm2, %xmm23, %k1
// CHECK: vpshufbitqmb %xmm2, %xmm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x02,0x8f,0xca]
vpshufbitqmb %xmm2, %xmm23, %k1 {%k2}
// CHECK: vpshufbitqmb (%rcx), %xmm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x00,0x8f,0x09]
vpshufbitqmb (%rcx), %xmm23, %k1
// CHECK: vpshufbitqmb -64(%rsp), %xmm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x00,0x8f,0x4c,0x24,0xfc]
vpshufbitqmb -64(%rsp), %xmm23, %k1
// CHECK: vpshufbitqmb 64(%rsp), %xmm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x00,0x8f,0x4c,0x24,0x04]
vpshufbitqmb 64(%rsp), %xmm23, %k1
// CHECK: vpshufbitqmb 268435456(%rcx,%r14,8), %xmm23, %k1
// CHECK: encoding: [0x62,0xb2,0x45,0x00,0x8f,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpshufbitqmb 268435456(%rcx,%r14,8), %xmm23, %k1
// CHECK: vpshufbitqmb -536870912(%rcx,%r14,8), %xmm23, %k1
// CHECK: encoding: [0x62,0xb2,0x45,0x00,0x8f,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpshufbitqmb -536870912(%rcx,%r14,8), %xmm23, %k1
// CHECK: vpshufbitqmb -536870910(%rcx,%r14,8), %xmm23, %k1
// CHECK: encoding: [0x62,0xb2,0x45,0x00,0x8f,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpshufbitqmb -536870910(%rcx,%r14,8), %xmm23, %k1
// CHECK: vpshufbitqmb (%rcx), %xmm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x02,0x8f,0x09]
vpshufbitqmb (%rcx), %xmm23, %k1 {%k2}
// CHECK: vpshufbitqmb -64(%rsp), %xmm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x02,0x8f,0x4c,0x24,0xfc]
vpshufbitqmb -64(%rsp), %xmm23, %k1 {%k2}
// CHECK: vpshufbitqmb 64(%rsp), %xmm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x02,0x8f,0x4c,0x24,0x04]
vpshufbitqmb 64(%rsp), %xmm23, %k1 {%k2}
// CHECK: vpshufbitqmb 268435456(%rcx,%r14,8), %xmm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xb2,0x45,0x02,0x8f,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpshufbitqmb 268435456(%rcx,%r14,8), %xmm23, %k1 {%k2}
// CHECK: vpshufbitqmb -536870912(%rcx,%r14,8), %xmm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xb2,0x45,0x02,0x8f,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpshufbitqmb -536870912(%rcx,%r14,8), %xmm23, %k1 {%k2}
// CHECK: vpshufbitqmb -536870910(%rcx,%r14,8), %xmm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xb2,0x45,0x02,0x8f,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpshufbitqmb -536870910(%rcx,%r14,8), %xmm23, %k1 {%k2}
// CHECK: vpshufbitqmb %ymm2, %ymm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x20,0x8f,0xca]
vpshufbitqmb %ymm2, %ymm23, %k1
// CHECK: vpshufbitqmb %ymm2, %ymm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x22,0x8f,0xca]
vpshufbitqmb %ymm2, %ymm23, %k1 {%k2}
// CHECK: vpshufbitqmb (%rcx), %ymm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x20,0x8f,0x09]
vpshufbitqmb (%rcx), %ymm23, %k1
// CHECK: vpshufbitqmb -128(%rsp), %ymm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x20,0x8f,0x4c,0x24,0xfc]
vpshufbitqmb -128(%rsp), %ymm23, %k1
// CHECK: vpshufbitqmb 128(%rsp), %ymm23, %k1
// CHECK: encoding: [0x62,0xf2,0x45,0x20,0x8f,0x4c,0x24,0x04]
vpshufbitqmb 128(%rsp), %ymm23, %k1
// CHECK: vpshufbitqmb 268435456(%rcx,%r14,8), %ymm23, %k1
// CHECK: encoding: [0x62,0xb2,0x45,0x20,0x8f,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpshufbitqmb 268435456(%rcx,%r14,8), %ymm23, %k1
// CHECK: vpshufbitqmb -536870912(%rcx,%r14,8), %ymm23, %k1
// CHECK: encoding: [0x62,0xb2,0x45,0x20,0x8f,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpshufbitqmb -536870912(%rcx,%r14,8), %ymm23, %k1
// CHECK: vpshufbitqmb -536870910(%rcx,%r14,8), %ymm23, %k1
// CHECK: encoding: [0x62,0xb2,0x45,0x20,0x8f,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpshufbitqmb -536870910(%rcx,%r14,8), %ymm23, %k1
// CHECK: vpshufbitqmb (%rcx), %ymm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x22,0x8f,0x09]
vpshufbitqmb (%rcx), %ymm23, %k1 {%k2}
// CHECK: vpshufbitqmb -128(%rsp), %ymm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x22,0x8f,0x4c,0x24,0xfc]
vpshufbitqmb -128(%rsp), %ymm23, %k1 {%k2}
// CHECK: vpshufbitqmb 128(%rsp), %ymm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xf2,0x45,0x22,0x8f,0x4c,0x24,0x04]
vpshufbitqmb 128(%rsp), %ymm23, %k1 {%k2}
// CHECK: vpshufbitqmb 268435456(%rcx,%r14,8), %ymm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xb2,0x45,0x22,0x8f,0x8c,0xf1,0x00,0x00,0x00,0x10]
vpshufbitqmb 268435456(%rcx,%r14,8), %ymm23, %k1 {%k2}
// CHECK: vpshufbitqmb -536870912(%rcx,%r14,8), %ymm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xb2,0x45,0x22,0x8f,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vpshufbitqmb -536870912(%rcx,%r14,8), %ymm23, %k1 {%k2}
// CHECK: vpshufbitqmb -536870910(%rcx,%r14,8), %ymm23, %k1 {%k2}
// CHECK: encoding: [0x62,0xb2,0x45,0x22,0x8f,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vpshufbitqmb -536870910(%rcx,%r14,8), %ymm23, %k1 {%k2}