xref: /llvm-project/llvm/test/CodeGen/LoongArch/ghc-cc.ll (revision b2e69f52bb5da067109b9a7d1f73d0dd1a6bb5ad)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc --mtriple=loongarch64 --mattr=+f,+d < %s | FileCheck %s --check-prefix=LA64
3
4; Check the GHC call convention works (la64)
5
6@base  = external dso_local global i64 ; assigned to register: s0
7@sp    = external dso_local global i64 ; assigned to register: s1
8@hp    = external dso_local global i64 ; assigned to register: s2
9@r1    = external dso_local global i64 ; assigned to register: s3
10@r2    = external dso_local global i64 ; assigned to register: s4
11@r3    = external dso_local global i64 ; assigned to register: s5
12@r4    = external dso_local global i64 ; assigned to register: s6
13@r5    = external dso_local global i64 ; assigned to register: s7
14@splim = external dso_local global i64 ; assigned to register: s8
15
16@f1 = external dso_local global float  ; assigned to register: fs0
17@f2 = external dso_local global float  ; assigned to register: fs1
18@f3 = external dso_local global float  ; assigned to register: fs2
19@f4 = external dso_local global float  ; assigned to register: fs3
20
21@d1 = external dso_local global double ; assigned to register: fs4
22@d2 = external dso_local global double ; assigned to register: fs5
23@d3 = external dso_local global double ; assigned to register: fs6
24@d4 = external dso_local global double ; assigned to register: fs7
25
26define ghccc void @foo() nounwind {
27; LA64-LABEL: foo:
28; LA64:       # %bb.0: # %entry
29; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d4)
30; LA64-NEXT:    fld.d $fs7, $a0, %pc_lo12(d4)
31; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d3)
32; LA64-NEXT:    fld.d $fs6, $a0, %pc_lo12(d3)
33; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d2)
34; LA64-NEXT:    fld.d $fs5, $a0, %pc_lo12(d2)
35; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d1)
36; LA64-NEXT:    fld.d $fs4, $a0, %pc_lo12(d1)
37; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f4)
38; LA64-NEXT:    fld.s $fs3, $a0, %pc_lo12(f4)
39; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f3)
40; LA64-NEXT:    fld.s $fs2, $a0, %pc_lo12(f3)
41; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f2)
42; LA64-NEXT:    fld.s $fs1, $a0, %pc_lo12(f2)
43; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f1)
44; LA64-NEXT:    fld.s $fs0, $a0, %pc_lo12(f1)
45; LA64-NEXT:    pcalau12i $a0, %pc_hi20(splim)
46; LA64-NEXT:    ld.d $s8, $a0, %pc_lo12(splim)
47; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r5)
48; LA64-NEXT:    ld.d $s7, $a0, %pc_lo12(r5)
49; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r4)
50; LA64-NEXT:    ld.d $s6, $a0, %pc_lo12(r4)
51; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r3)
52; LA64-NEXT:    ld.d $s5, $a0, %pc_lo12(r3)
53; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r2)
54; LA64-NEXT:    ld.d $s4, $a0, %pc_lo12(r2)
55; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r1)
56; LA64-NEXT:    ld.d $s3, $a0, %pc_lo12(r1)
57; LA64-NEXT:    pcalau12i $a0, %pc_hi20(hp)
58; LA64-NEXT:    ld.d $s2, $a0, %pc_lo12(hp)
59; LA64-NEXT:    pcalau12i $a0, %pc_hi20(sp)
60; LA64-NEXT:    ld.d $s1, $a0, %pc_lo12(sp)
61; LA64-NEXT:    pcalau12i $a0, %pc_hi20(base)
62; LA64-NEXT:    ld.d $s0, $a0, %pc_lo12(base)
63; LA64-NEXT:    b %plt(bar)
64
65entry:
66  %0  = load double, ptr @d4
67  %1  = load double, ptr @d3
68  %2  = load double, ptr @d2
69  %3  = load double, ptr @d1
70  %4  = load float, ptr @f4
71  %5  = load float, ptr @f3
72  %6 = load float, ptr @f2
73  %7 = load float, ptr @f1
74  %8 = load i64, ptr @splim
75  %9 = load i64, ptr @r5
76  %10 = load i64, ptr @r4
77  %11 = load i64, ptr @r3
78  %12 = load i64, ptr @r2
79  %13 = load i64, ptr @r1
80  %14 = load i64, ptr @hp
81  %15 = load i64, ptr @sp
82  %16 = load i64, ptr @base
83  tail call ghccc void @bar(i64 %16, i64 %15, i64 %14, i64 %13, i64 %12,
84                            i64 %11, i64 %10, i64 %9, i64 %8, float %7, float %6,
85                            float %5, float %4, double %3, double %2, double %1, double %0) nounwind
86  ret void
87}
88declare ghccc void @bar(i64, i64, i64, i64, i64, i64, i64, i64, i64,
89                        float, float, float, float,
90                        double, double, double, double)
91