llvm-for-llvmta/tools/clang/test/CodeGen/X86/att-inline-asm-prefix.c

28 lines
922 B
C

// REQUIRES: x86-registered-target
// RUN:%clang_cc1 %s -ferror-limit 0 -triple=x86_64-pc -target-feature +avx512f -target-feature +avx2 -target-feature +avx512vl -S -o - | FileCheck %s -check-prefix CHECK
// This test is to check if the prefix in inline assembly is correctly
// preserved.
void check_inline_prefix(void) {
__asm__ (
// CHECK: vcvtps2pd %xmm0, %xmm1
// CHECK: {vex} vcvtps2pd %xmm0, %xmm1
// CHECK: {vex2} vcvtps2pd %xmm0, %xmm1
// CHECK: {vex3} vcvtps2pd %xmm0, %xmm1
// CHECK: {evex} vcvtps2pd %xmm0, %xmm1
// CHECK: movl $1, (%rax)
// CHECK: {disp8} movl $1, (%rax)
// CHECK: {disp32} movl $1, (%rax)
"vcvtps2pd %xmm0, %xmm1\n\t"
"{vex} vcvtps2pd %xmm0, %xmm1\n\t"
"{vex2} vcvtps2pd %xmm0, %xmm1\n\t"
"{vex3} vcvtps2pd %xmm0, %xmm1\n\t"
"{evex} vcvtps2pd %xmm0, %xmm1\n\t"
"movl $1, (%rax)\n\t"
"{disp8} movl $1, (%rax)\n\t"
"{disp32} movl $1, (%rax)\n\t"
);
}