1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=arm-eabi -float-abi=soft -mattr=+vfp2 %s -o - | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workerdefine float @f(i32 %a) { 4*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: f: 5*9880d681SAndroid Build Coastguard Worker;CHECK: vmov 6*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vcvt.f32.s32 7*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vmov 8*9880d681SAndroid Build Coastguard Workerentry: 9*9880d681SAndroid Build Coastguard Worker %tmp = sitofp i32 %a to float ; <float> [#uses=1] 10*9880d681SAndroid Build Coastguard Worker ret float %tmp 11*9880d681SAndroid Build Coastguard Worker} 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workerdefine double @g(i32 %a) { 14*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: g: 15*9880d681SAndroid Build Coastguard Worker;CHECK: vmov 16*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vcvt.f64.s32 17*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vmov 18*9880d681SAndroid Build Coastguard Workerentry: 19*9880d681SAndroid Build Coastguard Worker %tmp = sitofp i32 %a to double ; <double> [#uses=1] 20*9880d681SAndroid Build Coastguard Worker ret double %tmp 21*9880d681SAndroid Build Coastguard Worker} 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Workerdefine double @uint_to_double(i32 %a) { 24*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: uint_to_double: 25*9880d681SAndroid Build Coastguard Worker;CHECK: vmov 26*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vcvt.f64.u32 27*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vmov 28*9880d681SAndroid Build Coastguard Workerentry: 29*9880d681SAndroid Build Coastguard Worker %tmp = uitofp i32 %a to double ; <double> [#uses=1] 30*9880d681SAndroid Build Coastguard Worker ret double %tmp 31*9880d681SAndroid Build Coastguard Worker} 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Workerdefine float @uint_to_float(i32 %a) { 34*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: uint_to_float: 35*9880d681SAndroid Build Coastguard Worker;CHECK: vmov 36*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vcvt.f32.u32 37*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vmov 38*9880d681SAndroid Build Coastguard Workerentry: 39*9880d681SAndroid Build Coastguard Worker %tmp = uitofp i32 %a to float ; <float> [#uses=1] 40*9880d681SAndroid Build Coastguard Worker ret float %tmp 41*9880d681SAndroid Build Coastguard Worker} 42*9880d681SAndroid Build Coastguard Worker 43*9880d681SAndroid Build Coastguard Workerdefine double @h(double* %v) { 44*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: h: 45*9880d681SAndroid Build Coastguard Worker;CHECK: vldr 46*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: vmov 47*9880d681SAndroid Build Coastguard Workerentry: 48*9880d681SAndroid Build Coastguard Worker %tmp = load double, double* %v ; <double> [#uses=1] 49*9880d681SAndroid Build Coastguard Worker ret double %tmp 50*9880d681SAndroid Build Coastguard Worker} 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Workerdefine float @h2() { 53*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: h2: 54*9880d681SAndroid Build Coastguard Worker;CHECK: mov r0, #1065353216 55*9880d681SAndroid Build Coastguard Workerentry: 56*9880d681SAndroid Build Coastguard Worker ret float 1.000000e+00 57*9880d681SAndroid Build Coastguard Worker} 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Workerdefine double @f2(double %a) { 60*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: f2: 61*9880d681SAndroid Build Coastguard Worker;CHECK-NOT: vmov 62*9880d681SAndroid Build Coastguard Worker ret double %a 63*9880d681SAndroid Build Coastguard Worker} 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Workerdefine void @f3() { 66*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: f3: 67*9880d681SAndroid Build Coastguard Worker;CHECK-NOT: vmov 68*9880d681SAndroid Build Coastguard Worker;CHECK: f4 69*9880d681SAndroid Build Coastguard Workerentry: 70*9880d681SAndroid Build Coastguard Worker %tmp = call double @f5( ) ; <double> [#uses=1] 71*9880d681SAndroid Build Coastguard Worker call void @f4( double %tmp ) 72*9880d681SAndroid Build Coastguard Worker ret void 73*9880d681SAndroid Build Coastguard Worker} 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Workerdeclare void @f4(double) 76*9880d681SAndroid Build Coastguard Worker 77*9880d681SAndroid Build Coastguard Workerdeclare double @f5() 78*9880d681SAndroid Build Coastguard Worker 79