Compiler projects using llvm
// REQUIRES: powerpc-registered-target
// RUN: %clang_cc1 -no-opaque-pointers -triple powerpc64-unknown-linux-gnu \
// RUN:   -emit-llvm %s -o - -target-cpu pwr7 | FileCheck %s
// RUN: %clang_cc1 -no-opaque-pointers -triple powerpc64le-unknown-linux-gnu \
// RUN:   -emit-llvm %s -o - -target-cpu pwr8 | FileCheck %s
// RUN: %clang_cc1 -no-opaque-pointers -triple powerpc64-unknown-aix \
// RUN:   -emit-llvm %s -o - -target-cpu pwr7 | FileCheck %s
// RUN: %clang_cc1 -no-opaque-pointers -triple powerpc-unknown-aix \
// RUN:   -emit-llvm %s -o - -target-cpu pwr7 | FileCheck %s
// RUN: %clang_cc1 -no-opaque-pointers -triple powerpc64-unknown-linux-gnu -ffast-math -ffp-contract=fast \
// RUN:   -emit-llvm %s -o - -target-cpu pwr7 | FileCheck %s --check-prefix CHECK-OFAST

extern double a;
extern double b;
extern float c;
extern float d;

// CHECK-LABEL:   @test_swdiv(
// CHECK:         [[TMP0:%.*]] = load double, double* @a
// CHECK-NEXT:    [[TMP1:%.*]] = load double, double* @b
// CHECK-NEXT:    [[SWDIV:%.*]] = fdiv double [[TMP0]], [[TMP1]]
// CHECK-NEXT:    ret double [[SWDIV]]
//
// CHECK-OFAST-LABEL:   @test_swdiv(
// CHECK-OFAST:         [[TMP0:%.*]] = load double, double* @a
// CHECK-OFAST-NEXT:    [[TMP1:%.*]] = load double, double* @b
// CHECK-OFAST-NEXT:    [[SWDIV:%.*]] = fdiv fast double [[TMP0]], [[TMP1]]
// CHECK-OFAST-NEXT:    ret double [[SWDIV]]
//
double test_swdiv() {
  return __swdiv(a, b);
}

// CHECK-LABEL:   @test_swdivs(
// CHECK:         [[TMP0:%.*]] = load float, float* @c
// CHECK-NEXT:    [[TMP1:%.*]] = load float, float* @d
// CHECK-NEXT:    [[SWDIVS:%.*]] = fdiv float [[TMP0]], [[TMP1]]
// CHECK-NEXT:    ret float [[SWDIVS]]
//
// CHECK-OFAST-LABEL:   @test_swdivs(
// CHECK-OFAST:         [[TMP0:%.*]] = load float, float* @c
// CHECK-OFAST-NEXT:    [[TMP1:%.*]] = load float, float* @d
// CHECK-OFAST-NEXT:    [[SWDIVS:%.*]] = fdiv fast float [[TMP0]], [[TMP1]]
// CHECK-OFAST-NEXT:    ret float [[SWDIVS]]
//
float test_swdivs() {
  return __swdivs(c, d);
}

// CHECK-LABEL:   @test_builtin_ppc_swdiv(
// CHECK:         [[TMP0:%.*]] = load double, double* @a
// CHECK-NEXT:    [[TMP1:%.*]] = load double, double* @b
// CHECK-NEXT:    [[SWDIV:%.*]] = fdiv double [[TMP0]], [[TMP1]]
// CHECK-NEXT:    ret double [[SWDIV]]
//
// CHECK-OFAST-LABEL:   @test_builtin_ppc_swdiv(
// CHECK-OFAST:         [[TMP0:%.*]] = load double, double* @a
// CHECK-OFAST-NEXT:    [[TMP1:%.*]] = load double, double* @b
// CHECK-OFAST-NEXT:    [[SWDIV:%.*]] = fdiv fast double [[TMP0]], [[TMP1]]
// CHECK-OFAST-NEXT:    ret double [[SWDIV]]
//
double test_builtin_ppc_swdiv() {
  return __builtin_ppc_swdiv(a, b);
}

// CHECK-LABEL:   @test_builtin_ppc_swdivs(
// CHECK:         [[TMP0:%.*]] = load float, float* @c
// CHECK-NEXT:    [[TMP1:%.*]] = load float, float* @d
// CHECK-NEXT:    [[SWDIVS:%.*]] = fdiv float [[TMP0]], [[TMP1]]
// CHECK-NEXT:    ret float [[SWDIVS]]
//
// CHECK-OFAST-LABEL:   @test_builtin_ppc_swdivs(
// CHECK-OFAST:         [[TMP0:%.*]] = load float, float* @c
// CHECK-OFAST-NEXT:    [[TMP1:%.*]] = load float, float* @d
// CHECK-OFAST-NEXT:    [[SWDIVS:%.*]] = fdiv fast float [[TMP0]], [[TMP1]]
// CHECK-OFAST-NEXT:    ret float [[SWDIVS]]
//
float test_builtin_ppc_swdivs() {
  return __builtin_ppc_swdivs(c, d);
}