1 // RUN
: llvm-mc
-triple x86_64-unknown-unknown
-show-encoding
%s
> %t 2> %t.err
2 // RUN
: FileCheck
< %t %s
3 // RUN
: FileCheck
--check-prefix
=CHECK-STDERR
< %t.err
%s
7 // CHECK
: encoding
: [0x0f,0x01,0xc8]
8 monitor
%rax
, %rcx
, %rdx
10 // CHECK
: encoding
: [0x0f,0x01,0xc8]
13 // CHECK
: encoding
: [0x0f,0x01,0xc9]
16 // CHECK
: encoding
: [0x0f,0x01,0xc9]
20 // CHECK
: addl $
0, %eax
22 // CHECK
: addb $
255, %al
24 // CHECK
: orq
%rax
, %rdx
26 // CHECK
: shlq $
3, %rax
30 // CHECK
: subb
%al
, %al
33 // CHECK
: addl $
24, %eax
36 // CHECK
: movl
%eax
, 10(%ebp
)
38 // CHECK
: movl
%eax
, 10(%ebp
,%ebx
)
39 movl
%eax
, 10(%ebp
, %ebx
)
40 // CHECK
: movl
%eax
, 10(%ebp
,%ebx
,4)
41 movl
%eax
, 10(%ebp
, %ebx
, 4)
42 // CHECK
: movl
%eax
, 10(,%ebx
,4)
43 movl
%eax
, 10(, %ebx
, 4)
45 // CHECK
: movl
0, %eax
47 // CHECK
: movl $
0, %eax
56 // FIXME
: Check that this matches SUB32ri8
57 // CHECK
: subl $
1, %eax
60 // FIXME
: Check that this matches SUB32ri8
61 // CHECK
: subl $
-1, %eax
64 // FIXME
: Check that this matches SUB32ri
65 // CHECK
: subl $
256, %eax
68 // FIXME
: Check that this matches XOR64ri8
69 // CHECK
: xorq $
1, %rax
72 // FIXME
: Check that this matches XOR64ri32
73 // CHECK
: xorq $
256, %rax
76 // FIXME
: Check that this matches SUB8rr
77 // CHECK
: subb
%al
, %bl
80 // FIXME
: Check that this matches SUB16rr
81 // CHECK
: subw
%ax
, %bx
84 // FIXME
: Check that this matches SUB32rr
85 // CHECK
: subl
%eax
, %ebx
88 // FIXME
: Check that this matches the correct instruction.
92 // FIXME
: Check that this matches the correct instruction.
93 // CHECK
: shldl
%cl
, %eax
, %ebx
96 // CHECK
: shll $
2, %eax
99 // CHECK
: shll $
2, %eax
121 smovb
// CHECK
: movsb
122 smovw
// CHECK
: movsw
123 smovl
// CHECK
: movsl
124 smovq
// CHECK
: movsq
139 // NOTE
: repz
and repe have the same opcode as rep
144 // NOTE
: repnz has the same opcode as repne
149 // NOTE
: repe
and repz have the same opcode as rep
159 // CHECK
: cmpxchgb
%al
, (%ebx
)
160 lock;cmpxchgb
%al
, 0(%ebx
)
163 // CHECK
: movb
(%eax
), %al
167 // CHECK
: movb
(%eax
), %al
171 // CHECK
: movb
(%eax
), %al
175 // CHECK
: movb
(%eax
), %al
179 // CHECK
: movb
(%eax
), %al
183 // CHECK
: movb
(%eax
), %al
186 // CHECK
: fadd %st(0)
187 // CHECK
: fadd %st(1)
188 // CHECK
: fadd %st(7)
194 // CHECK
: leal
0, %eax
197 // rdar
://7986634 - Insensitivity on opcodes.
201 // rdar
://8735979 - int $
3 -> int3
206 // Allow scale factor without index register.
207 // CHECK
: movaps
%xmm3
, (%esi
)
208 // CHECK-STDERR
: warning
: scale factor without index register is ignored
209 movaps
%xmm3
, (%esi
, 2)
211 // CHECK
: imull $
12, %eax
214 // CHECK
: imull
%ecx
, %eax
219 // CHECK
: outb
%al
, $
161
221 // CHECK
: outw
%ax
, $
128
223 // CHECK
: inb $
161, %al
232 // CHECK
: encoding
: [0x6a,0x01]
234 // CHECK
: encoding
: [0x68,0x47,0xf4,0x10,0x00]
241 // CHECK
: cmovnew
%bx
, %ax
243 // CHECK
: cmovneq
%rbx
, %rax
248 // CHECK
: inb $
127, %al
249 // CHECK
: inw
%dx
, %ax
250 // CHECK
: outb
%al
, $
127
251 // CHECK
: outw
%ax
, %dx
252 // CHECK
: inl
%dx
, %eax
261 // CHECK
: outb
%al
, %dx
262 // CHECK
: outb
%al
, %dx
263 // CHECK
: outw
%ax
, %dx
264 // CHECK
: outw
%ax
, %dx
265 // CHECK
: outl
%eax
, %dx
266 // CHECK
: outl
%eax
, %dx
275 // CHECK
: inb
%dx
, %al
276 // CHECK
: inb
%dx
, %al
277 // CHECK
: inw
%dx
, %ax
278 // CHECK
: inw
%dx
, %ax
279 // CHECK
: inl
%dx
, %eax
280 // CHECK
: inl
%dx
, %eax
292 // CHECK
: outsb
(%rsi
), %dx
294 // CHECK
: outsw
(%rsi
), %dx
296 // CHECK
: outsl
(%rsi
), %dx
298 insb
(%dx
), %es
:(%rdi
)
299 // CHECK
: insb
%dx
, %es
:(%rdi
)
300 insw
(%dx
), %es
:(%rdi
)
301 // CHECK
: insw
%dx
, %es
:(%rdi
)
302 insl
(%dx
), %es
:(%rdi
)
303 // CHECK
: insl
%dx
, %es
:(%rdi
)
307 // CHECK
: fxch
%st(1)
308 // CHECK
: fucom
%st(1)
309 // CHECK
: fucomp
%st(1)
310 // CHECK
: faddp
%st, %st(1)
311 // CHECK
: faddp
%st, %st(0)
312 // CHECK
: fsubp
%st, %st(1)
313 // CHECK
: fsubrp
%st, %st(1)
314 // CHECK
: fmulp
%st, %st(1)
315 // CHECK
: fdivp
%st, %st(1)
316 // CHECK
: fdivrp
%st, %st(1)
329 // CHECK
: fcomi
%st(1)
330 // CHECK
: fcomi
%st(2)
331 // CHECK
: fucomi
%st(1)
332 // CHECK
: fucomi
%st(2)
333 // CHECK
: fucomi
%st(2)
349 // CHECK
: rcll
3735928559(%ebx
,%ecx
,8)
351 // CHECK
: rcrl
305419896
353 rcll
0xdeadbeef(%ebx
,%ecx
,8)
357 rclb
%bl // CHECK
: rclb
%bl # encoding: [0xd0,0xd3]
358 rclb $
1, %bl // CHECK
: rclb
%bl # encoding: [0xd0,0xd3]
359 rclb $
2, %bl // CHECK
: rclb $
2, %bl # encoding: [0xc0,0xd3,0x02]
363 // CHECK
: shldw
%cl
, %bx
, %dx
364 // CHECK
: shldw
%cl
, %bx
, %dx
365 // CHECK
: shldw $
1, %bx
, %dx
366 // CHECK
: shldw
%cl
, %bx
, (%rax
)
367 // CHECK
: shldw
%cl
, %bx
, (%rax
)
368 // CHECK
: shrdw
%cl
, %bx
, %dx
369 // CHECK
: shrdw
%cl
, %bx
, %dx
370 // CHECK
: shrdw $
1, %bx
, %dx
371 // CHECK
: shrdw
%cl
, %bx
, (%rax
)
372 // CHECK
: shrdw
%cl
, %bx
, (%rax
)
378 shld
%cl
, %bx
, (%rax
)
383 shrd
%cl
, %bx
, (%rax
)
386 // CHECK
: encoding
: [0x0f,0x00,0xc1]
388 // CHECK
: encoding
: [0x66,0x0f,0x00,0xc1]
393 // CHECK
: lcalll
*3135175374
394 // CHECK
: ljmpl
*3135175374
395 // CHECK
: lcalll
*(%rax
)
396 // CHECK
: ljmpl
*(%rax
)
403 // CHECK
: enter $
31438, $
0
404 // CHECK
: encoding
: [0xc8,0xce,0x7a,0x00]
405 // CHECK
: enter $
31438, $
1
406 // CHECK
: encoding
: [0xc8,0xce,0x7a,0x01]
407 // CHECK
: enter $
31438, $
127
408 // CHECK
: encoding
: [0xc8,0xce,0x7a,0x7f]
415 // CHECK
: movw
%cs
, %ax
419 fcmovb
%st(1), %st // CHECK
: fcmovb
%st(1), %st
420 fcmove
%st(1), %st // CHECK
: fcmove
%st(1), %st
421 fcmovbe
%st(1), %st // CHECK
: fcmovbe
%st(1), %st
422 fcmovu
%st(1), %st // CHECK
: fcmovu
%st(1), %st
424 fcmovnb
%st(1), %st // CHECK
: fcmovnb
%st(1), %st
425 fcmovne
%st(1), %st // CHECK
: fcmovne
%st(1), %st
426 fcmovnbe
%st(1), %st // CHECK
: fcmovnbe
%st(1), %st
427 fcmovnu
%st(1), %st // CHECK
: fcmovnu
%st(1), %st
429 fcmovnae
%st(1), %st // CHECK
: fcmovb
%st(1), %st
430 fcmovna
%st(1), %st // CHECK
: fcmovbe
%st(1), %st
432 fcmovae
%st(1), %st // CHECK
: fcmovnb
%st(1), %st
433 fcmova
%st(1), %st // CHECK
: fcmovnbe
%st(1), %st
436 .byte (88 + 1) & 15 // CHECK: .byte 9
440 // CHECK
: movq
%rdx
, %cr0
441 // CHECK
: encoding
: [0x0f,0x22,0xc2]
443 // CHECK
: movq
%rdx
, %cr4
444 // CHECK
: encoding
: [0x0f,0x22,0xe2]
446 // CHECK
: movq
%rdx
, %cr8
447 // CHECK
: encoding
: [0x44,0x0f,0x22,0xc2]
449 // CHECK
: movq
%rdx
, %cr15
450 // CHECK
: encoding
: [0x44,0x0f,0x22,0xfa]
452 // CHECK
: movq
%rdx
, %dr15
453 // CHECK
: encoding
: [0x44,0x0f,0x23,0xfa]
455 // CHECK
: movq
%rdx
, %dr15
456 // CHECK
: encoding
: [0x44,0x0f,0x23,0xfa]
458 // rdar
://8456371 - Handle commutable instructions written backward.
459 // CHECK
: faddp
%st, %st(1)
460 // CHECK
: fmulp
%st, %st(2)
464 // rdar
://8468087 - Encode these accurately
, they are
not synonyms.
465 // CHECK
: fmul %st, %st(1)
466 // CHECK
: encoding
: [0xdc,0xc9]
467 // CHECK
: fmul %st(1)
468 // CHECK
: encoding
: [0xd8,0xc9]
472 // CHECK
: fadd %st, %st(1)
473 // CHECK
: encoding
: [0xdc,0xc1]
474 // CHECK
: fadd %st(1)
475 // CHECK
: encoding
: [0xd8,0xc1]
481 // CHECK
: xorb
%al
, %al
482 // CHECK
: encoding
: [0x30,0xc0]
483 // CHECK
: xorw
%di
, %di
484 // CHECK
: encoding
: [0x66,0x31,0xff]
485 // CHECK
: xorl
%esi
, %esi
486 // CHECK
: encoding
: [0x31,0xf6]
487 // CHECK
: xorq
%rsi
, %rsi
488 // CHECK
: encoding
: [0x48,0x31,0xf6]
506 // rdar
://8456378 and PR7557
- fstsw
512 // CHECK
: fnstsw
(%rax
)
517 // CHECK
: fnstcw
(%rsp
)
522 // CHECK
: fnstcw
(%rsp
)
531 // CHECK
: fnsave
32493
534 // rdar
://8456382 - cvtsd2si support.
536 // CHECK
: cvtsd2si
%xmm1
, %rax
537 // CHECK
: encoding
: [0xf2,0x48,0x0f,0x2d,0xc1]
539 // CHECK
: cvtsd2si
%xmm1
, %eax
540 // CHECK
: encoding
: [0xf2,0x0f,0x2d,0xc1]
542 cvtsd2siq
%xmm0
, %rax
// CHECK
: cvtsd2si
%xmm0
, %rax
543 cvtsd2sil
%xmm0
, %eax
// CHECK
: cvtsd2si
%xmm0
, %eax
544 cvtsd2si
%xmm0
, %rax
// CHECK
: cvtsd2si
%xmm0
, %rax
547 cvttpd2dq
%xmm1
, %xmm0
// CHECK
: cvttpd2dq
%xmm1
, %xmm0
548 cvttpd2dq
(%rax
), %xmm0
// CHECK
: cvttpd2dq
(%rax
), %xmm0
550 cvttps2dq
%xmm1
, %xmm0
// CHECK
: cvttps2dq
%xmm1
, %xmm0
551 cvttps2dq
(%rax
), %xmm0
// CHECK
: cvttps2dq
(%rax
), %xmm0
553 // rdar
://8456376 - llvm-mc rejects
'roundss'
554 roundss $
0xE, %xmm0
, %xmm0
// CHECK
: encoding
: [0x66,0x0f,0x3a,0x0a,0xc0,0x0e]
555 roundps $
0xE, %xmm0
, %xmm0
// CHECK
: encoding
: [0x66,0x0f,0x3a,0x08,0xc0,0x0e]
556 roundsd $
0xE, %xmm0
, %xmm0
// CHECK
: encoding
: [0x66,0x0f,0x3a,0x0b,0xc0,0x0e]
557 roundpd $
0xE, %xmm0
, %xmm0
// CHECK
: encoding
: [0x66,0x0f,0x3a,0x09,0xc0,0x0e]
560 // rdar
://8482675 - 32-bit mem operand support in
64-bit mode
(0x67 prefix
)
562 // CHECK
: leal
8(%eax
), %esi
563 // CHECK
: encoding
: [0x67,0x8d,0x70,0x08]
565 // CHECK
: leaq
8(%eax
), %rsi
566 // CHECK
: encoding
: [0x67,0x48,0x8d,0x70,0x08]
568 // CHECK
: leaq
8(%rax
), %rsi
569 // CHECK
: encoding
: [0x48,0x8d,0x70,0x08]
572 cvttpd2dq
0xdeadbeef(%ebx
,%ecx
,8),%xmm5
573 // CHECK
: cvttpd2dq
3735928559(%ebx
,%ecx
,8), %xmm5
574 // CHECK
: encoding
: [0x67,0x66,0x0f,0xe6,0xac,0xcb,0xef,0xbe,0xad,0xde]
576 // rdar
://8490728 - llvm-mc rejects
'movmskpd'
578 // CHECK
: movmskpd
%xmm6
, %eax
579 // CHECK
: encoding
: [0x66,0x0f,0x50,0xc6]
581 // CHECK
: movmskpd
%xmm6
, %eax
582 // CHECK
: encoding
: [0x66,0x0f,0x50,0xc6]
584 // rdar
://8491845 - Gas supports commuted forms of non-commutable instructions.
585 fdivrp
%st, %st(1) // CHECK
: encoding
: [0xde,0xf9]
586 fdivrp
%st(1), %st // CHECK
: encoding
: [0xde,0xf9]
588 fsubrp
%st, %st(1) // CHECK
: encoding
: [0xde,0xe9]
589 fsubrp
%st(1), %st // CHECK
: encoding
: [0xde,0xe9]
592 fdivp
%st, %st(1) // CHECK
: encoding
: [0xde,0xf1]
593 fdivp
%st(1), %st // CHECK
: encoding
: [0xde,0xf1]
597 // CHECK
: movl foo
(%rip
), %eax
598 // CHECK
: encoding
: [0x8b,0x05,A,A,A,A]
599 // CHECK
: fixup
A - offset
: 2, value
: foo-
4, kind
: reloc_riprel_4byte
602 // CHECK
: movb $
12, foo
(%rip
)
603 // CHECK
: encoding
: [0xc6,0x05,A,A,A,A,0x0c]
604 // CHECK
: fixup
A - offset
: 2, value
: foo-
5, kind
: reloc_riprel_4byte
607 // CHECK
: movw $
12, foo
(%rip
)
608 // CHECK
: encoding
: [0x66,0xc7,0x05,A,A,A,A,0x0c,0x00]
609 // CHECK
: fixup
A - offset
: 3, value
: foo-
6, kind
: reloc_riprel_4byte
612 // CHECK
: movl $
12, foo
(%rip
)
613 // CHECK
: encoding
: [0xc7,0x05,A,A,A,A,0x0c,0x00,0x00,0x00]
614 // CHECK
: fixup
A - offset
: 2, value
: foo-
8, kind
: reloc_riprel_4byte
618 // CHECK
: movl $
12, 1024(%rip
)
619 // CHECK
: encoding
: [0xc7,0x05,0x00,0x04,0x00,0x00,0x0c,0x00,0x00,0x00]
622 // CHECK
: movq $
12, foo
(%rip
)
623 // CHECK
: encoding
: [0x48,0xc7,0x05,A,A,A,A,0x0c,0x00,0x00,0x00]
624 // CHECK
: fixup
A - offset
: 3, value
: foo-
8, kind
: reloc_riprel_4byte
627 // CHECK
: movl foo
(%eip
), %eax
628 // CHECK
: encoding
: [0x67,0x8b,0x05,A,A,A,A]
629 // CHECK
: fixup
A - offset
: 3, value
: foo-
4, kind
: reloc_riprel_4byte
632 // CHECK
: movb $
12, foo
(%eip
)
633 // CHECK
: encoding
: [0x67,0xc6,0x05,A,A,A,A,0x0c]
634 // CHECK
: fixup
A - offset
: 3, value
: foo-
5, kind
: reloc_riprel_4byte
637 // CHECK
: movw $
12, foo
(%eip
)
638 // CHECK
: encoding
: [0x67,0x66,0xc7,0x05,A,A,A,A,0x0c,0x00]
639 // CHECK
: fixup
A - offset
: 4, value
: foo-
6, kind
: reloc_riprel_4byte
642 // CHECK
: movl $
12, foo
(%eip
)
643 // CHECK
: encoding
: [0x67,0xc7,0x05,A,A,A,A,0x0c,0x00,0x00,0x00]
644 // CHECK
: fixup
A - offset
: 3, value
: foo-
8, kind
: reloc_riprel_4byte
647 // CHECK
: movq $
12, foo
(%eip
)
648 // CHECK
: encoding
: [0x67,0x48,0xc7,0x05,A,A,A,A,0x0c,0x00,0x00,0x00]
649 // CHECK
: fixup
A - offset
: 4, value
: foo-
8, kind
: reloc_riprel_4byte
651 // CHECK
: addq $
-424, %rax
652 // CHECK
: encoding
: [0x48,0x05,0x58,0xfe,0xff,0xff]
656 // CHECK
: movq _foo@GOTPCREL
(%rip
), %rax
657 // CHECK
: encoding
: [0x48,0x8b,0x05,A,A,A,A]
658 // CHECK
: fixup
A - offset
: 3, value
: _foo@GOTPCREL-
4, kind
: reloc_riprel_4byte_movq_load
659 movq _foo@GOTPCREL
(%rip
), %rax
661 // CHECK
: movq _foo@GOTPCREL
(%rip
), %r14
662 // CHECK
: encoding
: [0x4c,0x8b,0x35,A,A,A,A]
663 // CHECK
: fixup
A - offset
: 3, value
: _foo@GOTPCREL-
4, kind
: reloc_riprel_4byte_movq_load
664 movq _foo@GOTPCREL
(%rip
), %r14
666 // CHECK
: movq _foo@GOTPCREL
(%eip
), %rax
667 // CHECK
: encoding
: [0x67,0x48,0x8b,0x05,A,A,A,A]
668 // CHECK
: fixup
A - offset
: 4, value
: _foo@GOTPCREL-
4, kind
: reloc_riprel_4byte_movq_load
669 movq _foo@GOTPCREL
(%eip
), %rax
671 // CHECK
: movq _foo@GOTPCREL
(%eip
), %r14
672 // CHECK
: encoding
: [0x67,0x4c,0x8b,0x35,A,A,A,A]
673 // CHECK
: fixup
A - offset
: 4, value
: _foo@GOTPCREL-
4, kind
: reloc_riprel_4byte_movq_load
674 movq _foo@GOTPCREL
(%eip
), %r14
676 // CHECK
: movq
(%r13,%rax
,8), %r13
677 // CHECK
: encoding
: [0x4d,0x8b,0x6c,0xc5,0x00]
678 movq
0x00(%r13,%rax
,8),%r13
680 // CHECK
: testq
%rax
, %rbx
681 // CHECK
: encoding
: [0x48,0x85,0xc3]
684 // CHECK
: cmpq
%rbx
, %r14
685 // CHECK
: encoding
: [0x49,0x39,0xde]
692 // CHECK
: encoding
: [0x48,0xa5]
696 // CHECK
: encoding
: [0xa5]
700 // CHECK
: encoding
: [0x48,0xab]
703 // CHECK
: encoding
: [0xab]
706 // Not moffset forms of moves
, they are x86-
32 only
! rdar
://7947184
707 movb
0, %al
// CHECK
: movb
0, %al
# encoding: [0x8a,0x04,0x25,0x00,0x00,0x00,0x00]
708 movw
0, %ax
// CHECK
: movw
0, %ax
# encoding: [0x66,0x8b,0x04,0x25,0x00,0x00,0x00,0x00]
709 movl
0, %eax
// CHECK
: movl
0, %eax
# encoding: [0x8b,0x04,0x25,0x00,0x00,0x00,0x00]
711 // CHECK
: pushfq
# encoding: [0x9c]
713 // CHECK
: pushfq
# encoding: [0x9c]
715 // CHECK
: popfq
# encoding: [0x9d]
717 // CHECK
: popfq
# encoding: [0x9d]
720 // CHECK
: movabsq $
-281474976710654, %rax
721 // CHECK
: encoding
: [0x48,0xb8,0x02,0x00,0x00,0x00,0x00,0x00,0xff,0xff]
722 movabsq $
0xFFFF000000000002, %rax
724 // CHECK
: movabsq $
-281474976710654, %rax
725 // CHECK
: encoding
: [0x48,0xb8,0x02,0x00,0x00,0x00,0x00,0x00,0xff,0xff]
726 movq $
0xFFFF000000000002, %rax
728 // CHECK
: movq $
-65536, %rax
729 // CHECK
: encoding
: [0x48,0xc7,0xc0,0x00,0x00,0xff,0xff]
730 movq $
0xFFFFFFFFFFFF0000, %rax
732 // CHECK
: movq $
-256, %rax
733 // CHECK
: encoding
: [0x48,0xc7,0xc0,0x00,0xff,0xff,0xff]
734 movq $
0xFFFFFFFFFFFFFF00, %rax
736 // CHECK
: movq $
10, %rax
737 // CHECK
: encoding
: [0x48,0xc7,0xc0,0x0a,0x00,0x00,0x00]
740 // CHECK
: movabsb
-6066930261531658096, %al
741 // CHECK
: encoding
: [0xa0,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
742 movabsb
0xabcdef1234567890,%al
744 // CHECK
: movabsw
-6066930261531658096, %ax
745 // CHECK
: encoding
: [0x66,0xa1,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
746 movabsw
0xabcdef1234567890,%ax
748 // CHECK
: movabsl
-6066930261531658096, %eax
749 // CHECK
: encoding
: [0xa1,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
750 movabsl
0xabcdef1234567890,%eax
752 // CHECK
: movabsq
-6066930261531658096, %rax
753 // CHECK
: encoding
: [0x48,0xa1,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
754 movabsq
0xabcdef1234567890, %rax
756 // CHECK
: movabsb
%al
, -6066930261531658096
757 // CHECK
: encoding
: [0xa2,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
758 movabsb
%al
,0xabcdef1234567890
760 // CHECK
: movabsw
%ax
, -6066930261531658096
761 // CHECK
: encoding
: [0x66,0xa3,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
762 movabsw
%ax
,0xabcdef1234567890
764 // CHECK
: movabsl
%eax
, -6066930261531658096
765 // CHECK
: encoding
: [0xa3,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
766 movabsl
%eax
,0xabcdef1234567890
768 // CHECK
: movabsq
%rax
, -6066930261531658096
769 // CHECK
: encoding
: [0x48,0xa3,0x90,0x78,0x56,0x34,0x12,0xef,0xcd,0xab]
770 movabsq
%rax
,0xabcdef1234567890
775 // CHECK
: encoding
: [0xc3]
779 // CHECK
: encoding
: [0x0f,0x94,0xc0]
783 // CHECK
: encoding
: [0x0f,0x95,0xc0]
787 // CHECK
: encoding
: [0x74,A]
791 // CHECK
: encoding
: [0x75,A]
795 btl $
1, 0 // CHECK
: btl $
1, 0 # encoding: [0x0f,0xba,0x24,0x25,0x00,0x00,0x00,0x00,0x01]
796 bt $
1, 0 // CHECK
: btl $
1, 0 # encoding: [0x0f,0xba,0x24,0x25,0x00,0x00,0x00,0x00,0x01]
800 // CHECK
: btq $
1, %rdx
801 // CHECK
: encoding
: [0x48,0x0f,0xba,0xe2,0x01]
804 // CHECK
: movzbl
%al
, %esi
805 // CHECK
: encoding
: [0x0f,0xb6,0xf0]
808 // CHECK
: movzbq
%al
, %rsi
809 // CHECK
: encoding
: [0x48,0x0f,0xb6,0xf0]
812 // CHECK
: movsbw
%al
, %ax
813 // CHECK
: encoding
: [0x66,0x0f,0xbe,0xc0]
816 // CHECK
: movsbl
%al
, %eax
817 // CHECK
: encoding
: [0x0f,0xbe,0xc0]
820 // CHECK
: movswl
%ax
, %eax
821 // CHECK
: encoding
: [0x0f,0xbf,0xc0]
824 // CHECK
: movsbq
%bl, %rax
825 // CHECK
: encoding
: [0x48,0x0f,0xbe,0xc3]
828 // CHECK
: movswq
%cx
, %rax
829 // CHECK
: encoding
: [0x48,0x0f,0xbf,0xc1]
832 // CHECK
: movslq
%edi
, %rax
833 // CHECK
: encoding
: [0x48,0x63,0xc7]
836 // CHECK
: movzbw
%al
, %ax
837 // CHECK
: encoding
: [0x66,0x0f,0xb6,0xc0]
840 // CHECK
: movzbl
%al
, %eax
841 // CHECK
: encoding
: [0x0f,0xb6,0xc0]
844 // CHECK
: movzwl
%ax
, %eax
845 // CHECK
: encoding
: [0x0f,0xb7,0xc0]
848 // CHECK
: movzbq
%bl, %rax
849 // CHECK
: encoding
: [0x48,0x0f,0xb6,0xc3]
852 // CHECK
: movzwq
%cx
, %rax
853 // CHECK
: encoding
: [0x48,0x0f,0xb7,0xc1]
856 // CHECK
: movsbw
(%rax
), %ax
857 // CHECK
: encoding
: [0x66,0x0f,0xbe,0x00]
860 // CHECK
: movzbw
(%rax
), %ax
861 // CHECK
: encoding
: [0x66,0x0f,0xb6,0x00]
866 // CHECK
: [0x65,0x8b,0x04,0x25,0x7c,0x00,0x00,0x00]
869 // CHECK
: jmpq
*8(%rax
)
870 // CHECK
: encoding
: [0xff,0x60,0x08]
873 // CHECK
: btq $
61, -216(%rbp
)
874 // CHECK
: encoding
: [0x48,0x0f,0xba,0xa5,0x28,0xff,0xff,0xff,0x3d]
882 // CHECK
: encoding
: [0x67,0xe3,A]
885 // CHECK
: encoding
: [0xe3,A]
889 // CHECK
: xchgl
%ecx
, 368(%rax
)
890 xchgl
%ecx
, 368(%rax
)
891 // CHECK
: xchgl
%ecx
, 368(%rax
)
894 xchg
0xdeadbeef(%rbx
,%rcx
,8),%bl
895 // CHECK
: xchgb
%bl, 3735928559(%rbx
,%rcx
,8)
902 // CHECK
: incl
1(%rsp
)
907 // CHECK
: incl
1(%rsp
)
910 lock addq
%rsi
, (%rdi
)
912 // CHECK
: addq
%rsi
, (%rdi
)
913 // CHECK
: encoding
: [0xf0,0x48,0x01,0x37]
915 lock subq
%rsi
, (%rdi
)
917 // CHECK
: subq
%rsi
, (%rdi
)
918 // CHECK
: encoding
: [0xf0,0x48,0x29,0x37]
920 lock andq
%rsi
, (%rdi
)
922 // CHECK
: andq
%rsi
, (%rdi
)
923 // CHECK
: encoding
: [0xf0,0x48,0x21,0x37]
925 lock orq
%rsi
, (%rdi
)
927 // CHECK
: orq
%rsi
, (%rdi
)
928 // CHECK
: encoding
: [0xf0,0x48,0x09,0x37]
930 lock xorq
%rsi
, (%rdi
)
932 // CHECK
: xorq
%rsi
, (%rdi
)
933 // CHECK
: encoding
: [0xf0,0x48,0x31,0x37]
935 xacquire lock addq
%rax
, (%rax
)
937 // CHECK
: encoding
: [0xf2]
939 // CHECK
: addq
%rax
, (%rax
)
940 // CHECK
: encoding
: [0xf0,0x48,0x01,0x00]
942 xrelease lock addq
%rax
, (%rax
)
944 // CHECK
: encoding
: [0xf3]
946 // CHECK
: addq
%rax
, (%rax
)
947 // CHECK
: encoding
: [0xf0,0x48,0x01,0x00]
953 // CHECK
: encoding
: [0xf3,0xa5]
959 // CHECK
: encoding
: [0xcf]
962 // CHECK
: encoding
: [0x66,0xcf]
965 // CHECK
: encoding
: [0xcf]
968 // CHECK
: encoding
: [0x48,0xcf]
971 // CHECK
: retw $
31438
972 // CHECK
: encoding
: [0x66,0xc2,0xce,0x7a]
975 // CHECK
: lretw $
31438
976 // CHECK
: encoding
: [0x66,0xca,0xce,0x7a]
980 lretq
// CHECK
: lretq
# encoding: [0x48,0xcb]
981 lretl
// CHECK
: lretl
# encoding: [0xcb]
982 lret
// CHECK
: lretl
# encoding: [0xcb]
983 lretw
// CHECK
: lretw
# encoding: [0x66,0xcb]
988 // CHECK
: encoding
: [0x0f,0x07]
991 // CHECK
: encoding
: [0x0f,0x07]
994 // CHECK
: encoding
: [0x48,0x0f,0x07]
999 // CHECK
: encoding
: [0x0f,0xa0]
1002 // CHECK
: encoding
: [0x0f,0xa8]
1006 // CHECK
: encoding
: [0x66,0x0f,0xa0]
1009 // CHECK
: encoding
: [0x66,0x0f,0xa8]
1014 // CHECK
: encoding
: [0x0f,0xa1]
1017 // CHECK
: encoding
: [0x0f,0xa9]
1021 // CHECK
: encoding
: [0x66,0x0f,0xa1]
1024 // CHECK
: encoding
: [0x66,0x0f,0xa9]
1029 // CHECK
: fildll
-8(%rsp
)
1030 // CHECK
: encoding
: [0xdf,0x6c,0x24,0xf8]
1031 // CHECK
: fildll
-8(%rsp
)
1032 // CHECK
: encoding
: [0xdf,0x6c,0x24,0xf8]
1037 // CHECK
: leaq
-40(%rbp
), %r15
1038 leaq
-40(%rbp
), %r15
1042 // rdar
://8013734 - Alias dr6
=db6
1045 // CHECK
: movq
%dr6
, %rax
1046 // CHECK
: movq
%dr6
, %rax
1049 // INC
/DEC encodings.
1050 incb
%al
// CHECK
: incb
%al
# encoding: [0xfe,0xc0]
1051 incw
%ax
// CHECK
: incw
%ax
# encoding: [0x66,0xff,0xc0]
1052 incl
%eax
// CHECK
: incl
%eax
# encoding: [0xff,0xc0]
1053 decb
%al
// CHECK
: decb
%al
# encoding: [0xfe,0xc8]
1054 decw
%ax
// CHECK
: decw
%ax
# encoding: [0x66,0xff,0xc8]
1055 decl
%eax
// CHECK
: decl
%eax
# encoding: [0xff,0xc8]
1058 // CHECK
: lgdtq
4(%rax
)
1059 // CHECK
: encoding
: [0x0f,0x01,0x50,0x04]
1062 // CHECK
: lgdtq
4(%rax
)
1063 // CHECK
: encoding
: [0x0f,0x01,0x50,0x04]
1066 // CHECK
: lidtq
4(%rax
)
1067 // CHECK
: encoding
: [0x0f,0x01,0x58,0x04]
1070 // CHECK
: lidtq
4(%rax
)
1071 // CHECK
: encoding
: [0x0f,0x01,0x58,0x04]
1074 // CHECK
: sgdtq
4(%rax
)
1075 // CHECK
: encoding
: [0x0f,0x01,0x40,0x04]
1078 // CHECK
: sgdtq
4(%rax
)
1079 // CHECK
: encoding
: [0x0f,0x01,0x40,0x04]
1082 // CHECK
: sidtq
4(%rax
)
1083 // CHECK
: encoding
: [0x0f,0x01,0x48,0x04]
1086 // CHECK
: sidtq
4(%rax
)
1087 // CHECK
: encoding
: [0x0f,0x01,0x48,0x04]
1092 mov
(%rsi
), %gs
// CHECK
: movw
(%rsi
), %gs
# encoding: [0x8e,0x2e]
1093 mov
%gs
, (%rsi
) // CHECK
: movw
%gs
, (%rsi
) # encoding: [0x8c,0x2e]
1100 //CHECK
: divl
3735928559(%ebx
,%ecx
,8)
1103 //CHECK
: divl
3133065982
1104 //CHECK
: divl
305419896
1108 //CHECK
: idivl
3735928559(%ebx
,%ecx
,8)
1110 //CHECK
: idivl
32493
1111 //CHECK
: idivl
3133065982
1112 //CHECK
: idivl
305419896
1116 div 0xdeadbeef(%ebx
,%ecx
,8),%eax
1124 idiv
0xdeadbeef(%ebx
,%ecx
,8),%eax
1127 idiv
0xbabecafe,%eax
1128 idiv
0x12345678,%eax
1131 movd
%rax
, %mm5
// CHECK
: movq
%rax
, %mm5
# encoding: [0x48,0x0f,0x6e,0xe8]
1132 movd
%mm5
, %rbx
// CHECK
: movq
%mm5
, %rbx
# encoding: [0x48,0x0f,0x7e,0xeb]
1133 movq
%rax
, %mm5
// CHECK
: movq
%rax
, %mm5
# encoding: [0x48,0x0f,0x6e,0xe8]
1134 movq
%mm5
, %rbx
// CHECK
: movq
%mm5
, %rbx
# encoding: [0x48,0x0f,0x7e,0xeb]
1136 rex64
// CHECK
: rex64
# encoding: [0x48]
1137 data16
// CHECK
: data16
# encoding: [0x66]
1140 // CHECK
: encoding
: [0x66]
1141 // CHECK
: lgdtq
4(%rax
)
1142 // CHECK
: encoding
: [0x0f,0x01,0x50,0x04]
1146 movq
18446744073709551615,%rbx
// CHECK
: movq
-1, %rbx
1149 movdqu
%xmm0
, %xmm1
// CHECK
: movdqu
%xmm0
, %xmm1
# encoding: [0xf3,0x0f,0x6f,0xc8]
1152 xgetbv
// CHECK
: xgetbv
# encoding: [0x0f,0x01,0xd0]
1153 xsetbv
// CHECK
: xsetbv
# encoding: [0x0f,0x01,0xd1]
1156 // CHECK
: encoding
: [0xe1,A]
1160 // CHECK
: encoding
: [0xe0,A]
1163 // CHECK
: outsb
(%rsi
), %dx
# encoding: [0x6e]
1167 outsb
%ds
:(%rsi
), %dx
1170 // CHECK
: outsw
(%rsi
), %dx
# encoding: [0x66,0x6f]
1174 outsw
%ds
:(%rsi
), %dx
1177 // CHECK
: outsl
(%rsi
), %dx
# encoding: [0x6f]
1180 outsl
%ds
:(%rsi
), %dx
1183 // CHECK
: insb
%dx
, %es
:(%rdi
) # encoding: [0x6c]
1186 insb
%dx
, %es
:(%rdi
)
1188 // CHECK
: insw
%dx
, %es
:(%rdi
) # encoding: [0x66,0x6d]
1191 insw
%dx
, %es
:(%rdi
)
1193 // CHECK
: insl
%dx
, %es
:(%rdi
) # encoding: [0x6d]
1196 insl
%dx
, %es
:(%rdi
)
1198 // CHECK
: movsb
(%rsi
), %es
:(%rdi
) # encoding: [0xa4]
1202 movsb
%ds
:(%rsi
), %es
:(%rdi
)
1203 movsb
(%rsi
), %es
:(%rdi
)
1205 // CHECK
: movsw
(%rsi
), %es
:(%rdi
) # encoding: [0x66,0xa5]
1209 movsw
%ds
:(%rsi
), %es
:(%rdi
)
1210 movsw
(%rsi
), %es
:(%rdi
)
1212 // CHECK
: movsl
(%rsi
), %es
:(%rdi
) # encoding: [0xa5]
1216 movsl
%ds
:(%rsi
), %es
:(%rdi
)
1217 movsl
(%rsi
), %es
:(%rdi
)
1220 movsl
(%rsi
), (%rdi
)
1222 // CHECK
: movsq
(%rsi
), %es
:(%rdi
) # encoding: [0x48,0xa5]
1226 movsq
%ds
:(%rsi
), %es
:(%rdi
)
1227 movsq
(%rsi
), %es
:(%rdi
)
1229 // CHECK
: lodsb
(%rsi
), %al
# encoding: [0xac]
1235 lodsb
%ds
:(%rsi
), %al
1237 lods
%ds
:(%rsi
), %al
1240 // CHECK
: lodsw
(%rsi
), %ax
# encoding: [0x66,0xad]
1246 lodsw
%ds
:(%rsi
), %ax
1248 lods
%ds
:(%rsi
), %ax
1251 // CHECK
: lodsl
(%rsi
), %eax
# encoding: [0xad]
1257 lodsl
%ds
:(%rsi
), %eax
1259 lods
%ds
:(%rsi
), %eax
1262 // CHECK
: lodsq
(%rsi
), %rax
# encoding: [0x48,0xad]
1268 lodsq
%ds
:(%rsi
), %rax
1270 lods
%ds
:(%rsi
), %rax
1273 // CHECK
: stosb
%al
, %es
:(%rdi
) # encoding: [0xaa]
1277 stosb
%al
, %es
:(%rdi
)
1278 stos
%al
, %es
:(%rdi
)
1280 // CHECK
: stosw
%ax
, %es
:(%rdi
) # encoding: [0x66,0xab]
1284 stosw
%ax
, %es
:(%rdi
)
1285 stos
%ax
, %es
:(%rdi
)
1287 // CHECK
: stosl
%eax
, %es
:(%rdi
) # encoding: [0xab]
1291 stosl
%eax
, %es
:(%rdi
)
1292 stos
%eax
, %es
:(%rdi
)
1294 // CHECK
: stosq
%rax
, %es
:(%rdi
) # encoding: [0x48,0xab]
1298 stosq
%rax
, %es
:(%rdi
)
1299 stos
%rax
, %es
:(%rdi
)
1302 // CHECK
: encoding
: [0x66,0x0f,0x00,0xc8]
1306 // CHECK
: encoding
: [0x0f,0x00,0xc8]
1310 // CHECK
: encoding
: [0x66,0x0f,0x00,0xc8]
1314 // CHECK
: encoding
: [0x48,0x0f,0x00,0xc8]
1317 // CHECK
: movq
%rdi
, %xmm0
1318 // CHECK
: encoding
: [0x66,0x48,0x0f,0x6e,0xc7]
1321 // CHECK
: movq
%xmm0
, %rax
1322 // CHECK
: encoding
: [0x66,0x48,0x0f,0x7e,0xc0]
1325 // CHECK
: movntil
%eax
, (%rdi
)
1326 // CHECK
: encoding
: [0x0f,0xc3,0x07]
1328 movntil
%eax
, (%rdi
)
1331 // CHECK
: movntiq
%rax
, (%rdi
)
1332 // CHECK
: encoding
: [0x48,0x0f,0xc3,0x07]
1334 movntiq
%rax
, (%rdi
)
1337 // CHECK
: pclmulqdq $
17, %xmm0
, %xmm1
1338 // CHECK
: encoding
: [0x66,0x0f,0x3a,0x44,0xc8,0x11]
1339 pclmulhqhqdq
%xmm0
, %xmm1
1341 // CHECK
: pclmulqdq $
1, %xmm0
, %xmm1
1342 // CHECK
: encoding
: [0x66,0x0f,0x3a,0x44,0xc8,0x01]
1343 pclmulqdq $
1, %xmm0
, %xmm1
1345 // CHECK
: pclmulqdq $
16, (%rdi
), %xmm1
1346 // CHECK
: encoding
: [0x66,0x0f,0x3a,0x44,0x0f,0x10]
1347 pclmullqhqdq
(%rdi
), %xmm1
1349 // CHECK
: pclmulqdq $
0, (%rdi
), %xmm1
1350 // CHECK
: encoding
: [0x66,0x0f,0x3a,0x44,0x0f,0x00]
1351 pclmulqdq $
0, (%rdi
), %xmm1
1355 // CHECK
: encoding
: [0x90]
1358 // CHECK
: xchgl
%eax
, %eax
1359 // CHECK
: encoding
: [0x87,0xc0]
1362 // CHECK
: xchgw
%ax
, %ax
1363 // CHECK
: encoding
: [0x66,0x90]
1366 // CHECK
: xchgl
%ecx
, %eax
1367 // CHECK
: encoding
: [0x91]
1370 // CHECK
: xchgl
%ecx
, %eax
1371 // CHECK
: encoding
: [0x91]
1375 // CHECK
: encoding
: [0x0f,0x35]
1379 // CHECK
: encoding
: [0x0f,0x35]
1383 // CHECK
: encoding
: [0x48,0x0f,0x35]
1387 // CHECK
: encoding
: [0x0f,0x01,0xca]
1391 // CHECK
: encoding
: [0x0f,0x01,0xcb]
1394 // CHECK
: faddp
%st, %st(1)
1395 // CHECK
: fmulp
%st, %st(1)
1396 // CHECK
: fsubp
%st, %st(1)
1397 // CHECK
: fsubrp
%st, %st(1)
1398 // CHECK
: fdivp
%st, %st(1)
1399 // CHECK
: fdivrp
%st, %st(1)
1407 // CHECK
: faddp
%st, %st(1)
1408 // CHECK
: fmulp
%st, %st(1)
1409 // CHECK
: fsubp
%st, %st(1)
1410 // CHECK
: fsubrp
%st, %st(1)
1411 // CHECK
: fdivp
%st, %st(1)
1412 // CHECK
: fdivrp
%st, %st(1)
1420 // CHECK
: faddp
%st, %st(1)
1421 // CHECK
: fmulp
%st, %st(1)
1422 // CHECK
: fsubp
%st, %st(1)
1423 // CHECK
: fsubrp
%st, %st(1)
1424 // CHECK
: fdivp
%st, %st(1)
1425 // CHECK
: fdivrp
%st, %st(1)
1433 // CHECK
: faddp
%st, %st(1)
1434 // CHECK
: fmulp
%st, %st(1)
1435 // CHECK
: fsubp
%st, %st(1)
1436 // CHECK
: fsubrp
%st, %st(1)
1437 // CHECK
: fdivp
%st, %st(1)
1438 // CHECK
: fdivrp
%st, %st(1)
1446 // CHECK
: fadd %st(1)
1447 // CHECK
: fmul %st(1)
1448 // CHECK
: fsub %st(1)
1449 // CHECK
: fsubr
%st(1)
1450 // CHECK
: fdiv %st(1)
1451 // CHECK
: fdivr
%st(1)
1459 // CHECK
: fadd %st, %st(1)
1460 // CHECK
: fmul %st, %st(1)
1461 // CHECK
: fsub %st, %st(1)
1462 // CHECK
: fsubr
%st, %st(1)
1463 // CHECK
: fdiv %st, %st(1)
1464 // CHECK
: fdivr
%st, %st(1)
1472 // CHECK
: fadd %st(1)
1473 // CHECK
: fmul %st(1)
1474 // CHECK
: fsub %st(1)
1475 // CHECK
: fsubr
%st(1)
1476 // CHECK
: fdiv %st(1)
1477 // CHECK
: fdivr
%st(1)
1485 // CHECK
: movd
%xmm0
, %eax
1486 // CHECK
: movq
%xmm0
, %rax
1487 // CHECK
: movq
%xmm0
, %rax
1488 // CHECK
: vmovd
%xmm0
, %eax
1489 // CHECK
: vmovq
%xmm0
, %rax
1490 // CHECK
: vmovq
%xmm0
, %rax
1498 // CHECK
: seto
3735928559(%r10,%r9,8)
1499 // CHECK
: encoding
: [0x43,0x0f,0x90,0x84,0xca,0xef,0xbe,0xad,0xde]
1500 seto
0xdeadbeef(%r10,%r9,8)
1503 // CHECK
: encoding
: [0x0f,0x01,0xfa]
1507 // CHECK
: encoding
: [0x0f,0x01,0xfa]
1508 monitorx
%rax
, %rcx
, %rdx
1511 // CHECK
: encoding
: [0x0f,0x01,0xfb]
1515 // CHECK
: encoding
: [0x0f,0x01,0xfb]
1516 mwaitx
%rax
, %rcx
, %rbx
1519 // CHECK
: encoding
: [0x0f,0x01,0xfc]
1523 // CHECK
: encoding
: [0x0f,0x01,0xfc]
1526 // CHECK
: movl
%r15d
, (%r15,%r15)
1527 // CHECK
: encoding
: [0x47,0x89,0x3c,0x3f]
1528 movl
%r15d
, (%r15,%r15)
1530 // CHECK
: nopq
3735928559(%rbx
,%rcx
,8)
1531 // CHECK
: encoding
: [0x48,0x0f,0x1f,0x84,0xcb,0xef,0xbe,0xad,0xde]
1532 nopq
0xdeadbeef(%rbx
,%rcx
,8)
1535 // CHECK
: encoding
: [0x48,0x0f,0x1f,0xc0]
1538 // CHECK
: rdpid
%rax
1539 // CHECK
: encoding
: [0xf3,0x0f,0xc7,0xf8]
1542 // CHECK
: ptwritel
3735928559(%rbx
,%rcx
,8)
1543 // CHECK
: encoding
: [0xf3,0x0f,0xae,0xa4,0xcb,0xef,0xbe,0xad,0xde]
1544 ptwritel
0xdeadbeef(%rbx
,%rcx
,8)
1546 // CHECK
: ptwritel
%eax
1547 // CHECK
: encoding
: [0xf3,0x0f,0xae,0xe0]
1550 // CHECK
: ptwriteq
3735928559(%rbx
,%rcx
,8)
1551 // CHECK
: encoding
: [0xf3,0x48,0x0f,0xae,0xa4,0xcb,0xef,0xbe,0xad,0xde]
1552 ptwriteq
0xdeadbeef(%rbx
,%rcx
,8)
1554 // CHECK
: ptwriteq
%rax
1555 // CHECK
: encoding
: [0xf3,0x48,0x0f,0xae,0xe0]
1559 // CHECK
: encoding
: [0xf3,0x0f,0x09]
1562 // CHECK
: cldemote
4(%rax
)
1563 // CHECK
: encoding
: [0x0f,0x1c,0x40,0x04]
1566 // CHECK
: cldemote
3735928559(%rbx
,%rcx
,8)
1567 // CHECK
: encoding
: [0x0f,0x1c,0x84,0xcb,0xef,0xbe,0xad,0xde]
1568 cldemote
0xdeadbeef(%rbx
,%rcx
,8)
1570 // CHECK
: umonitor
%r13
1571 // CHECK
: encoding
: [0xf3,0x41,0x0f,0xae,0xf5]
1574 // CHECK
: umonitor
%rax
1575 // CHECK
: encoding
: [0xf3,0x0f,0xae,0xf0]
1578 // CHECK
: umonitor
%eax
1579 // CHECK
: encoding
: [0x67,0xf3,0x0f,0xae,0xf0]
1582 // CHECK
: umwait
%r15
1583 // CHECK
: encoding
: [0xf2,0x41,0x0f,0xae,0xf7]
1586 // CHECK
: umwait
%ebx
1587 // CHECK
: encoding
: [0xf2,0x0f,0xae,0xf3]
1590 // CHECK
: tpause
%r15
1591 // CHECK
: encoding
: [0x66,0x41,0x0f,0xae,0xf7]
1594 // CHECK
: tpause
%ebx
1595 // CHECK
: encoding
: [0x66,0x0f,0xae,0xf3]
1598 // CHECK
: movdiri
%r15, 485498096
1599 // CHECK
: # encoding: [0x4c,0x0f,0x38,0xf9,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
1600 movdiri
%r15, 485498096
1602 // CHECK
: movdiri
%r15, (%rdx
)
1603 // CHECK
: # encoding: [0x4c,0x0f,0x38,0xf9,0x3a]
1604 movdiri
%r15, (%rdx
)
1606 // CHECK
: movdiri
%r15, 64(%rdx
)
1607 // CHECK
: # encoding: [0x4c,0x0f,0x38,0xf9,0x7a,0x40]
1608 movdiri
%r15, 64(%rdx
)
1610 // CHECK
: movdir64b
485498096, %rax
1611 // CHECK
: # encoding: [0x66,0x0f,0x38,0xf8,0x04,0x25,0xf0,0x1c,0xf0,0x1c]
1612 movdir64b
485498096, %rax
1614 // CHECK
: movdir64b
485498096, %eax
1615 // CHECK
: # encoding: [0x67,0x66,0x0f,0x38,0xf8,0x04,0x25,0xf0,0x1c,0xf0,0x1c]
1616 movdir64b
485498096, %eax
1618 // CHECK
: movdir64b
(%rdx
), %r15
1619 // CHECK
: # encoding: [0x66,0x44,0x0f,0x38,0xf8,0x3a]
1620 movdir64b
(%rdx
), %r15
1623 // CHECK
: # encoding: [0x0f,0x01,0xc5]
1627 // CHECK
: encoding
: [0x0f,0x01,0xcf]
1631 // CHECK
: encoding
: [0x0f,0x01,0xd7]
1635 // CHECK
: encoding
: [0x0f,0x01,0xc0]
1638 // CHECK
: movq
%rax
, %rbx
1639 // CHECK
: encoding
: [0x48,0x8b,0xd8]
1642 // CHECK
: movq
%rax
, %rbx
1643 // CHECK
: encoding
: [0x48,0x8b,0xd8]
1646 // CHECK
: movl
%eax
, %ebx
1647 // CHECK
: encoding
: [0x8b,0xd8]
1650 // CHECK
: movl
%eax
, %ebx
1651 // CHECK
: encoding
: [0x8b,0xd8]
1654 // CHECK
: movw
%ax
, %bx
1655 // CHECK
: encoding
: [0x66,0x8b,0xd8]
1658 // CHECK
: movw
%ax
, %bx
1659 // CHECK
: encoding
: [0x66,0x8b,0xd8]
1662 // CHECK
: movb
%al
, %bl
1663 // CHECK
: encoding
: [0x8a,0xd8]
1666 // CHECK
: movb
%al
, %bl
1667 // CHECK
: encoding
: [0x8a,0xd8]
1670 // CHECK
: movq
%mm0
, %mm1
1671 // CHECK
: encoding
: [0x0f,0x7f,0xc1]
1674 // CHECK
: movq
%xmm0
, %xmm1
1675 // CHECK
: encoding
: [0x66,0x0f,0xd6,0xc1]
1678 // CHECK
: movdqa
%xmm0
, %xmm1
1679 // CHECK
: encoding
: [0x66,0x0f,0x7f,0xc1]
1680 movdqa.s
%xmm0
, %xmm1
1682 // CHECK
: movdqu
%xmm0
, %xmm1
1683 // CHECK
: encoding
: [0xf3,0x0f,0x7f,0xc1]
1684 movdqu.s
%xmm0
, %xmm1
1686 // CHECK
: movaps
%xmm0
, %xmm1
1687 // CHECK
: encoding
: [0x0f,0x29,0xc1]
1688 movaps.s
%xmm0
, %xmm1
1690 // CHECK
: movups
%xmm0
, %xmm1
1691 // CHECK
: encoding
: [0x0f,0x11,0xc1]
1692 movups.s
%xmm0
, %xmm1
1694 // CHECK
: movapd
%xmm0
, %xmm1
1695 // CHECK
: encoding
: [0x66,0x0f,0x29,0xc1]
1696 movapd.s
%xmm0
, %xmm1
1698 // CHECK
: movupd
%xmm0
, %xmm1
1699 // CHECK
: encoding
: [0x66,0x0f,0x11,0xc1]
1700 movupd.s
%xmm0
, %xmm1
1702 // CHECK
: vmovq
%xmm0
, %xmm8
1703 // CHECK
: encoding
: [0xc4,0xc1,0x79,0xd6,0xc0]
1704 vmovq.s
%xmm0
, %xmm8
1706 // CHECK
: vmovq
%xmm8
, %xmm0
1707 // CHECK
: encoding
: [0xc5,0x79,0xd6,0xc0]
1708 vmovq.s
%xmm8
, %xmm0
1710 // CHECK
: vmovdqa
%xmm0
, %xmm8
1711 // CHECK
: encoding
: [0xc4,0xc1,0x79,0x7f,0xc0]
1712 vmovdqa.s
%xmm0
, %xmm8
1714 // CHECK
: vmovdqa
%xmm8
, %xmm0
1715 // CHECK
: encoding
: [0xc5,0x79,0x7f,0xc0]
1716 vmovdqa.s
%xmm8
, %xmm0
1718 // CHECK
: vmovdqu
%xmm0
, %xmm8
1719 // CHECK
: encoding
: [0xc4,0xc1,0x7a,0x7f,0xc0]
1720 vmovdqu.s
%xmm0
, %xmm8
1722 // CHECK
: vmovdqu
%xmm8
, %xmm0
1723 // CHECK
: encoding
: [0xc5,0x7a,0x7f,0xc0]
1724 vmovdqu.s
%xmm8
, %xmm0
1726 // CHECK
: vmovaps
%xmm0
, %xmm8
1727 // CHECK
: encoding
: [0xc4,0xc1,0x78,0x29,0xc0]
1728 vmovaps.s
%xmm0
, %xmm8
1730 // CHECK
: vmovaps
%xmm8
, %xmm0
1731 // CHECK
: encoding
: [0xc5,0x78,0x29,0xc0]
1732 vmovaps.s
%xmm8
, %xmm0
1734 // CHECK
: vmovups
%xmm0
, %xmm8
1735 // CHECK
: encoding
: [0xc4,0xc1,0x78,0x11,0xc0]
1736 vmovups.s
%xmm0
, %xmm8
1738 // CHECK
: vmovups
%xmm8
, %xmm0
1739 // CHECK
: encoding
: [0xc5,0x78,0x11,0xc0]
1740 vmovups.s
%xmm8
, %xmm0
1742 // CHECK
: vmovapd
%xmm0
, %xmm8
1743 // CHECK
: encoding
: [0xc4,0xc1,0x79,0x29,0xc0]
1744 vmovapd.s
%xmm0
, %xmm8
1746 // CHECK
: vmovapd
%xmm8
, %xmm0
1747 // CHECK
: encoding
: [0xc5,0x79,0x29,0xc0]
1748 vmovapd.s
%xmm8
, %xmm0
1750 // CHECK
: vmovupd
%xmm0
, %xmm8
1751 // CHECK
: encoding
: [0xc4,0xc1,0x79,0x11,0xc0]
1752 vmovupd.s
%xmm0
, %xmm8
1754 // CHECK
: vmovupd
%xmm8
, %xmm0
1755 // CHECK
: encoding
: [0xc5,0x79,0x11,0xc0]
1756 vmovupd.s
%xmm8
, %xmm0
1758 // __asm __volatile
(
1762 // ".byte 0x0f, 0xa7, 0xd0"
1765 // CHECK-NEXT
: popfq
1767 // CHECK-NEXT
: .byte 15
1768 // CHECK-NEXT
: .byte 167
1769 // CHECK-NEXT
: .byte 208
1782 1: cmpxchgl
%ecx
,(%rdi
)
1790 // This line has to
be the last one in the file