[ELF] Reorder SectionBase/InputSectionBase members
[llvm-project.git] / llvm / test / CodeGen / AArch64 / powi-windows.ll
blob2d2f78b44f711e563c3a9c6e07385647c3e36707
1 ; RUN: llc -mtriple aarch64-windows < %s | FileCheck %s
3 declare double @llvm.powi.f64.i32(double, i32)
4 declare float @llvm.powi.f32.i32(float, i32)
6 define double @d(double %d, i32 %i) {
7 entry:
8   %0 = tail call double @llvm.powi.f64.i32(double %d, i32 %i)
9   ret double %0
12 ; CHECK-LABEL: d:
13 ; CHECK: scvtf d1, w0
14 ; CHECK-NEXT: b pow
16 define float @f(float %f, i32 %i) {
17 entry:
18   %0 = tail call float @llvm.powi.f32.i32(float %f, i32 %i)
19   ret float %0
22 ; CHECK-LABEL: f:
23 ; CHECK: scvtf s1, w0
24 ; CHECK-NEXT: b powf
26 define float @g(double %d, i32 %i) {
27 entry:
28   %0 = tail call double @llvm.powi.f64.i32(double %d, i32 %i)
29   %conv = fptrunc double %0 to float
30   ret float %conv
33 ; CHECK-LABEL: g:
34 ; CHECK: scvtf d1, w0
35 ; CHECK-NEXT: bl pow
37 define double @h(float %f, i32 %i) {
38 entry:
39   %0 = tail call float @llvm.powi.f32.i32(float %f, i32 %i)
40   %conv = fpext float %0 to double
41   ret double %conv
44 ; CHECK-LABEL: h:
45 ; CHECK: scvtf s1, w0
46 ; CHECK-NEXT: bl powf