1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 12:12:47 +01:00
llvm-mirror/test/MC/X86/gfni-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

255 lines
11 KiB
ArmAsm

// RUN: llvm-mc -triple x86_64-unknown-unknown --show-encoding < %s | FileCheck %s
// CHECK: gf2p8affineinvqb $7, %xmm2, %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xcf,0xca,0x07]
gf2p8affineinvqb $7, %xmm2, %xmm1
// CHECK: gf2p8affineqb $7, %xmm2, %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xce,0xca,0x07]
gf2p8affineqb $7, %xmm2, %xmm1
// CHECK: gf2p8affineinvqb $7, (%rcx), %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xcf,0x09,0x07]
gf2p8affineinvqb $7, (%rcx), %xmm1
// CHECK: gf2p8affineinvqb $7, -4(%rsp), %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xcf,0x4c,0x24,0xfc,0x07]
gf2p8affineinvqb $7, -4(%rsp), %xmm1
// CHECK: gf2p8affineinvqb $7, 4(%rsp), %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xcf,0x4c,0x24,0x04,0x07]
gf2p8affineinvqb $7, 4(%rsp), %xmm1
// CHECK: gf2p8affineinvqb $7, 268435456(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x3a,0xcf,0x8c,0xf1,0x00,0x00,0x00,0x10,0x07]
gf2p8affineinvqb $7, 268435456(%rcx,%r14,8), %xmm1
// CHECK: gf2p8affineinvqb $7, -536870912(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x3a,0xcf,0x8c,0xf1,0x00,0x00,0x00,0xe0,0x07]
gf2p8affineinvqb $7, -536870912(%rcx,%r14,8), %xmm1
// CHECK: gf2p8affineinvqb $7, -536870910(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x3a,0xcf,0x8c,0xf1,0x02,0x00,0x00,0xe0,0x07]
gf2p8affineinvqb $7, -536870910(%rcx,%r14,8), %xmm1
// CHECK: gf2p8affineqb $7, (%rcx), %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xce,0x09,0x07]
gf2p8affineqb $7, (%rcx), %xmm1
// CHECK: gf2p8affineqb $7, -4(%rsp), %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xce,0x4c,0x24,0xfc,0x07]
gf2p8affineqb $7, -4(%rsp), %xmm1
// CHECK: gf2p8affineqb $7, 4(%rsp), %xmm1
// CHECK: encoding: [0x66,0x0f,0x3a,0xce,0x4c,0x24,0x04,0x07]
gf2p8affineqb $7, 4(%rsp), %xmm1
// CHECK: gf2p8affineqb $7, 268435456(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x3a,0xce,0x8c,0xf1,0x00,0x00,0x00,0x10,0x07]
gf2p8affineqb $7, 268435456(%rcx,%r14,8), %xmm1
// CHECK: gf2p8affineqb $7, -536870912(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x3a,0xce,0x8c,0xf1,0x00,0x00,0x00,0xe0,0x07]
gf2p8affineqb $7, -536870912(%rcx,%r14,8), %xmm1
// CHECK: gf2p8affineqb $7, -536870910(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x3a,0xce,0x8c,0xf1,0x02,0x00,0x00,0xe0,0x07]
gf2p8affineqb $7, -536870910(%rcx,%r14,8), %xmm1
// CHECK: gf2p8mulb %xmm2, %xmm1
// CHECK: encoding: [0x66,0x0f,0x38,0xcf,0xca]
gf2p8mulb %xmm2, %xmm1
// CHECK: gf2p8mulb (%rcx), %xmm1
// CHECK: encoding: [0x66,0x0f,0x38,0xcf,0x09]
gf2p8mulb (%rcx), %xmm1
// CHECK: gf2p8mulb -4(%rsp), %xmm1
// CHECK: encoding: [0x66,0x0f,0x38,0xcf,0x4c,0x24,0xfc]
gf2p8mulb -4(%rsp), %xmm1
// CHECK: gf2p8mulb 4(%rsp), %xmm1
// CHECK: encoding: [0x66,0x0f,0x38,0xcf,0x4c,0x24,0x04]
gf2p8mulb 4(%rsp), %xmm1
// CHECK: gf2p8mulb 268435456(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x38,0xcf,0x8c,0xf1,0x00,0x00,0x00,0x10]
gf2p8mulb 268435456(%rcx,%r14,8), %xmm1
// CHECK: gf2p8mulb -536870912(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x38,0xcf,0x8c,0xf1,0x00,0x00,0x00,0xe0]
gf2p8mulb -536870912(%rcx,%r14,8), %xmm1
// CHECK: gf2p8mulb -536870910(%rcx,%r14,8), %xmm1
// CHECK: encoding: [0x66,0x42,0x0f,0x38,0xcf,0x8c,0xf1,0x02,0x00,0x00,0xe0]
gf2p8mulb -536870910(%rcx,%r14,8), %xmm1
// CHECK: vgf2p8affineinvqb $7, %xmm2, %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xcf,0xca,0x07]
vgf2p8affineinvqb $7, %xmm2, %xmm10, %xmm1
// CHECK: vgf2p8affineqb $7, %xmm2, %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xce,0xca,0x07]
vgf2p8affineqb $7, %xmm2, %xmm10, %xmm1
// CHECK: vgf2p8affineinvqb $7, (%rcx), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xcf,0x09,0x07]
vgf2p8affineinvqb $7, (%rcx), %xmm10, %xmm1
// CHECK: vgf2p8affineinvqb $7, -4(%rsp), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xcf,0x4c,0x24,0xfc,0x07]
vgf2p8affineinvqb $7, -4(%rsp), %xmm10, %xmm1
// CHECK: vgf2p8affineinvqb $7, 4(%rsp), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xcf,0x4c,0x24,0x04,0x07]
vgf2p8affineinvqb $7, 4(%rsp), %xmm10, %xmm1
// CHECK: vgf2p8affineinvqb $7, 268435456(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa3,0xa9,0xcf,0x8c,0xf1,0x00,0x00,0x00,0x10,0x07]
vgf2p8affineinvqb $7, 268435456(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8affineinvqb $7, -536870912(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa3,0xa9,0xcf,0x8c,0xf1,0x00,0x00,0x00,0xe0,0x07]
vgf2p8affineinvqb $7, -536870912(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8affineinvqb $7, -536870910(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa3,0xa9,0xcf,0x8c,0xf1,0x02,0x00,0x00,0xe0,0x07]
vgf2p8affineinvqb $7, -536870910(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8affineqb $7, (%rcx), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xce,0x09,0x07]
vgf2p8affineqb $7, (%rcx), %xmm10, %xmm1
// CHECK: vgf2p8affineqb $7, -4(%rsp), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xce,0x4c,0x24,0xfc,0x07]
vgf2p8affineqb $7, -4(%rsp), %xmm10, %xmm1
// CHECK: vgf2p8affineqb $7, 4(%rsp), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe3,0xa9,0xce,0x4c,0x24,0x04,0x07]
vgf2p8affineqb $7, 4(%rsp), %xmm10, %xmm1
// CHECK: vgf2p8affineqb $7, 268435456(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa3,0xa9,0xce,0x8c,0xf1,0x00,0x00,0x00,0x10,0x07]
vgf2p8affineqb $7, 268435456(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8affineqb $7, -536870912(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa3,0xa9,0xce,0x8c,0xf1,0x00,0x00,0x00,0xe0,0x07]
vgf2p8affineqb $7, -536870912(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8affineqb $7, -536870910(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa3,0xa9,0xce,0x8c,0xf1,0x02,0x00,0x00,0xe0,0x07]
vgf2p8affineqb $7, -536870910(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8affineinvqb $7, %ymm2, %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xcf,0xca,0x07]
vgf2p8affineinvqb $7, %ymm2, %ymm10, %ymm1
// CHECK: vgf2p8affineqb $7, %ymm2, %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xce,0xca,0x07]
vgf2p8affineqb $7, %ymm2, %ymm10, %ymm1
// CHECK: vgf2p8affineinvqb $7, (%rcx), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xcf,0x09,0x07]
vgf2p8affineinvqb $7, (%rcx), %ymm10, %ymm1
// CHECK: vgf2p8affineinvqb $7, -4(%rsp), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xcf,0x4c,0x24,0xfc,0x07]
vgf2p8affineinvqb $7, -4(%rsp), %ymm10, %ymm1
// CHECK: vgf2p8affineinvqb $7, 4(%rsp), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xcf,0x4c,0x24,0x04,0x07]
vgf2p8affineinvqb $7, 4(%rsp), %ymm10, %ymm1
// CHECK: vgf2p8affineinvqb $7, 268435456(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa3,0xad,0xcf,0x8c,0xf1,0x00,0x00,0x00,0x10,0x07]
vgf2p8affineinvqb $7, 268435456(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8affineinvqb $7, -536870912(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa3,0xad,0xcf,0x8c,0xf1,0x00,0x00,0x00,0xe0,0x07]
vgf2p8affineinvqb $7, -536870912(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8affineinvqb $7, -536870910(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa3,0xad,0xcf,0x8c,0xf1,0x02,0x00,0x00,0xe0,0x07]
vgf2p8affineinvqb $7, -536870910(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8affineqb $7, (%rcx), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xce,0x09,0x07]
vgf2p8affineqb $7, (%rcx), %ymm10, %ymm1
// CHECK: vgf2p8affineqb $7, -4(%rsp), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xce,0x4c,0x24,0xfc,0x07]
vgf2p8affineqb $7, -4(%rsp), %ymm10, %ymm1
// CHECK: vgf2p8affineqb $7, 4(%rsp), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe3,0xad,0xce,0x4c,0x24,0x04,0x07]
vgf2p8affineqb $7, 4(%rsp), %ymm10, %ymm1
// CHECK: vgf2p8affineqb $7, 268435456(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa3,0xad,0xce,0x8c,0xf1,0x00,0x00,0x00,0x10,0x07]
vgf2p8affineqb $7, 268435456(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8affineqb $7, -536870912(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa3,0xad,0xce,0x8c,0xf1,0x00,0x00,0x00,0xe0,0x07]
vgf2p8affineqb $7, -536870912(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8affineqb $7, -536870910(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa3,0xad,0xce,0x8c,0xf1,0x02,0x00,0x00,0xe0,0x07]
vgf2p8affineqb $7, -536870910(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8mulb %xmm2, %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe2,0x29,0xcf,0xca]
vgf2p8mulb %xmm2, %xmm10, %xmm1
// CHECK: vgf2p8mulb (%rcx), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe2,0x29,0xcf,0x09]
vgf2p8mulb (%rcx), %xmm10, %xmm1
// CHECK: vgf2p8mulb -4(%rsp), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe2,0x29,0xcf,0x4c,0x24,0xfc]
vgf2p8mulb -4(%rsp), %xmm10, %xmm1
// CHECK: vgf2p8mulb 4(%rsp), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xe2,0x29,0xcf,0x4c,0x24,0x04]
vgf2p8mulb 4(%rsp), %xmm10, %xmm1
// CHECK: vgf2p8mulb 268435456(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa2,0x29,0xcf,0x8c,0xf1,0x00,0x00,0x00,0x10]
vgf2p8mulb 268435456(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8mulb -536870912(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa2,0x29,0xcf,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vgf2p8mulb -536870912(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8mulb -536870910(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: encoding: [0xc4,0xa2,0x29,0xcf,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vgf2p8mulb -536870910(%rcx,%r14,8), %xmm10, %xmm1
// CHECK: vgf2p8mulb %ymm2, %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe2,0x2d,0xcf,0xca]
vgf2p8mulb %ymm2, %ymm10, %ymm1
// CHECK: vgf2p8mulb (%rcx), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe2,0x2d,0xcf,0x09]
vgf2p8mulb (%rcx), %ymm10, %ymm1
// CHECK: vgf2p8mulb -4(%rsp), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe2,0x2d,0xcf,0x4c,0x24,0xfc]
vgf2p8mulb -4(%rsp), %ymm10, %ymm1
// CHECK: vgf2p8mulb 4(%rsp), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xe2,0x2d,0xcf,0x4c,0x24,0x04]
vgf2p8mulb 4(%rsp), %ymm10, %ymm1
// CHECK: vgf2p8mulb 268435456(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa2,0x2d,0xcf,0x8c,0xf1,0x00,0x00,0x00,0x10]
vgf2p8mulb 268435456(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8mulb -536870912(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa2,0x2d,0xcf,0x8c,0xf1,0x00,0x00,0x00,0xe0]
vgf2p8mulb -536870912(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: vgf2p8mulb -536870910(%rcx,%r14,8), %ymm10, %ymm1
// CHECK: encoding: [0xc4,0xa2,0x2d,0xcf,0x8c,0xf1,0x02,0x00,0x00,0xe0]
vgf2p8mulb -536870910(%rcx,%r14,8), %ymm10, %ymm1