aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/MC/X86/sm4-32-intel.s
blob: 1a413afced78a283a3eac128a8298e004fa3779e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
// RUN: llvm-mc -triple i686-unknown-unknown -x86-asm-syntax=intel -output-asm-variant=1 --show-encoding %s | FileCheck %s

// CHECK:      vsm4key4 ymm2, ymm3, ymm4
// CHECK: encoding: [0xc4,0xe2,0x66,0xda,0xd4]
               vsm4key4 ymm2, ymm3, ymm4

// CHECK:      vsm4key4 xmm2, xmm3, xmm4
// CHECK: encoding: [0xc4,0xe2,0x62,0xda,0xd4]
               vsm4key4 xmm2, xmm3, xmm4

// CHECK:      vsm4key4 ymm2, ymm3, ymmword ptr [esp + 8*esi + 268435456]
// CHECK: encoding: [0xc4,0xe2,0x66,0xda,0x94,0xf4,0x00,0x00,0x00,0x10]
               vsm4key4 ymm2, ymm3, ymmword ptr [esp + 8*esi + 268435456]

// CHECK:      vsm4key4 ymm2, ymm3, ymmword ptr [edi + 4*eax + 291]
// CHECK: encoding: [0xc4,0xe2,0x66,0xda,0x94,0x87,0x23,0x01,0x00,0x00]
               vsm4key4 ymm2, ymm3, ymmword ptr [edi + 4*eax + 291]

// CHECK:      vsm4key4 ymm2, ymm3, ymmword ptr [eax]
// CHECK: encoding: [0xc4,0xe2,0x66,0xda,0x10]
               vsm4key4 ymm2, ymm3, ymmword ptr [eax]

// CHECK:      vsm4key4 ymm2, ymm3, ymmword ptr [2*ebp - 1024]
// CHECK: encoding: [0xc4,0xe2,0x66,0xda,0x14,0x6d,0x00,0xfc,0xff,0xff]
               vsm4key4 ymm2, ymm3, ymmword ptr [2*ebp - 1024]

// CHECK:      vsm4key4 ymm2, ymm3, ymmword ptr [ecx + 4064]
// CHECK: encoding: [0xc4,0xe2,0x66,0xda,0x91,0xe0,0x0f,0x00,0x00]
               vsm4key4 ymm2, ymm3, ymmword ptr [ecx + 4064]

// CHECK:      vsm4key4 ymm2, ymm3, ymmword ptr [edx - 4096]
// CHECK: encoding: [0xc4,0xe2,0x66,0xda,0x92,0x00,0xf0,0xff,0xff]
               vsm4key4 ymm2, ymm3, ymmword ptr [edx - 4096]

// CHECK:      vsm4key4 xmm2, xmm3, xmmword ptr [esp + 8*esi + 268435456]
// CHECK: encoding: [0xc4,0xe2,0x62,0xda,0x94,0xf4,0x00,0x00,0x00,0x10]
               vsm4key4 xmm2, xmm3, xmmword ptr [esp + 8*esi + 268435456]

// CHECK:      vsm4key4 xmm2, xmm3, xmmword ptr [edi + 4*eax + 291]
// CHECK: encoding: [0xc4,0xe2,0x62,0xda,0x94,0x87,0x23,0x01,0x00,0x00]
               vsm4key4 xmm2, xmm3, xmmword ptr [edi + 4*eax + 291]

// CHECK:      vsm4key4 xmm2, xmm3, xmmword ptr [eax]
// CHECK: encoding: [0xc4,0xe2,0x62,0xda,0x10]
               vsm4key4 xmm2, xmm3, xmmword ptr [eax]

// CHECK:      vsm4key4 xmm2, xmm3, xmmword ptr [2*ebp - 512]
// CHECK: encoding: [0xc4,0xe2,0x62,0xda,0x14,0x6d,0x00,0xfe,0xff,0xff]
               vsm4key4 xmm2, xmm3, xmmword ptr [2*ebp - 512]

// CHECK:      vsm4key4 xmm2, xmm3, xmmword ptr [ecx + 2032]
// CHECK: encoding: [0xc4,0xe2,0x62,0xda,0x91,0xf0,0x07,0x00,0x00]
               vsm4key4 xmm2, xmm3, xmmword ptr [ecx + 2032]

// CHECK:      vsm4key4 xmm2, xmm3, xmmword ptr [edx - 2048]
// CHECK: encoding: [0xc4,0xe2,0x62,0xda,0x92,0x00,0xf8,0xff,0xff]
               vsm4key4 xmm2, xmm3, xmmword ptr [edx - 2048]

