# RUN: llvm-mc --disassemble %s -triple=x86_64 | FileCheck %s --check-prefixes=ATT
# RUN: llvm-mc --disassemble %s -triple=x86_64 -x86-asm-syntax=intel --output-asm-variant=1 | FileCheck %s --check-prefixes=INTEL

# ATT:        vsm4key4 %zmm24, %zmm23, %zmm22
# INTEL:      vsm4key4 zmm22, zmm23, zmm24
0x62,0x82,0x46,0x40,0xda,0xf0

# ATT:        vsm4key4  268435456(%rbp,%r14,8), %zmm23, %zmm22
# INTEL:      vsm4key4 zmm22, zmm23, zmmword ptr [rbp + 8*r14 + 268435456]
0x62,0xa2,0x46,0x40,0xda,0xb4,0xf5,0x00,0x00,0x00,0x10

# ATT:        vsm4key4  291(%r8,%rax,4), %zmm23, %zmm22
# INTEL:      vsm4key4 zmm22, zmm23, zmmword ptr [r8 + 4*rax + 291]
0x62,0xc2,0x46,0x40,0xda,0xb4,0x80,0x23,0x01,0x00,0x00

# ATT:        vsm4key4  (%rip), %zmm23, %zmm22
# INTEL:      vsm4key4 zmm22, zmm23, zmmword ptr [rip]
0x62,0xe2,0x46,0x40,0xda,0x35,0x00,0x00,0x00,0x00

# ATT:        vsm4key4  -2048(,%rbp,2), %zmm23, %zmm22
# INTEL:      vsm4key4 zmm22, zmm23, zmmword ptr [2*rbp - 2048]
0x62,0xe2,0x46,0x40,0xda,0x34,0x6d,0x00,0xf8,0xff,0xff

# ATT:        vsm4key4  8128(%rcx), %zmm23, %zmm22
# INTEL:      vsm4key4 zmm22, zmm23, zmmword ptr [rcx + 8128]
0x62,0xe2,0x46,0x40,0xda,0x71,0x7f

# ATT:        vsm4key4  -8192(%rdx), %zmm23, %zmm22
# INTEL:      vsm4key4 zmm22, zmm23, zmmword ptr [rdx - 8192]
0x62,0xe2,0x46,0x40,0xda,0x72,0x80

# ATT:        vsm4rnds4 %zmm24, %zmm23, %zmm22
# INTEL:      vsm4rnds4 zmm22, zmm23, zmm24
0x62,0x82,0x47,0x40,0xda,0xf0

# ATT:        vsm4rnds4  268435456(%rbp,%r14,8), %zmm23, %zmm22
# INTEL:      vsm4rnds4 zmm22, zmm23, zmmword ptr [rbp + 8*r14 + 268435456]
0x62,0xa2,0x47,0x40,0xda,0xb4,0xf5,0x00,0x00,0x00,0x10

# ATT:        vsm4rnds4  291(%r8,%rax,4), %zmm23, %zmm22
# INTEL:      vsm4rnds4 zmm22, zmm23, zmmword ptr [r8 + 4*rax + 291]
0x62,0xc2,0x47,0x40,0xda,0xb4,0x80,0x23,0x01,0x00,0x00

# ATT:        vsm4rnds4  (%rip), %zmm23, %zmm22
# INTEL:      vsm4rnds4 zmm22, zmm23, zmmword ptr [rip]
0x62,0xe2,0x47,0x40,0xda,0x35,0x00,0x00,0x00,0x00

# ATT:        vsm4rnds4  -2048(,%rbp,2), %zmm23, %zmm22
# INTEL:      vsm4rnds4 zmm22, zmm23, zmmword ptr [2*rbp - 2048]
0x62,0xe2,0x47,0x40,0xda,0x34,0x6d,0x00,0xf8,0xff,0xff

# ATT:        vsm4rnds4  8128(%rcx), %zmm23, %zmm22
# INTEL:      vsm4rnds4 zmm22, zmm23, zmmword ptr [rcx + 8128]
0x62,0xe2,0x47,0x40,0xda,0x71,0x7f

