1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=thumbv7-apple-ios7.0 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-OLD 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=thumbv7s-apple-ios7.0 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-F16 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=thumbv8-apple-ios7.0 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-V8 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Workerdefine void @test_load_store(half* %in, half* %out) { 6*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_load_store: 7*9880d681SAndroid Build Coastguard Worker; CHECK: ldrh [[TMP:r[0-9]+]], [r0] 8*9880d681SAndroid Build Coastguard Worker; CHECK: strh [[TMP]], [r1] 9*9880d681SAndroid Build Coastguard Worker %val = load half, half* %in 10*9880d681SAndroid Build Coastguard Worker store half %val, half* %out 11*9880d681SAndroid Build Coastguard Worker ret void 12*9880d681SAndroid Build Coastguard Worker} 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Workerdefine i16 @test_bitcast_from_half(half* %addr) { 15*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_bitcast_from_half: 16*9880d681SAndroid Build Coastguard Worker; CHECK: ldrh r0, [r0] 17*9880d681SAndroid Build Coastguard Worker %val = load half, half* %addr 18*9880d681SAndroid Build Coastguard Worker %val_int = bitcast half %val to i16 19*9880d681SAndroid Build Coastguard Worker ret i16 %val_int 20*9880d681SAndroid Build Coastguard Worker} 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Workerdefine void @test_bitcast_to_half(half* %addr, i16 %in) { 23*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_bitcast_to_half: 24*9880d681SAndroid Build Coastguard Worker; CHECK: strh r1, [r0] 25*9880d681SAndroid Build Coastguard Worker %val_fp = bitcast i16 %in to half 26*9880d681SAndroid Build Coastguard Worker store half %val_fp, half* %addr 27*9880d681SAndroid Build Coastguard Worker ret void 28*9880d681SAndroid Build Coastguard Worker} 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Workerdefine float @test_extend32(half* %addr) { 31*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_extend32: 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker; CHECK-OLD: b.w ___extendhfsf2 34*9880d681SAndroid Build Coastguard Worker; CHECK-F16: vcvtb.f32.f16 35*9880d681SAndroid Build Coastguard Worker; CHECK-V8: vcvtb.f32.f16 36*9880d681SAndroid Build Coastguard Worker %val16 = load half, half* %addr 37*9880d681SAndroid Build Coastguard Worker %val32 = fpext half %val16 to float 38*9880d681SAndroid Build Coastguard Worker ret float %val32 39*9880d681SAndroid Build Coastguard Worker} 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Workerdefine double @test_extend64(half* %addr) { 42*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_extend64: 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker; CHECK-OLD: bl ___extendhfsf2 45*9880d681SAndroid Build Coastguard Worker; CHECK-OLD: vcvt.f64.f32 46*9880d681SAndroid Build Coastguard Worker; CHECK-F16: vcvtb.f32.f16 47*9880d681SAndroid Build Coastguard Worker; CHECK-F16: vcvt.f64.f32 48*9880d681SAndroid Build Coastguard Worker; CHECK-V8: vcvtb.f64.f16 49*9880d681SAndroid Build Coastguard Worker %val16 = load half, half* %addr 50*9880d681SAndroid Build Coastguard Worker %val32 = fpext half %val16 to double 51*9880d681SAndroid Build Coastguard Worker ret double %val32 52*9880d681SAndroid Build Coastguard Worker} 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Workerdefine void @test_trunc32(float %in, half* %addr) { 55*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_trunc32: 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker; CHECK-OLD: bl ___truncsfhf2 58*9880d681SAndroid Build Coastguard Worker; CHECK-F16: vcvtb.f16.f32 59*9880d681SAndroid Build Coastguard Worker; CHECK-V8: vcvtb.f16.f32 60*9880d681SAndroid Build Coastguard Worker %val16 = fptrunc float %in to half 61*9880d681SAndroid Build Coastguard Worker store half %val16, half* %addr 62*9880d681SAndroid Build Coastguard Worker ret void 63*9880d681SAndroid Build Coastguard Worker} 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Workerdefine void @test_trunc64(double %in, half* %addr) { 66*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_trunc64: 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker; CHECK-OLD: bl ___truncdfhf2 69*9880d681SAndroid Build Coastguard Worker; CHECK-F16: bl ___truncdfhf2 70*9880d681SAndroid Build Coastguard Worker; CHECK-V8: vcvtb.f16.f64 71*9880d681SAndroid Build Coastguard Worker %val16 = fptrunc double %in to half 72*9880d681SAndroid Build Coastguard Worker store half %val16, half* %addr 73*9880d681SAndroid Build Coastguard Worker ret void 74*9880d681SAndroid Build Coastguard Worker} 75