1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=arm-eabi -mattr=+neon %s -o - | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workerdefine <2 x i32> @test1(<2 x double>* %A) { 4*9880d681SAndroid Build Coastguard Worker; CHECK: test1 5*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.s32.f64 6*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.s32.f64 7*9880d681SAndroid Build Coastguard Worker %tmp1 = load <2 x double>, <2 x double>* %A 8*9880d681SAndroid Build Coastguard Worker %tmp2 = fptosi <2 x double> %tmp1 to <2 x i32> 9*9880d681SAndroid Build Coastguard Worker ret <2 x i32> %tmp2 10*9880d681SAndroid Build Coastguard Worker} 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Workerdefine <2 x i32> @test2(<2 x double>* %A) { 13*9880d681SAndroid Build Coastguard Worker; CHECK: test2 14*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.u32.f64 15*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.u32.f64 16*9880d681SAndroid Build Coastguard Worker %tmp1 = load <2 x double>, <2 x double>* %A 17*9880d681SAndroid Build Coastguard Worker %tmp2 = fptoui <2 x double> %tmp1 to <2 x i32> 18*9880d681SAndroid Build Coastguard Worker ret <2 x i32> %tmp2 19*9880d681SAndroid Build Coastguard Worker} 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Workerdefine <2 x double> @test3(<2 x i32>* %A) { 22*9880d681SAndroid Build Coastguard Worker; CHECK: test3 23*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.f64.s32 24*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.f64.s32 25*9880d681SAndroid Build Coastguard Worker %tmp1 = load <2 x i32>, <2 x i32>* %A 26*9880d681SAndroid Build Coastguard Worker %tmp2 = sitofp <2 x i32> %tmp1 to <2 x double> 27*9880d681SAndroid Build Coastguard Worker ret <2 x double> %tmp2 28*9880d681SAndroid Build Coastguard Worker} 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Workerdefine <2 x double> @test4(<2 x i32>* %A) { 31*9880d681SAndroid Build Coastguard Worker; CHECK: test4 32*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.f64.u32 33*9880d681SAndroid Build Coastguard Worker; CHECK: vcvt.f64.u32 34*9880d681SAndroid Build Coastguard Worker %tmp1 = load <2 x i32>, <2 x i32>* %A 35*9880d681SAndroid Build Coastguard Worker %tmp2 = uitofp <2 x i32> %tmp1 to <2 x double> 36*9880d681SAndroid Build Coastguard Worker ret <2 x double> %tmp2 37*9880d681SAndroid Build Coastguard Worker} 38