| // 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" |
| ); |
| } |