# ATT:        vsm4rnds4  -8192(%rdx), %zmm23, %zmm22
# INTEL:      vsm4rnds4 zmm22, zmm23, zmmword ptr [rdx - 8192]
0x62,0xe2,0x47,0x40,0xda,0x72,0x80

# ATT:        vsm4key4 %ymm24, %ymm23, %ymm22
# INTEL:      vsm4key4 ymm22, ymm23, ymm24
0x62,0x82,0x46,0x20,0xda,0xf0

# ATT:        vsm4key4 %xmm24, %xmm23, %xmm22
# INTEL:      vsm4key4 xmm22, xmm23, xmm24
0x62,0x82,0x46,0x00,0xda,0xf0

# ATT:        vsm4key4  268435456(%rbp,%r14,8), %ymm23, %ymm22
# INTEL:      vsm4key4 ymm22, ymm23, ymmword ptr [rbp + 8*r14 + 268435456]
0x62,0xa2,0x46,0x20,0xda,0xb4,0xf5,0x00,0x00,0x00,0x10

# ATT:        vsm4key4  291(%r8,%rax,4), %ymm23, %ymm22
# INTEL:      vsm4key4 ymm22, ymm23, ymmword ptr [r8 + 4*rax + 291]
0x62,0xc2,0x46,0x20,0xda,0xb4,0x80,0x23,0x01,0x00,0x00

# ATT:        vsm4key4  (%rip), %ymm23, %ymm22
# INTEL:      vsm4key4 ymm22, ymm23, ymmword ptr [rip]
0x62,0xe2,0x46,0x20,0xda,0x35,0x00,0x00,0x00,0x00

# ATT:        vsm4key4  -1024(,%rbp,2), %ymm23, %ymm22
# INTEL:      vsm4key4 ymm22, ymm23, ymmword ptr [2*rbp - 1024]
0x62,0xe2,0x46,0x20,0xda,0x34,0x6d,0x00,0xfc,0xff,0xff

# ATT:        vsm4key4  4064(%rcx), %ymm23, %ymm22
# INTEL:      vsm4key4 ymm22, ymm23, ymmword ptr [rcx + 4064]
0x62,0xe2,0x46,0x20,0xda,0x71,0x7f

# ATT:        vsm4key4  -4096(%rdx), %ymm23, %ymm22
# INTEL:      vsm4key4 ymm22, ymm23, ymmword ptr [rdx - 4096]
0x62,0xe2,0x46,0x20,0xda,0x72,0x80

# ATT:        vsm4key4  268435456(%rbp,%r14,8), %xmm23, %xmm22
# INTEL:      vsm4key4 xmm22, xmm23, xmmword ptr [rbp + 8*r14 + 268435456]
0x62,0xa2,0x46,0x00,0xda,0xb4,0xf5,0x00,0x00,0x00,0x10

# ATT:        vsm4key4  291(%r8,%rax,4), %xmm23, %xmm22
# INTEL:      vsm4key4 xmm22, xmm23, xmmword ptr [r8 + 4*rax + 291]
0x62,0xc2,0x46,0x00,0xda,0xb4,0x80,0x23,0x01,0x00,0x00

# ATT:        vsm4key4  (%rip), %xmm23, %xmm22
# INTEL:      vsm4key4 xmm22, xmm23, xmmword ptr [rip]
0x62,0xe2,0x46,0x00,0xda,0x35,0x00,0x00,0x00,0x00

# ATT:        vsm4key4  -512(,%rbp,2), %xmm23, %xmm22
# INTEL:      vsm4key4 xmm22, xmm23, xmmword ptr [2*rbp - 512]
0x62,0xe2,0x46,0x00,0xda,0x34,0x6d,0x00,0xfe,0xff,0xff

# ATT:        vsm4key4  2032(%rcx), %xmm23, %xmm22
# INTEL:      vsm4key4 xmm22, xmm23, xmmword ptr [rcx + 2032]
0x62,0xe2,0x46,0x00,0xda,0x71,0x7f

# ATT:        vsm4key4  -2048(%rdx), %xmm23, %xmm22
# INTEL:      vsm4key4 xmm22, xmm23, xmmword ptr [rdx - 2048]
0x62,0xe2,0x46,0x00,0xda,0x72,0x80

