blob: 116320723ccd43c6b9ffb8023284cd80cae92bb3 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=s390x-linux-gnu < %s | FileCheck -check-prefix=LINUX %s
; FIXME: Merge with llvm.sincos.ll when zos is fixed for half.
define { half, half } @test_sincos_f16(half %a) #0 {
; LINUX-LABEL: test_sincos_f16:
; LINUX: # %bb.0:
; LINUX-NEXT: stmg %r14, %r15, 112(%r15)
; LINUX-NEXT: .cfi_offset %r14, -48
; LINUX-NEXT: .cfi_offset %r15, -40
; LINUX-NEXT: aghi %r15, -176
; LINUX-NEXT: .cfi_def_cfa_offset 336
; LINUX-NEXT: std %f8, 168(%r15) # 8-byte Spill
; LINUX-NEXT: .cfi_offset %f8, -168
; LINUX-NEXT: brasl %r14, __extendhfsf2@PLT
; LINUX-NEXT: la %r2, 164(%r15)
; LINUX-NEXT: la %r3, 160(%r15)
; LINUX-NEXT: brasl %r14, sincosf@PLT
; LINUX-NEXT: le %f0, 164(%r15)
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: le %f1, 160(%r15)
; LINUX-NEXT: ler %f8, %f0
; LINUX-NEXT: ler %f0, %f1
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: ler %f2, %f0
; LINUX-NEXT: ler %f0, %f8
; LINUX-NEXT: ld %f8, 168(%r15) # 8-byte Reload
; LINUX-NEXT: lmg %r14, %r15, 288(%r15)
; LINUX-NEXT: br %r14
%result = call { half, half } @llvm.sincos.f16(half %a)
ret { half, half } %result
}
define half @test_sincos_f16_only_use_sin(half %a) #0 {
; LINUX-LABEL: test_sincos_f16_only_use_sin:
; LINUX: # %bb.0:
; LINUX-NEXT: stmg %r14, %r15, 112(%r15)
; LINUX-NEXT: .cfi_offset %r14, -48
; LINUX-NEXT: .cfi_offset %r15, -40
; LINUX-NEXT: aghi %r15, -168
; LINUX-NEXT: .cfi_def_cfa_offset 328
; LINUX-NEXT: brasl %r14, __extendhfsf2@PLT
; LINUX-NEXT: la %r2, 160(%r15)
; LINUX-NEXT: la %r3, 164(%r15)
; LINUX-NEXT: brasl %r14, sincosf@PLT
; LINUX-NEXT: le %f0, 160(%r15)
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: lmg %r14, %r15, 280(%r15)
; LINUX-NEXT: br %r14
%result = call { half, half } @llvm.sincos.f16(half %a)
%result.0 = extractvalue { half, half } %result, 0
ret half %result.0
}
define half @test_sincos_f16_only_use_cos(half %a) #0 {
; LINUX-LABEL: test_sincos_f16_only_use_cos:
; LINUX: # %bb.0:
; LINUX-NEXT: stmg %r14, %r15, 112(%r15)
; LINUX-NEXT: .cfi_offset %r14, -48
; LINUX-NEXT: .cfi_offset %r15, -40
; LINUX-NEXT: aghi %r15, -168
; LINUX-NEXT: .cfi_def_cfa_offset 328
; LINUX-NEXT: brasl %r14, __extendhfsf2@PLT
; LINUX-NEXT: la %r2, 164(%r15)
; LINUX-NEXT: la %r3, 160(%r15)
; LINUX-NEXT: brasl %r14, sincosf@PLT
; LINUX-NEXT: le %f0, 160(%r15)
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: lmg %r14, %r15, 280(%r15)
; LINUX-NEXT: br %r14
%result = call { half, half } @llvm.sincos.f16(half %a)
%result.1 = extractvalue { half, half } %result, 1
ret half %result.1
}
define { <2 x half>, <2 x half> } @test_sincos_v2f16(<2 x half> %a) #0 {
; LINUX-LABEL: test_sincos_v2f16:
; LINUX: # %bb.0:
; LINUX-NEXT: stmg %r14, %r15, 112(%r15)
; LINUX-NEXT: .cfi_offset %r14, -48
; LINUX-NEXT: .cfi_offset %r15, -40
; LINUX-NEXT: aghi %r15, -200
; LINUX-NEXT: .cfi_def_cfa_offset 360
; LINUX-NEXT: std %f8, 192(%r15) # 8-byte Spill
; LINUX-NEXT: std %f9, 184(%r15) # 8-byte Spill
; LINUX-NEXT: std %f10, 176(%r15) # 8-byte Spill
; LINUX-NEXT: .cfi_offset %f8, -168
; LINUX-NEXT: .cfi_offset %f9, -176
; LINUX-NEXT: .cfi_offset %f10, -184
; LINUX-NEXT: ler %f8, %f2
; LINUX-NEXT: brasl %r14, __extendhfsf2@PLT
; LINUX-NEXT: la %r2, 172(%r15)
; LINUX-NEXT: la %r3, 168(%r15)
; LINUX-NEXT: brasl %r14, sincosf@PLT
; LINUX-NEXT: ler %f0, %f8
; LINUX-NEXT: brasl %r14, __extendhfsf2@PLT
; LINUX-NEXT: la %r2, 164(%r15)
; LINUX-NEXT: la %r3, 160(%r15)
; LINUX-NEXT: brasl %r14, sincosf@PLT
; LINUX-NEXT: le %f0, 172(%r15)
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: le %f1, 164(%r15)
; LINUX-NEXT: ler %f8, %f0
; LINUX-NEXT: ler %f0, %f1
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: le %f1, 168(%r15)
; LINUX-NEXT: ler %f9, %f0
; LINUX-NEXT: ler %f0, %f1
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: le %f1, 160(%r15)
; LINUX-NEXT: ler %f10, %f0
; LINUX-NEXT: ler %f0, %f1
; LINUX-NEXT: brasl %r14, __truncsfhf2@PLT
; LINUX-NEXT: ler %f6, %f0
; LINUX-NEXT: ler %f0, %f8
; LINUX-NEXT: ler %f2, %f9
; LINUX-NEXT: ler %f4, %f10
; LINUX-NEXT: ld %f8, 192(%r15) # 8-byte Reload
; LINUX-NEXT: ld %f9, 184(%r15) # 8-byte Reload
; LINUX-NEXT: ld %f10, 176(%r15) # 8-byte Reload
; LINUX-NEXT: lmg %r14, %r15, 312(%r15)
; LINUX-NEXT: br %r14
%result = call { <2 x half>, <2 x half> } @llvm.sincos.v2f16(<2 x half> %a)
ret { <2 x half>, <2 x half> } %result
}