1 ! RUN: bbc -emit-fir %s -outline-intrinsics -o - | FileCheck --check-prefixes="CHECK-FIR" %s
2 ! RUN: %flang_fc1 -emit-llvm %s -o - | FileCheck --check-prefixes="CHECK-LLVMIR" %s
3 ! REQUIRES: target=powerpc{{.*}}
5 ! CHECK-LABEL: fmadd_testr
6 subroutine fmadd_testr(a
, x
, y
)
9 ! CHECK-FIR: fir.call @fir.__ppc_fmadd.f32.f32.f32.f32
10 ! CHECK-LLVMIR: call contract float @llvm.fma.f32(float %{{[0-9]}}, float %{{[0-9]}}, float %{{[0-9]}})
13 ! CHECK-LABEL: fmadd_testd
14 subroutine fmadd_testd(a
, x
, y
)
17 ! CHECK-FIR: fir.call @fir.__ppc_fmadd.f64.f64.f64.f64
18 ! CHECK-LLVMIR: call contract double @llvm.fma.f64(double %{{[0-9]}}, double %{{[0-9]}}, double %{{[0-9]}})
21 ! CHECK-LABEL: fnmadd_testr
22 subroutine fnmadd_testr(a
, x
, y
)
25 ! CHECK-FIR: fir.call @fir.__ppc_fnmadd.f32.f32.f32.f32
26 ! CHECK-LLVMIR: call contract float @llvm.ppc.fnmadds(float %{{[0-9]}}, float %{{[0-9]}}, float %{{[0-9]}})
29 ! CHECK-LABEL: fnmadd_testd
30 subroutine fnmadd_testd(a
, x
, y
)
33 ! CHECK-FIR: fir.call @fir.__ppc_fnmadd.f64.f64.f64.f64
34 ! CHECK-LLVMIR: call contract double @llvm.ppc.fnmadd(double %{{[0-9]}}, double %{{[0-9]}}, double %{{[0-9]}})
37 ! CHECK-LABEL: fmsub_testr
38 subroutine fmsub_testr(a
, x
, y
)
41 ! CHECK-FIR: fir.call @fir.__ppc_fmsub.f32.f32.f32.f32
42 ! CHECK-LLVMIR: call contract float @llvm.ppc.fmsubs(float %{{[0-9]}}, float %{{[0-9]}}, float %{{[0-9]}})
45 ! CHECK-LABEL: fmsub_testd
46 subroutine fmsub_testd(a
, x
, y
)
49 ! CHECK-FIR: fir.call @fir.__ppc_fmsub.f64.f64.f64.f64
50 ! CHECK-LLVMIR: call contract double @llvm.ppc.fmsub(double %{{[0-9]}}, double %{{[0-9]}}, double %{{[0-9]}})
53 ! CHECK-LABEL: fnmsub_testr
54 subroutine fnmsub_testr(a
, x
, y
)
57 ! CHECK-FIR: fir.call @fir.__ppc_fnmsub.f32.f32.f32.f32
58 ! CHECK-LLVMIR: call contract float @llvm.ppc.fnmsub.f32(float %{{[0-9]}}, float %{{[0-9]}}, float %{{[0-9]}})
61 ! CHECK-LABEL: fnmsub_testd
62 subroutine fnmsub_testd(a
, x
, y
)
65 ! CHECK-FIR: fir.call @fir.__ppc_fnmsub.f64.f64.f64.f64
66 ! CHECK-LLVMIR: call contract double @llvm.ppc.fnmsub.f64(double %{{[0-9]}}, double %{{[0-9]}}, double %{{[0-9]}})