llvm-project/clang/test/CodeGen/PowerPC/builtins-ppc-xlcompat-fnabs.c
Amy Kwan c35ca3a1c7 [PowerPC] Implement XL compat __fnabs and __fnabss builtins.
This patch implements the following floating point negative absolute value
builtins that required for compatibility with the XL compiler:
```
double __fnabs(double);
float __fnabss(float);
```

These builtins will emit :
- fnabs on PWR6 and below, or if VSX is disabled.
- xsnabsdp on PWR7 and above, if VSX is enabled.

Differential Revision: https://reviews.llvm.org/D125506
2022-05-19 11:28:40 -05:00

37 lines
1.4 KiB
C

// REQUIRES: powerpc-registered-target
// RUN: %clang_cc1 -triple powerpc64le-unknown-linux-gnu \
// RUN: -emit-llvm %s -target-cpu pwr8 -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc-unknown-aix \
// RUN: -emit-llvm %s -target-cpu pwr8 -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc64-unknown-linux-gnu \
// RUN: -emit-llvm %s -target-cpu pwr7 -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc64-unknown-aix \
// RUN: -emit-llvm %s -target-cpu pwr7 -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc64-unknown-linux-gnu \
// RUN: -emit-llvm %s -target-cpu pwr6 -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc64le-unknown-linux-gnu \
// RUN: -emit-llvm %s -target-cpu pwr6 -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc64-unknown-aix \
// RUN: -emit-llvm %s -target-cpu pwr6 -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc-unknown-aix \
// RUN: -emit-llvm %s -target-cpu pwr6 -o - | FileCheck %s
extern float f;
extern double d;
// CHECK-LABEL: @test_fnabs(
// CHECK: [[TMP0:%.*]] = load double, ptr @d
// CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.ppc.fnabs(double [[TMP0]])
// CHECK-NEXT: ret double [[TMP1]]
double test_fnabs() {
return __fnabs (d);
}
// CHECK-LABEL: @test_fnabss(
// CHECK: [[TMP0:%.*]] = load float, ptr @f
// CHECK-NEXT: [[TMP1:%.*]] = call float @llvm.ppc.fnabss(float [[TMP0]])
// CHECK-NEXT: ret float [[TMP1]]
float test_fnabss() {
return __fnabss (f);
}