blob: 789e1f98a2a15d1a7956bcf107449edbef04388b [file] [log] [blame]
// 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"
);
}