# ATT:        vsm4rnds4 %ymm24, %ymm23, %ymm22
# INTEL:      vsm4rnds4 ymm22, ymm23, ymm24
0x62,0x82,0x47,0x20,0xda,0xf0

# ATT:        vsm4rnds4 %xmm24, %xmm23, %xmm22
# INTEL:      vsm4rnds4 xmm22, xmm23, xmm24
0x62,0x82,0x47,0x00,0xda,0xf0

# ATT:        vsm4rnds4  268435456(%rbp,%r14,8), %ymm23, %ymm22
# INTEL:      vsm4rnds4 ymm22, ymm23, ymmword ptr [rbp + 8*r14 + 268435456]
0x62,0xa2,0x47,0x20,0xda,0xb4,0xf5,0x00,0x00,0x00,0x10

# ATT:        vsm4rnds4  291(%r8,%rax,4), %ymm23, %ymm22
# INTEL:      vsm4rnds4 ymm22, ymm23, ymmword ptr [r8 + 4*rax + 291]
0x62,0xc2,0x47,0x20,0xda,0xb4,0x80,0x23,0x01,0x00,0x00

# ATT:        vsm4rnds4  (%rip), %ymm23, %ymm22
# INTEL:      vsm4rnds4 ymm22, ymm23, ymmword ptr [rip]
0x62,0xe2,0x47,0x20,0xda,0x35,0x00,0x00,0x00,0x00

# ATT:        vsm4rnds4  -1024(,%rbp,2), %ymm23, %ymm22
# INTEL:      vsm4rnds4 ymm22, ymm23, ymmword ptr [2*rbp - 1024]
0x62,0xe2,0x47,0x20,0xda,0x34,0x6d,0x00,0xfc,0xff,0xff

# ATT:        vsm4rnds4  4064(%rcx), %ymm23, %ymm22
# INTEL:      vsm4rnds4 ymm22, ymm23, ymmword ptr [rcx + 4064]
0x62,0xe2,0x47,0x20,0xda,0x71,0x7f

# ATT:        vsm4rnds4  -4096(%rdx), %ymm23, %ymm22
# INTEL:      vsm4rnds4 ymm22, ymm23, ymmword ptr [rdx - 4096]
0x62,0xe2,0x47,0x20,0xda,0x72,0x80

# ATT:        vsm4rnds4  268435456(%rbp,%r14,8), %xmm23, %xmm22
# INTEL:      vsm4rnds4 xmm22, xmm23, xmmword ptr [rbp + 8*r14 + 268435456]
0x62,0xa2,0x47,0x00,0xda,0xb4,0xf5,0x00,0x00,0x00,0x10

# ATT:        vsm4rnds4  291(%r8,%rax,4), %xmm23, %xmm22
# INTEL:      vsm4rnds4 xmm22, xmm23, xmmword ptr [r8 + 4*rax + 291]
0x62,0xc2,0x47,0x00,0xda,0xb4,0x80,0x23,0x01,0x00,0x00

# ATT:        vsm4rnds4  (%rip), %xmm23, %xmm22
# INTEL:      vsm4rnds4 xmm22, xmm23, xmmword ptr [rip]
0x62,0xe2,0x47,0x00,0xda,0x35,0x00,0x00,0x00,0x00

# ATT:        vsm4rnds4  -512(,%rbp,2), %xmm23, %xmm22
# INTEL:      vsm4rnds4 xmm22, xmm23, xmmword ptr [2*rbp - 512]
0x62,0xe2,0x47,0x00,0xda,0x34,0x6d,0x00,0xfe,0xff,0xff

# ATT:        vsm4rnds4  2032(%rcx), %xmm23, %xmm22
# INTEL:      vsm4rnds4 xmm22, xmm23, xmmword ptr [rcx + 2032]
0x62,0xe2,0x47,0x00,0xda,0x71,0x7f

# ATT:        vsm4rnds4  -2048(%rdx), %xmm23, %xmm22
# INTEL:      vsm4rnds4 xmm22, xmm23, xmmword ptr [rdx - 2048]
0x62,0xe2,0x47,0x00,0xda,0x72,0x80
