; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 ; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z16 -verify-machineinstrs \ ; RUN: | FileCheck %s ; ; Some tests with comparisons and their uses involving 16-bit floating point. ; fcmp half; select half define half @fun0(half %Arg0, half %Arg1) { ; CHECK-LABEL: fun0: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: stmg %r14, %r15, 112(%r15) ; CHECK-NEXT: .cfi_offset %r14, -48 ; CHECK-NEXT: .cfi_offset %r15, -40 ; CHECK-NEXT: aghi %r15, -176 ; CHECK-NEXT: .cfi_def_cfa_offset 336 ; CHECK-NEXT: std %f8, 168(%r15) # 8-byte Spill ; CHECK-NEXT: std %f9, 160(%r15) # 8-byte Spill ; CHECK-NEXT: .cfi_offset %f8, -168 ; CHECK-NEXT: .cfi_offset %f9, -176 ; CHECK-NEXT: ldr %f8, %f2 ; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT ; CHECK-NEXT: ldr %f9, %f0 ; CHECK-NEXT: ldr %f0, %f8 ; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT ; CHECK-NEXT: ltebr %f1, %f9 ; CHECK-NEXT: # kill: def $f0s killed $f0s def $v0 ; CHECK-NEXT: jl .LBB0_2 ; CHECK-NEXT: # %bb.1: # %entry ; CHECK-NEXT: vgmf %v0, 2, 8 ; CHECK-NEXT: .LBB0_2: # %entry ; CHECK-NEXT: # kill: def $f0s killed $f0s killed $v0 ; CHECK-NEXT: brasl %r14, __truncsfhf2@PLT ; CHECK-NEXT: ld %f8, 168(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f9, 160(%r15) # 8-byte Reload ; CHECK-NEXT: lmg %r14, %r15, 288(%r15) ; CHECK-NEXT: br %r14 entry: %cmp = fcmp olt half %Arg0, 0xH0000 %cond = select i1 %cmp, half %Arg1, half 1.0 ret half %cond } ; fcmp half; select i32 define i32 @fun1(half %Arg0, i32 %Arg1) { ; CHECK-LABEL: fun1: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: stmg %r13, %r15, 104(%r15) ; CHECK-NEXT: .cfi_offset %r13, -56 ; CHECK-NEXT: .cfi_offset %r14, -48 ; CHECK-NEXT: .cfi_offset %r15, -40 ; CHECK-NEXT: aghi %r15, -160 ; CHECK-NEXT: .cfi_def_cfa_offset 320 ; CHECK-NEXT: lr %r13, %r2 ; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT ; CHECK-NEXT: ltebr %f0, %f0 ; CHECK-NEXT: lochinl %r13, 0 ; CHECK-NEXT: lr %r2, %r13 ; CHECK-NEXT: lmg %r13, %r15, 264(%r15) ; CHECK-NEXT: br %r14 entry: %cmp = fcmp olt half %Arg0, 0xH0000 %cond = select i1 %cmp, i32 %Arg1, i32 0 ret i32 %cond } ; icmp i32; select half define half @fun2(i32 %Arg0, half %Arg1) { ; CHECK-LABEL: fun2: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: stmg %r13, %r15, 104(%r15) ; CHECK-NEXT: .cfi_offset %r13, -56 ; CHECK-NEXT: .cfi_offset %r14, -48 ; CHECK-NEXT: .cfi_offset %r15, -40 ; CHECK-NEXT: aghi %r15, -160 ; CHECK-NEXT: .cfi_def_cfa_offset 320 ; CHECK-NEXT: lr %r13, %r2 ; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT ; CHECK-NEXT: # kill: def $f0s killed $f0s def $v0 ; CHECK-NEXT: cije %r13, 0, .LBB2_2 ; CHECK-NEXT: # %bb.1: # %entry ; CHECK-NEXT: vgmf %v0, 2, 8 ; CHECK-NEXT: .LBB2_2: # %entry ; CHECK-NEXT: # kill: def $f0s killed $f0s killed $v0 ; CHECK-NEXT: brasl %r14, __truncsfhf2@PLT ; CHECK-NEXT: lmg %r13, %r15, 264(%r15) ; CHECK-NEXT: br %r14 entry: %cmp = icmp eq i32 %Arg0, 0 %cond = select i1 %cmp, half %Arg1, half 1.0 ret half %cond } define i64 @fun3(i64 %a, i64 %b, half %f1, half %f2) #0 { ; CHECK-LABEL: fun3: ; CHECK: # %bb.0: ; CHECK-NEXT: stmg %r12, %r15, 96(%r15) ; CHECK-NEXT: .cfi_offset %r12, -64 ; CHECK-NEXT: .cfi_offset %r13, -56 ; CHECK-NEXT: .cfi_offset %r14, -48 ; CHECK-NEXT: .cfi_offset %r15, -40 ; CHECK-NEXT: aghi %r15, -176 ; CHECK-NEXT: .cfi_def_cfa_offset 336 ; CHECK-NEXT: std %f8, 168(%r15) # 8-byte Spill ; CHECK-NEXT: std %f9, 160(%r15) # 8-byte Spill ; CHECK-NEXT: .cfi_offset %f8, -168 ; CHECK-NEXT: .cfi_offset %f9, -176 ; CHECK-NEXT: ldr %f8, %f0 ; CHECK-NEXT: ldr %f0, %f2 ; CHECK-NEXT: lgr %r13, %r3 ; CHECK-NEXT: lgr %r12, %r2 ; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT ; CHECK-NEXT: ldr %f9, %f0 ; CHECK-NEXT: ldr %f0, %f8 ; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT ; CHECK-NEXT: cebr %f0, %f9 ; CHECK-NEXT: ld %f8, 168(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f9, 160(%r15) # 8-byte Reload ; CHECK-NEXT: selgre %r2, %r12, %r13 ; CHECK-NEXT: lmg %r12, %r15, 272(%r15) ; CHECK-NEXT: br %r14 %cond = call i1 @llvm.experimental.constrained.fcmp.f32( half %f1, half %f2, metadata !"oeq", metadata !"fpexcept.strict") #0 %res = select i1 %cond, i64 %a, i64 %b ret i64 %res } define half @fun4(half %Arg0, ptr %Dst) { ; CHECK-LABEL: fun4: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: stmg %r13, %r15, 104(%r15) ; CHECK-NEXT: .cfi_offset %r13, -56 ; CHECK-NEXT: .cfi_offset %r14, -48 ; CHECK-NEXT: .cfi_offset %r15, -40 ; CHECK-NEXT: aghi %r15, -160 ; CHECK-NEXT: .cfi_def_cfa_offset 320 ; CHECK-NEXT: lgr %r13, %r2 ; CHECK-NEXT: brasl %r14, __extendhfsf2@PLT ; CHECK-NEXT: ltebr %f0, %f0 ; CHECK-NEXT: je .LBB4_2 ; CHECK-NEXT: # %bb.1: # %store ; CHECK-NEXT: lzer %f0 ; CHECK-NEXT: vsteh %v0, 0(%r13), 0 ; CHECK-NEXT: .LBB4_2: # %exit ; CHECK-NEXT: lzer %f0 ; CHECK-NEXT: lmg %r13, %r15, 264(%r15) ; CHECK-NEXT: br %r14 entry: %cmp = fcmp oeq half %Arg0, 0.0 br i1 %cmp, label %exit, label %store store: store half 0.0, ptr %Dst br label %exit exit: ret half 0.0 } declare i1 @llvm.experimental.constrained.fcmp.f32(half, half, metadata, metadata)