// CHECK:      vsm4rnds4 ymm2, ymm3, ymm4
// CHECK: encoding: [0xc4,0xe2,0x67,0xda,0xd4]
               vsm4rnds4 ymm2, ymm3, ymm4

// CHECK:      vsm4rnds4 xmm2, xmm3, xmm4
// CHECK: encoding: [0xc4,0xe2,0x63,0xda,0xd4]
               vsm4rnds4 xmm2, xmm3, xmm4

// CHECK:      vsm4rnds4 ymm2, ymm3, ymmword ptr [esp + 8*esi + 268435456]
// CHECK: encoding: [0xc4,0xe2,0x67,0xda,0x94,0xf4,0x00,0x00,0x00,0x10]
               vsm4rnds4 ymm2, ymm3, ymmword ptr [esp + 8*esi + 268435456]

// CHECK:      vsm4rnds4 ymm2, ymm3, ymmword ptr [edi + 4*eax + 291]
// CHECK: encoding: [0xc4,0xe2,0x67,0xda,0x94,0x87,0x23,0x01,0x00,0x00]
               vsm4rnds4 ymm2, ymm3, ymmword ptr [edi + 4*eax + 291]

// CHECK:      vsm4rnds4 ymm2, ymm3, ymmword ptr [eax]
// CHECK: encoding: [0xc4,0xe2,0x67,0xda,0x10]
               vsm4rnds4 ymm2, ymm3, ymmword ptr [eax]

// CHECK:      vsm4rnds4 ymm2, ymm3, ymmword ptr [2*ebp - 1024]
// CHECK: encoding: [0xc4,0xe2,0x67,0xda,0x14,0x6d,0x00,0xfc,0xff,0xff]
               vsm4rnds4 ymm2, ymm3, ymmword ptr [2*ebp - 1024]

// CHECK:      vsm4rnds4 ymm2, ymm3, ymmword ptr [ecx + 4064]
// CHECK: encoding: [0xc4,0xe2,0x67,0xda,0x91,0xe0,0x0f,0x00,0x00]
               vsm4rnds4 ymm2, ymm3, ymmword ptr [ecx + 4064]

// CHECK:      vsm4rnds4 ymm2, ymm3, ymmword ptr [edx - 4096]
// CHECK: encoding: [0xc4,0xe2,0x67,0xda,0x92,0x00,0xf0,0xff,0xff]
               vsm4rnds4 ymm2, ymm3, ymmword ptr [edx - 4096]

// CHECK:      vsm4rnds4 xmm2, xmm3, xmmword ptr [esp + 8*esi + 268435456]
// CHECK: encoding: [0xc4,0xe2,0x63,0xda,0x94,0xf4,0x00,0x00,0x00,0x10]
               vsm4rnds4 xmm2, xmm3, xmmword ptr [esp + 8*esi + 268435456]

// CHECK:      vsm4rnds4 xmm2, xmm3, xmmword ptr [edi + 4*eax + 291]
// CHECK: encoding: [0xc4,0xe2,0x63,0xda,0x94,0x87,0x23,0x01,0x00,0x00]
               vsm4rnds4 xmm2, xmm3, xmmword ptr [edi + 4*eax + 291]

// CHECK:      vsm4rnds4 xmm2, xmm3, xmmword ptr [eax]
// CHECK: encoding: [0xc4,0xe2,0x63,0xda,0x10]
               vsm4rnds4 xmm2, xmm3, xmmword ptr [eax]

// CHECK:      vsm4rnds4 xmm2, xmm3, xmmword ptr [2*ebp - 512]
// CHECK: encoding: [0xc4,0xe2,0x63,0xda,0x14,0x6d,0x00,0xfe,0xff,0xff]
               vsm4rnds4 xmm2, xmm3, xmmword ptr [2*ebp - 512]

// CHECK:      vsm4rnds4 xmm2, xmm3, xmmword ptr [ecx + 2032]
// CHECK: encoding: [0xc4,0xe2,0x63,0xda,0x91,0xf0,0x07,0x00,0x00]
               vsm4rnds4 xmm2, xmm3, xmmword ptr [ecx + 2032]

// CHECK:      vsm4rnds4 xmm2, xmm3, xmmword ptr [edx - 2048]
// CHECK: encoding: [0xc4,0xe2,0x63,0xda,0x92,0x00,0xf8,0xff,0xff]
               vsm4rnds4 xmm2, xmm3, xmmword ptr [edx - 2048]