Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / CodeGen / X86 / llvm.tan.ll
blob24b30038687f2b423a805b0907df101139894faa
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
2 ; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu | FileCheck %s
4 define half @use_tanf16(half %a) nounwind {
5 ; CHECK-LABEL: use_tanf16:
6 ; CHECK:       # %bb.0:
7 ; CHECK-NEXT:    pushq %rax
8 ; CHECK-NEXT:    callq __extendhfsf2@PLT
9 ; CHECK-NEXT:    callq tanf@PLT
10 ; CHECK-NEXT:    callq __truncsfhf2@PLT
11 ; CHECK-NEXT:    popq %rax
12 ; CHECK-NEXT:    retq
13   %x = call half @llvm.tan.f16(half %a)
14   ret half %x
17 define float @use_tanf32(float %a) nounwind {
18 ; CHECK-LABEL: use_tanf32:
19 ; CHECK:       # %bb.0:
20 ; CHECK-NEXT:    jmp tanf@PLT # TAILCALL
21   %x = call float @llvm.tan.f32(float %a)
22   ret float %x
25 define double @use_tanf64(double %a) nounwind {
26 ; CHECK-LABEL: use_tanf64:
27 ; CHECK:       # %bb.0:
28 ; CHECK-NEXT:    jmp tan@PLT # TAILCALL
29   %x = call double @llvm.tan.f64(double %a)
30   ret double %x
33 define x86_fp80 @use_tanf80(x86_fp80 %a) nounwind {
34 ; CHECK-LABEL: use_tanf80:
35 ; CHECK:       # %bb.0:
36 ; CHECK-NEXT:    subq $24, %rsp
37 ; CHECK-NEXT:    fldt 32(%rsp)
38 ; CHECK-NEXT:    fstpt (%rsp)
39 ; CHECK-NEXT:    callq tanl@PLT
40 ; CHECK-NEXT:    addq  $24, %rsp
41 ; CHECK-NEXT:    retq
42   %x = call x86_fp80 @llvm.tan.f80(x86_fp80 %a)
43   ret x86_fp80 %x
46 define fp128 @use_tanfp128(fp128 %a) nounwind {
47 ; CHECK-LABEL: use_tanfp128:
48 ; CHECK:       # %bb.0:
49 ; CHECK-NEXT:    jmp  tanf128@PLT # TAILCALL
50   %x = call fp128 @llvm.tan.f128(fp128 %a)
51   ret fp128 %x
54 define ppc_fp128 @use_tanppc_fp128(ppc_fp128 %a) nounwind {
55 ; CHECK-LABEL: use_tanppc_fp128:
56 ; CHECK:       # %bb.0:
57 ; CHECK-NEXT:    pushq %rax
58 ; CHECK-NEXT:    callq tanl@PLT
59 ; CHECK-NEXT:    popq %rax
60 ; CHECK-NEXT:    retq
61   %x = call ppc_fp128 @llvm.tan.ppcf128(ppc_fp128 %a)
62   ret ppc_fp128 %x
65 declare half @llvm.tan.f16(half)
66 declare float @llvm.tan.f32(float)
67 declare double @llvm.tan.f64(double)
68 declare x86_fp80 @llvm.tan.f80(x86_fp80)
69 declare fp128 @llvm.tan.f128(fp128)
70 declare ppc_fp128 @llvm.tan.ppcf128(ppc_fp128)