mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 22:56:05 +00:00

Set this on any source level floating-point type argument, return value, call return or outgoing parameter which is lowered to a valid IR type for the attribute. Currently this isn't applied to emitted intrinsics since those don't go through ABI code.
59 lines
2.5 KiB
C++
59 lines
2.5 KiB
C++
// RUN: %clang_cc1 -triple x86_64-linux-gnu -ffast-math -ffp-contract=fast -emit-llvm -o - %s | FileCheck %s
|
|
// RUN: %clang_cc1 -triple x86_64-linux-gnu -ffast-math -ffp-contract=fast-honor-pragmas -emit-llvm -o - %s | FileCheck %s
|
|
|
|
float test_default(float a, float b, float c) {
|
|
float tmp = a;
|
|
tmp += b;
|
|
tmp += c;
|
|
return tmp;
|
|
}
|
|
|
|
// CHECK: define{{.*}} float @_Z12test_defaultfff(float noundef nofpclass(nan inf) %a, float noundef nofpclass(nan inf) %b, float noundef nofpclass(nan inf) %c) [[FAST_ATTRS:#[0-9]+]]
|
|
// CHECK: fadd fast float {{%.+}}, {{%.+}}
|
|
// CHECK: fadd fast float {{%.+}}, {{%.+}}
|
|
|
|
float test_precise_on_pragma(float a, float b, float c) {
|
|
float tmp = a;
|
|
{
|
|
#pragma float_control(precise, on)
|
|
tmp += b;
|
|
}
|
|
tmp += c;
|
|
return tmp;
|
|
}
|
|
|
|
// CHECK: define{{.*}} float @_Z22test_precise_on_pragmafff(float noundef nofpclass(nan inf) %a, float noundef nofpclass(nan inf) %b, float noundef nofpclass(nan inf) %c) [[PRECISE_ATTRS:#[0-9]+]]
|
|
// CHECK: fadd float {{%.+}}, {{%.+}}
|
|
// CHECK: fadd fast float {{%.+}}, {{%.+}}
|
|
|
|
float test_reassociate_off_pragma(float a, float b, float c) {
|
|
float tmp = a;
|
|
{
|
|
#pragma clang fp reassociate(off)
|
|
tmp += b;
|
|
}
|
|
tmp += c;
|
|
return tmp;
|
|
}
|
|
|
|
// CHECK: define{{.*}} float @_Z27test_reassociate_off_pragmafff(float noundef nofpclass(nan inf) %a, float noundef nofpclass(nan inf) %b, float noundef nofpclass(nan inf) %c) [[NO_UNSAFE_ATTRS:#[0-9]+]]
|
|
// CHECK: fadd nnan ninf nsz arcp contract afn float {{%.+}}, {{%.+}}
|
|
// CHECK: fadd fast float {{%.+}}, {{%.+}}
|
|
|
|
float test_contract_on_pragma(float a, float b, float c) {
|
|
float tmp = a * b;
|
|
{
|
|
#pragma clang fp contract(on)
|
|
tmp += c;
|
|
}
|
|
return tmp;
|
|
}
|
|
|
|
// CHECK: define{{.*}} float @_Z23test_contract_on_pragmafff(float noundef nofpclass(nan inf) %a, float noundef nofpclass(nan inf) %b, float noundef nofpclass(nan inf) %c) [[NO_UNSAFE_ATTRS:#[0-9]+]]
|
|
// CHECK: fmul fast float {{%.+}}, {{%.+}}
|
|
// CHECK: fadd reassoc nnan ninf nsz arcp afn float {{%.+}}, {{%.+}}
|
|
|
|
// CHECK: attributes [[FAST_ATTRS]] = { {{.*}}"no-infs-fp-math"="true" {{.*}}"no-nans-fp-math"="true" "no-signed-zeros-fp-math"="true" {{.*}}"unsafe-fp-math"="true"{{.*}} }
|
|
// CHECK: attributes [[PRECISE_ATTRS]] = { {{.*}}"no-infs-fp-math"="false" {{.*}}"no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" {{.*}}"unsafe-fp-math"="false"{{.*}} }
|
|
// CHECK: attributes [[NO_UNSAFE_ATTRS]] = { {{.*}}"no-infs-fp-math"="true" {{.*}}"no-nans-fp-math"="true" "no-signed-zeros-fp-math"="true" {{.*}}"unsafe-fp-math"="false"{{.*}} }
|