|  | ; RUN: llc -O0 -fast-isel -verify-machineinstrs -mtriple=aarch64-apple-ios < %s | FileCheck %s | 
|  |  | 
|  | ; Fast-isel can't do vector conversions yet, but it was emitting some highly | 
|  | ; suspect UCVTFUWDri MachineInstrs. | 
|  | define <4 x float> @test_uitofp(<4 x i32> %in) { | 
|  | ; CHECK-LABEL: test_uitofp: | 
|  | ; CHECK: ucvtf.4s v0, v0 | 
|  |  | 
|  | %res = uitofp <4 x i32> %in to <4 x float> | 
|  | ret <4 x float> %res | 
|  | } | 
|  |  | 
|  | define <2 x double> @test_sitofp(<2 x i32> %in) { | 
|  | ; CHECK-LABEL: test_sitofp: | 
|  | ; CHECK: sshll.2d [[EXT:v[0-9]+]], v0, #0 | 
|  | ; CHECK: scvtf.2d v0, [[EXT]] | 
|  |  | 
|  | %res = sitofp <2 x i32> %in to <2 x double> | 
|  | ret <2 x double> %res | 
|  | } | 
|  |  | 
|  | define <2 x i32> @test_fptoui(<2 x float> %in) { | 
|  | ; CHECK-LABEL: test_fptoui: | 
|  | ; CHECK: fcvtzu.2s v0, v0 | 
|  |  | 
|  | %res = fptoui <2 x float> %in to <2 x i32> | 
|  | ret <2 x i32> %res | 
|  | } | 
|  |  | 
|  | define <2 x i64> @test_fptosi(<2 x double> %in) { | 
|  | ; CHECK-LABEL: test_fptosi: | 
|  | ; CHECK: fcvtzs.2d v0, v0 | 
|  |  | 
|  | %res = fptosi <2 x double> %in to <2 x i64> | 
|  | ret <2 x i64> %res | 
|  | } | 
|  |  | 
|  | define fp128 @uitofp_i32_fp128(i32 %a) { | 
|  | entry: | 
|  | ; CHECK-LABEL: uitofp_i32_fp128 | 
|  | ; CHECK: bl ___floatunsitf | 
|  | %conv = uitofp i32 %a to fp128 | 
|  | ret fp128 %conv | 
|  | } | 
|  |  | 
|  | define fp128 @uitofp_i64_fp128(i64 %a) { | 
|  | entry: | 
|  | ; CHECK-LABEL: uitofp_i64_fp128 | 
|  | ; CHECK: bl ___floatunditf | 
|  | %conv = uitofp i64 %a to fp128 | 
|  | ret fp128 %conv | 
|  | } | 
|  |  | 
|  | define i32 @uitofp_fp128_i32(fp128 %a) { | 
|  | entry: | 
|  | ; CHECK-LABEL: uitofp_fp128_i32 | 
|  | ; CHECK: ___fixunstfsi | 
|  | %conv = fptoui fp128 %a to i32 | 
|  | ret i32 %conv | 
|  | } | 
|  |  | 
|  | define i64 @uitofp_fp128_i64(fp128 %a) { | 
|  | entry: | 
|  | ; CHECK-LABEL: uitofp_fp128_i64 | 
|  | ; CHECK: ___fixunstfdi | 
|  | %conv = fptoui fp128 %a to i64 | 
|  | ret i64 %conv | 
|  | } |