intel-syntax-encoding.s
2.17 KB
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
// RUN: llvm-mc -x86-asm-syntax=intel -triple x86_64-unknown-unknown --show-encoding %s | FileCheck %s
// CHECK: encoding: [0x66,0x83,0xf0,0x0c]
xor ax, 12
// CHECK: encoding: [0x83,0xf0,0x0c]
xor eax, 12
// CHECK: encoding: [0x48,0x83,0xf0,0x0c]
xor rax, 12
// CHECK: encoding: [0x66,0x83,0xc8,0x0c]
or ax, 12
// CHECK: encoding: [0x83,0xc8,0x0c]
or eax, 12
// CHECK: encoding: [0x48,0x83,0xc8,0x0c]
or rax, 12
// CHECK: encoding: [0x66,0x83,0xf8,0x0c]
cmp ax, 12
// CHECK: encoding: [0x83,0xf8,0x0c]
cmp eax, 12
// CHECK: encoding: [0x48,0x83,0xf8,0x0c]
cmp rax, 12
// CHECK: encoding: [0x48,0x89,0x44,0x24,0xf0]
mov QWORD PTR [RSP - 16], RAX
// CHECK: encoding: [0x66,0x83,0xc0,0xf4]
add ax, -12
// CHECK: encoding: [0x83,0xc0,0xf4]
add eax, -12
// CHECK: encoding: [0x48,0x83,0xc0,0xf4]
add rax, -12
// CHECK: encoding: [0x66,0x83,0xd0,0xf4]
adc ax, -12
// CHECK: encoding: [0x83,0xd0,0xf4]
adc eax, -12
// CHECK: encoding: [0x48,0x83,0xd0,0xf4]
adc rax, -12
// CHECK: encoding: [0x66,0x83,0xd8,0xf4]
sbb ax, -12
// CHECK: encoding: [0x83,0xd8,0xf4]
sbb eax, -12
// CHECK: encoding: [0x48,0x83,0xd8,0xf4]
sbb rax, -12
// CHECK: encoding: [0x66,0x83,0xf8,0xf4]
cmp ax, -12
// CHECK: encoding: [0x83,0xf8,0xf4]
cmp eax, -12
// CHECK: encoding: [0x48,0x83,0xf8,0xf4]
cmp rax, -12
acquire lock add [rax], rax
// CHECK: encoding: [0xf2]
// CHECK: encoding: [0xf0,0x48,0x01,0x00]
release lock add [rax], rax
// CHECK: encoding: [0xf3]
// CHECK: encoding: [0xf0,0x48,0x01,0x00]
// CHECK: encoding: [0x9c]
// CHECK: encoding: [0x9d]
pushf
popf
// CHECK: encoding: [0x66,0x9c]
// CHECK: encoding: [0x66,0x9d]
pushfw
popfw
LBB0_3:
// CHECK: encoding: [0xeb,A]
jmp LBB0_3
// CHECK: encoding: [0xf2,0x0f,0x10,0x2c,0x25,0xf8,0xff,0xff,0xff]
movsd XMM5, QWORD PTR [-8]
// CHECK: encoding: [0xd1,0xe7]
shl EDI, 1
// CHECK: encoding: [0x0f,0xc2,0xd1,0x01]
cmpltps XMM2, XMM1
// CHECK: encoding: [0xc3]
ret
// CHECK: encoding: [0xcb]
retf
// CHECK: encoding: [0xc2,0x08,0x00]
ret 8
// CHECK: encoding: [0xca,0x08,0x00]
retf 8
.set FOO, 2
cmp eax, FOO
// CHECK: encoding: [0x83,0xf8,0x02]
cmp eax, FOO[eax]
// CHECK: encoding: [0x67,0x3b,0x40,0x02]