// RUN: llvm-mc -triple x86_64-unknown-unknown --show-encoding %s | FileCheck %s
// CHECK: vaesdec 485498096, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xde,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
vaesdec 485498096, %xmm15, %xmm15
// CHECK: vaesdec 485498096, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xde,0x34,0x25,0xf0,0x1c,0xf0,0x1c]
vaesdec 485498096, %xmm6, %xmm6
// CHECK: vaesdec 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xde,0x7c,0x82,0x40]
vaesdec 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesdec -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xde,0x7c,0x82,0xc0]
vaesdec -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesdec 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xde,0x74,0x82,0x40]
vaesdec 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesdec -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xde,0x74,0x82,0xc0]
vaesdec -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesdec 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xde,0x7c,0x02,0x40]
vaesdec 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: vaesdec 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xde,0x74,0x02,0x40]
vaesdec 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: vaesdec 64(%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xde,0x7a,0x40]
vaesdec 64(%rdx), %xmm15, %xmm15
// CHECK: vaesdec 64(%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xde,0x72,0x40]
vaesdec 64(%rdx), %xmm6, %xmm6
// CHECK: vaesdeclast 485498096, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdf,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
vaesdeclast 485498096, %xmm15, %xmm15
// CHECK: vaesdeclast 485498096, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdf,0x34,0x25,0xf0,0x1c,0xf0,0x1c]
vaesdeclast 485498096, %xmm6, %xmm6
// CHECK: vaesdeclast 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdf,0x7c,0x82,0x40]
vaesdeclast 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesdeclast -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdf,0x7c,0x82,0xc0]
vaesdeclast -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesdeclast 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdf,0x74,0x82,0x40]
vaesdeclast 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesdeclast -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdf,0x74,0x82,0xc0]
vaesdeclast -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesdeclast 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdf,0x7c,0x02,0x40]
vaesdeclast 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: vaesdeclast 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdf,0x74,0x02,0x40]
vaesdeclast 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: vaesdeclast 64(%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdf,0x7a,0x40]
vaesdeclast 64(%rdx), %xmm15, %xmm15
// CHECK: vaesdeclast 64(%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdf,0x72,0x40]
vaesdeclast 64(%rdx), %xmm6, %xmm6
// CHECK: vaesdeclast (%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdf,0x3a]
vaesdeclast (%rdx), %xmm15, %xmm15
// CHECK: vaesdeclast (%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdf,0x32]
vaesdeclast (%rdx), %xmm6, %xmm6
// CHECK: vaesdeclast %xmm15, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x42,0x01,0xdf,0xff]
vaesdeclast %xmm15, %xmm15, %xmm15
// CHECK: vaesdeclast %xmm6, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdf,0xf6]
vaesdeclast %xmm6, %xmm6, %xmm6
// CHECK: vaesdec (%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xde,0x3a]
vaesdec (%rdx), %xmm15, %xmm15
// CHECK: vaesdec (%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xde,0x32]
vaesdec (%rdx), %xmm6, %xmm6
// CHECK: vaesdec %xmm15, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x42,0x01,0xde,0xff]
vaesdec %xmm15, %xmm15, %xmm15
// CHECK: vaesdec %xmm6, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xde,0xf6]
vaesdec %xmm6, %xmm6, %xmm6
// CHECK: vaesenc 485498096, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdc,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
vaesenc 485498096, %xmm15, %xmm15
// CHECK: vaesenc 485498096, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdc,0x34,0x25,0xf0,0x1c,0xf0,0x1c]
vaesenc 485498096, %xmm6, %xmm6
// CHECK: vaesenc 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdc,0x7c,0x82,0x40]
vaesenc 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesenc -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdc,0x7c,0x82,0xc0]
vaesenc -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesenc 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdc,0x74,0x82,0x40]
vaesenc 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesenc -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdc,0x74,0x82,0xc0]
vaesenc -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesenc 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdc,0x7c,0x02,0x40]
vaesenc 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: vaesenc 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdc,0x74,0x02,0x40]
vaesenc 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: vaesenc 64(%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdc,0x7a,0x40]
vaesenc 64(%rdx), %xmm15, %xmm15
// CHECK: vaesenc 64(%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdc,0x72,0x40]
vaesenc 64(%rdx), %xmm6, %xmm6
// CHECK: vaesenclast 485498096, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdd,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
vaesenclast 485498096, %xmm15, %xmm15
// CHECK: vaesenclast 485498096, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdd,0x34,0x25,0xf0,0x1c,0xf0,0x1c]
vaesenclast 485498096, %xmm6, %xmm6
// CHECK: vaesenclast 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdd,0x7c,0x82,0x40]
vaesenclast 64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesenclast -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdd,0x7c,0x82,0xc0]
vaesenclast -64(%rdx,%rax,4), %xmm15, %xmm15
// CHECK: vaesenclast 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdd,0x74,0x82,0x40]
vaesenclast 64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesenclast -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdd,0x74,0x82,0xc0]
vaesenclast -64(%rdx,%rax,4), %xmm6, %xmm6
// CHECK: vaesenclast 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdd,0x7c,0x02,0x40]
vaesenclast 64(%rdx,%rax), %xmm15, %xmm15
// CHECK: vaesenclast 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdd,0x74,0x02,0x40]
vaesenclast 64(%rdx,%rax), %xmm6, %xmm6
// CHECK: vaesenclast 64(%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdd,0x7a,0x40]
vaesenclast 64(%rdx), %xmm15, %xmm15
// CHECK: vaesenclast 64(%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdd,0x72,0x40]
vaesenclast 64(%rdx), %xmm6, %xmm6
// CHECK: vaesenclast (%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdd,0x3a]
vaesenclast (%rdx), %xmm15, %xmm15
// CHECK: vaesenclast (%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdd,0x32]
vaesenclast (%rdx), %xmm6, %xmm6
// CHECK: vaesenclast %xmm15, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x42,0x01,0xdd,0xff]
vaesenclast %xmm15, %xmm15, %xmm15
// CHECK: vaesenclast %xmm6, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdd,0xf6]
vaesenclast %xmm6, %xmm6, %xmm6
// CHECK: vaesenc (%rdx), %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x62,0x01,0xdc,0x3a]
vaesenc (%rdx), %xmm15, %xmm15
// CHECK: vaesenc (%rdx), %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdc,0x32]
vaesenc (%rdx), %xmm6, %xmm6
// CHECK: vaesenc %xmm15, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x42,0x01,0xdc,0xff]
vaesenc %xmm15, %xmm15, %xmm15
// CHECK: vaesenc %xmm6, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x49,0xdc,0xf6]
vaesenc %xmm6, %xmm6, %xmm6
// CHECK: vaesimc 485498096, %xmm15
// CHECK: encoding: [0xc4,0x62,0x79,0xdb,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
vaesimc 485498096, %xmm15
// CHECK: vaesimc 485498096, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x79,0xdb,0x34,0x25,0xf0,0x1c,0xf0,0x1c]
vaesimc 485498096, %xmm6
// CHECK: vaesimc 64(%rdx,%rax,4), %xmm15
// CHECK: encoding: [0xc4,0x62,0x79,0xdb,0x7c,0x82,0x40]
vaesimc 64(%rdx,%rax,4), %xmm15
// CHECK: vaesimc -64(%rdx,%rax,4), %xmm15
// CHECK: encoding: [0xc4,0x62,0x79,0xdb,0x7c,0x82,0xc0]
vaesimc -64(%rdx,%rax,4), %xmm15
// CHECK: vaesimc 64(%rdx,%rax,4), %xmm6
// CHECK: encoding: [0xc4,0xe2,0x79,0xdb,0x74,0x82,0x40]
vaesimc 64(%rdx,%rax,4), %xmm6
// CHECK: vaesimc -64(%rdx,%rax,4), %xmm6
// CHECK: encoding: [0xc4,0xe2,0x79,0xdb,0x74,0x82,0xc0]
vaesimc -64(%rdx,%rax,4), %xmm6
// CHECK: vaesimc 64(%rdx,%rax), %xmm15
// CHECK: encoding: [0xc4,0x62,0x79,0xdb,0x7c,0x02,0x40]
vaesimc 64(%rdx,%rax), %xmm15
// CHECK: vaesimc 64(%rdx,%rax), %xmm6
// CHECK: encoding: [0xc4,0xe2,0x79,0xdb,0x74,0x02,0x40]
vaesimc 64(%rdx,%rax), %xmm6
// CHECK: vaesimc 64(%rdx), %xmm15
// CHECK: encoding: [0xc4,0x62,0x79,0xdb,0x7a,0x40]
vaesimc 64(%rdx), %xmm15
// CHECK: vaesimc 64(%rdx), %xmm6
// CHECK: encoding: [0xc4,0xe2,0x79,0xdb,0x72,0x40]
vaesimc 64(%rdx), %xmm6
// CHECK: vaesimc (%rdx), %xmm15
// CHECK: encoding: [0xc4,0x62,0x79,0xdb,0x3a]
vaesimc (%rdx), %xmm15
// CHECK: vaesimc (%rdx), %xmm6
// CHECK: encoding: [0xc4,0xe2,0x79,0xdb,0x32]
vaesimc (%rdx), %xmm6
// CHECK: vaesimc %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x42,0x79,0xdb,0xff]
vaesimc %xmm15, %xmm15
// CHECK: vaesimc %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe2,0x79,0xdb,0xf6]
vaesimc %xmm6, %xmm6
// CHECK: vaeskeygenassist $0, 485498096, %xmm15
// CHECK: encoding: [0xc4,0x63,0x79,0xdf,0x3c,0x25,0xf0,0x1c,0xf0,0x1c,0x00]
vaeskeygenassist $0, 485498096, %xmm15
// CHECK: vaeskeygenassist $0, 485498096, %xmm6
// CHECK: encoding: [0xc4,0xe3,0x79,0xdf,0x34,0x25,0xf0,0x1c,0xf0,0x1c,0x00]
vaeskeygenassist $0, 485498096, %xmm6
// CHECK: vaeskeygenassist $0, 64(%rdx,%rax,4), %xmm15
// CHECK: encoding: [0xc4,0x63,0x79,0xdf,0x7c,0x82,0x40,0x00]
vaeskeygenassist $0, 64(%rdx,%rax,4), %xmm15
// CHECK: vaeskeygenassist $0, -64(%rdx,%rax,4), %xmm15
// CHECK: encoding: [0xc4,0x63,0x79,0xdf,0x7c,0x82,0xc0,0x00]
vaeskeygenassist $0, -64(%rdx,%rax,4), %xmm15
// CHECK: vaeskeygenassist $0, 64(%rdx,%rax,4), %xmm6
// CHECK: encoding: [0xc4,0xe3,0x79,0xdf,0x74,0x82,0x40,0x00]
vaeskeygenassist $0, 64(%rdx,%rax,4), %xmm6
// CHECK: vaeskeygenassist $0, -64(%rdx,%rax,4), %xmm6
// CHECK: encoding: [0xc4,0xe3,0x79,0xdf,0x74,0x82,0xc0,0x00]
vaeskeygenassist $0, -64(%rdx,%rax,4), %xmm6
// CHECK: vaeskeygenassist $0, 64(%rdx,%rax), %xmm15
// CHECK: encoding: [0xc4,0x63,0x79,0xdf,0x7c,0x02,0x40,0x00]
vaeskeygenassist $0, 64(%rdx,%rax), %xmm15
// CHECK: vaeskeygenassist $0, 64(%rdx,%rax), %xmm6
// CHECK: encoding: [0xc4,0xe3,0x79,0xdf,0x74,0x02,0x40,0x00]
vaeskeygenassist $0, 64(%rdx,%rax), %xmm6
// CHECK: vaeskeygenassist $0, 64(%rdx), %xmm15
// CHECK: encoding: [0xc4,0x63,0x79,0xdf,0x7a,0x40,0x00]
vaeskeygenassist $0, 64(%rdx), %xmm15
// CHECK: vaeskeygenassist $0, 64(%rdx), %xmm6
// CHECK: encoding: [0xc4,0xe3,0x79,0xdf,0x72,0x40,0x00]
vaeskeygenassist $0, 64(%rdx), %xmm6
// CHECK: vaeskeygenassist $0, (%rdx), %xmm15
// CHECK: encoding: [0xc4,0x63,0x79,0xdf,0x3a,0x00]
vaeskeygenassist $0, (%rdx), %xmm15
// CHECK: vaeskeygenassist $0, (%rdx), %xmm6
// CHECK: encoding: [0xc4,0xe3,0x79,0xdf,0x32,0x00]
vaeskeygenassist $0, (%rdx), %xmm6
// CHECK: vaeskeygenassist $0, %xmm15, %xmm15
// CHECK: encoding: [0xc4,0x43,0x79,0xdf,0xff,0x00]
vaeskeygenassist $0, %xmm15, %xmm15
// CHECK: vaeskeygenassist $0, %xmm6, %xmm6
// CHECK: encoding: [0xc4,0xe3,0x79,0xdf,0xf6,0x00]
vaeskeygenassist $0, %xmm6, %xmm6