; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 ; RUN: llc < %s -mtriple=armv7-none-eabihf -mattr=+fullfp16 -enable-no-nans-fp-math | FileCheck %s ; RUN: llc < %s -mtriple=thumbv7a-none-eabihf -mattr=+fullfp16 -enable-no-nans-fp-math | FileCheck %s ; TODO: we can't pass half-precision arguments as "half" types yet. We do ; that for the time being by passing "float %f.coerce" and the necessary ; bitconverts/truncates. In these tests we pass i16 and use 1 bitconvert, which ; is the shortest way to get a half type. But when we can pass half types, we ; want to use that here. define half @fp16_vminnm_o(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_o: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast olt half %0, %1 %cond = select nsz i1 %cmp, half %0, half %1 ret half %cond } define half @fp16_vminnm_o_rev(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_o_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ogt half %0, %1 %cond = select nsz i1 %cmp, half %1, half %0 ret half %cond } define half @fp16_vminnm_u(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_u: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ult half %0, %1 %cond = select nsz i1 %cmp, half %0, half %1 ret half %cond } define half @fp16_vminnm_ule(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_ule: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ule half %0, %1 %cond = select nsz i1 %cmp, half %0, half %1 ret half %cond } define half @fp16_vminnm_u_rev(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_u_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ugt half %0, %1 %cond = select nsz i1 %cmp, half %1, half %0 ret half %cond } define half @fp16_vmaxnm_o(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_o: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ogt half %0, %1 %cond = select nsz i1 %cmp, half %0, half %1 ret half %cond } define half @fp16_vmaxnm_oge(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_oge: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast oge half %0, %1 %cond = select nsz i1 %cmp, half %0, half %1 ret half %cond } define half @fp16_vmaxnm_o_rev(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_o_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast olt half %0, %1 %cond = select nsz i1 %cmp, half %1, half %0 ret half %cond } define half @fp16_vmaxnm_ole_rev(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_ole_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ole half %0, %1 %cond = select nsz i1 %cmp, half %1, half %0 ret half %cond } define half @fp16_vmaxnm_u(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_u: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ugt half %0, %1 %cond = select nsz i1 %cmp, half %0, half %1 ret half %cond } define half @fp16_vmaxnm_uge(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_uge: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast uge half %0, %1 %cond = select nsz i1 %cmp, half %0, half %1 ret half %cond } define half @fp16_vmaxnm_u_rev(i16 signext %a, i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_u_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r1 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr entry: %0 = bitcast i16 %a to half %1 = bitcast i16 %b to half %cmp = fcmp fast ult half %0, %1 %cond = select nsz i1 %cmp, half %1, half %0 ret half %cond } ; known non-NaNs define half @fp16_vminnm_NNNo(i16 signext %a) { ; CHECK-LABEL: fp16_vminnm_NNNo: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmov.f16 s2, #1.200000e+01 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI12_0 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI12_0: ; CHECK-NEXT: .short 0x5040 @ half 34 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast olt half %0, 12. %cond1 = select nsz i1 %cmp1, half %0, half 12. %cmp2 = fcmp fast olt half 34., %cond1 %cond2 = select nsz i1 %cmp2, half 34., half %cond1 ret half %cond2 } define half @fp16_vminnm_NNNo_rev(i16 signext %a) { ; CHECK-LABEL: fp16_vminnm_NNNo_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI13_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI13_1 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI13_0: ; CHECK-NEXT: .short 0x5300 @ half 56 ; CHECK-NEXT: .LCPI13_1: ; CHECK-NEXT: .short 0x54e0 @ half 78 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast ogt half %0, 56. %cond1 = select nsz i1 %cmp1, half 56., half %0 %cmp2 = fcmp fast ogt half 78., %cond1 %cond2 = select nsz i1 %cmp2, half %cond1, half 78. ret half %cond2 } define half @fp16_vminnm_NNNu(i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_NNNu: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmov.f16 s2, #1.200000e+01 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI14_0 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI14_0: ; CHECK-NEXT: .short 0x5040 @ half 34 entry: %0 = bitcast i16 %b to half %cmp1 = fcmp fast ult half 12., %0 %cond1 = select nsz i1 %cmp1, half 12., half %0 %cmp2 = fcmp fast ult half %cond1, 34. %cond2 = select nsz i1 %cmp2, half %cond1, half 34. ret half %cond2 } define half @fp16_vminnm_NNNule(i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_NNNule: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI15_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI15_1 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI15_0: ; CHECK-NEXT: .short 0x5040 @ half 34 ; CHECK-NEXT: .LCPI15_1: ; CHECK-NEXT: .short 0x5300 @ half 56 entry: %0 = bitcast i16 %b to half %cmp1 = fcmp fast ule half 34., %0 %cond1 = select nsz i1 %cmp1, half 34., half %0 %cmp2 = fcmp fast ule half %cond1, 56. %cond2 = select nsz i1 %cmp2, half %cond1, half 56. ret half %cond2 } define half @fp16_vminnm_NNNu_rev(i16 signext %b) { ; CHECK-LABEL: fp16_vminnm_NNNu_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI16_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI16_1 ; CHECK-NEXT: vminnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI16_0: ; CHECK-NEXT: .short 0x5300 @ half 56 ; CHECK-NEXT: .LCPI16_1: ; CHECK-NEXT: .short 0x54e0 @ half 78 entry: %0 = bitcast i16 %b to half %cmp1 = fcmp fast ugt half 56., %0 %cond1 = select nsz i1 %cmp1, half %0, half 56. %cmp2 = fcmp fast ugt half %cond1, 78. %cond2 = select nsz i1 %cmp2, half 78., half %cond1 ret half %cond2 } define half @fp16_vmaxnm_NNNo(i16 signext %a) { ; CHECK-LABEL: fp16_vmaxnm_NNNo: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmov.f16 s2, #1.200000e+01 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI17_0 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI17_0: ; CHECK-NEXT: .short 0x5040 @ half 34 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast ogt half %0, 12. %cond1 = select nsz i1 %cmp1, half %0, half 12. %cmp2 = fcmp fast ogt half 34., %cond1 %cond2 = select nsz i1 %cmp2, half 34., half %cond1 ret half %cond2 } define half @fp16_vmaxnm_NNNoge(i16 signext %a) { ; CHECK-LABEL: fp16_vmaxnm_NNNoge: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI18_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI18_1 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI18_0: ; CHECK-NEXT: .short 0x5040 @ half 34 ; CHECK-NEXT: .LCPI18_1: ; CHECK-NEXT: .short 0x5300 @ half 56 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast oge half %0, 34. %cond1 = select nsz i1 %cmp1, half %0, half 34. %cmp2 = fcmp fast oge half 56., %cond1 %cond2 = select nsz i1 %cmp2, half 56., half %cond1 ret half %cond2 } define half @fp16_vmaxnm_NNNo_rev(i16 signext %a) { ; CHECK-LABEL: fp16_vmaxnm_NNNo_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI19_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI19_1 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI19_0: ; CHECK-NEXT: .short 0x5300 @ half 56 ; CHECK-NEXT: .LCPI19_1: ; CHECK-NEXT: .short 0x54e0 @ half 78 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast olt half %0, 56. %cond1 = select nsz i1 %cmp1, half 56., half %0 %cmp2 = fcmp fast olt half 78., %cond1 %cond2 = select nsz i1 %cmp2, half %cond1, half 78. ret half %cond2 } define half @fp16_vmaxnm_NNNole_rev(i16 signext %a) { ; CHECK-LABEL: fp16_vmaxnm_NNNole_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI20_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI20_1 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI20_0: ; CHECK-NEXT: .short 0x54e0 @ half 78 ; CHECK-NEXT: .LCPI20_1: ; CHECK-NEXT: .short 0x55a0 @ half 90 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast ole half %0, 78. %cond1 = select nsz i1 %cmp1, half 78., half %0 %cmp2 = fcmp fast ole half 90., %cond1 %cond2 = select nsz i1 %cmp2, half %cond1, half 90. ret half %cond2 } define half @fp16_vmaxnm_NNNu(i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_NNNu: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmov.f16 s2, #1.200000e+01 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI21_0 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI21_0: ; CHECK-NEXT: .short 0x5040 @ half 34 entry: %0 = bitcast i16 %b to half %cmp1 = fcmp fast ugt half 12., %0 %cond1 = select nsz i1 %cmp1, half 12., half %0 %cmp2 = fcmp fast ugt half %cond1, 34. %cond2 = select nsz i1 %cmp2, half %cond1, half 34. ret half %cond2 } define half @fp16_vmaxnm_NNNuge(i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_NNNuge: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI22_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI22_1 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI22_0: ; CHECK-NEXT: .short 0x5040 @ half 34 ; CHECK-NEXT: .LCPI22_1: ; CHECK-NEXT: .short 0x5300 @ half 56 entry: %0 = bitcast i16 %b to half %cmp1 = fcmp fast uge half 34., %0 %cond1 = select nsz i1 %cmp1, half 34., half %0 %cmp2 = fcmp fast uge half %cond1, 56. %cond2 = select nsz i1 %cmp2, half %cond1, half 56. ret half %cond2 } define half @fp16_vmaxnm_NNNu_rev(i16 signext %b) { ; CHECK-LABEL: fp16_vmaxnm_NNNu_rev: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s2, .LCPI23_0 ; CHECK-NEXT: vmov.f16 s0, r0 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: vldr.16 s2, .LCPI23_1 ; CHECK-NEXT: vmaxnm.f16 s0, s0, s2 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI23_0: ; CHECK-NEXT: .short 0x5300 @ half 56 ; CHECK-NEXT: .LCPI23_1: ; CHECK-NEXT: .short 0x54e0 @ half 78 entry: %0 = bitcast i16 %b to half %cmp1 = fcmp fast ult half 56., %0 %cond1 = select nsz i1 %cmp1, half %0, half 56. %cmp2 = fcmp fast ult half %cond1, 78. %cond2 = select nsz i1 %cmp2, half 78., half %cond1 ret half %cond2 } define half @fp16_vminmaxnm_0(i16 signext %a) { ; CHECK-LABEL: fp16_vminmaxnm_0: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s0, .LCPI24_0 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s2, s2, s0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI24_0: ; CHECK-NEXT: .short 0x0000 @ half 0 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast olt half %0, 0. %cond1 = select nsz i1 %cmp1, half %0, half 0. %cmp2 = fcmp fast ogt half %cond1, 0. %cond2 = select nsz i1 %cmp2, half %cond1, half 0. ret half %cond2 } define half @fp16_vminmaxnm_neg0(i16 signext %a) { ; CHECK-LABEL: fp16_vminmaxnm_neg0: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s0, .LCPI25_0 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s2, s2, s0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI25_0: ; CHECK-NEXT: .short 0x8000 @ half -0 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast olt half %0, -0. %cond1 = select nsz i1 %cmp1, half %0, half -0. %cmp2 = fcmp fast ugt half %cond1, -0. %cond2 = select nsz i1 %cmp2, half %cond1, half -0. ret half %cond2 } define half @fp16_vminmaxnm_e_0(i16 signext %a) { ; CHECK-LABEL: fp16_vminmaxnm_e_0: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s0, .LCPI26_0 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s2, s2, s0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI26_0: ; CHECK-NEXT: .short 0x0000 @ half 0 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast ule half 0., %0 %cond1 = select nsz i1 %cmp1, half 0., half %0 %cmp2 = fcmp fast uge half 0., %cond1 %cond2 = select nsz i1 %cmp2, half 0., half %cond1 ret half %cond2 } define half @fp16_vminmaxnm_e_neg0(i16 signext %a) { ; CHECK-LABEL: fp16_vminmaxnm_e_neg0: ; CHECK: @ %bb.0: @ %entry ; CHECK-NEXT: vldr.16 s0, .LCPI27_0 ; CHECK-NEXT: vmov.f16 s2, r0 ; CHECK-NEXT: vminnm.f16 s2, s2, s0 ; CHECK-NEXT: vmaxnm.f16 s0, s2, s0 ; CHECK-NEXT: bx lr ; CHECK-NEXT: .p2align 1 ; CHECK-NEXT: @ %bb.1: ; CHECK-NEXT: .LCPI27_0: ; CHECK-NEXT: .short 0x8000 @ half -0 entry: %0 = bitcast i16 %a to half %cmp1 = fcmp fast ule half -0., %0 %cond1 = select nsz i1 %cmp1, half -0., half %0 %cmp2 = fcmp fast oge half -0., %cond1 %cond2 = select nsz i1 %cmp2, half -0., half %cond1 ret half %cond2 }