2016-02-03 19:32:08 +08:00
|
|
|
// REQUIRES: x86-registered-target
|
2017-05-05 02:19:52 +08:00
|
|
|
// RUN: %clang_cc1 %s -triple x86_64-pc-windows-msvc -target-cpu skylake-avx512 -fasm-blocks -emit-llvm -o - | FileCheck %s
|
2016-02-03 19:32:08 +08:00
|
|
|
|
|
|
|
void t1() {
|
|
|
|
// CHECK: @t1
|
|
|
|
// CHECK: call void asm sideeffect inteldialect "vaddpd zmm8, zmm27, zmm6", "~{zmm8},~{dirflag},~{fpsr},~{flags}"()
|
|
|
|
// CHECK: ret void
|
|
|
|
__asm {
|
|
|
|
vaddpd zmm8, zmm27, zmm6
|
|
|
|
}
|
|
|
|
}
|
2016-03-08 02:10:25 +08:00
|
|
|
|
|
|
|
|
|
|
|
void t2() {
|
|
|
|
// CHECK: @t2
|
|
|
|
// CHECK: call void asm sideeffect inteldialect "vaddpd zmm8 {k1}, zmm27, zmm6", "~{zmm8},~{dirflag},~{fpsr},~{flags}"()
|
|
|
|
// CHECK: ret void
|
|
|
|
__asm {
|
|
|
|
vaddpd zmm8 {k1}, zmm27, zmm6
|
|
|
|
}
|
|
|
|
}
|
2017-05-05 02:19:52 +08:00
|
|
|
|
|
|
|
void ignore_fe_size() {
|
2018-02-24 02:09:29 +08:00
|
|
|
// CHECK-LABEL: define void @ignore_fe_size()
|
2017-05-05 02:19:52 +08:00
|
|
|
char c;
|
|
|
|
// CHECK: vaddps xmm1, xmm2, $1{1to4}
|
|
|
|
__asm vaddps xmm1, xmm2, [c]{1to4}
|
|
|
|
// CHECK: vaddps xmm1, xmm2, $2
|
|
|
|
__asm vaddps xmm1, xmm2, [c]
|
|
|
|
// CHECK: mov eax, $3
|
|
|
|
__asm mov eax, [c]
|
|
|
|
// CHECK: mov $0, rax
|
|
|
|
__asm mov [c], rax
|
|
|
|
}
|