1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc -mtriple=riscv32 -mattr=+f,+d < %s | FileCheck %s
3
4; Check the GHC call convention works (rv32)
5
6@base  = external global i32 ; assigned to register: s1
7@sp    = external global i32 ; assigned to register: s2
8@hp    = external global i32 ; assigned to register: s3
9@r1    = external global i32 ; assigned to register: s4
10@r2    = external global i32 ; assigned to register: s5
11@r3    = external global i32 ; assigned to register: s6
12@r4    = external global i32 ; assigned to register: s7
13@r5    = external global i32 ; assigned to register: s8
14@r6    = external global i32 ; assigned to register: s9
15@r7    = external global i32 ; assigned to register: s10
16@splim = external global i32 ; assigned to register: s11
17
18@f1 = external global float  ; assigned to register: fs0
19@f2 = external global float  ; assigned to register: fs1
20@f3 = external global float  ; assigned to register: fs2
21@f4 = external global float  ; assigned to register: fs3
22@f5 = external global float  ; assigned to register: fs4
23@f6 = external global float  ; assigned to register: fs5
24
25@d1 = external global double ; assigned to register: fs6
26@d2 = external global double ; assigned to register: fs7
27@d3 = external global double ; assigned to register: fs8
28@d4 = external global double ; assigned to register: fs9
29@d5 = external global double ; assigned to register: fs10
30@d6 = external global double ; assigned to register: fs11
31
32define ghccc void @foo() nounwind {
33; CHECK-LABEL: foo:
34; CHECK:       # %bb.0: # %entry
35; CHECK-NEXT:    lui a0, %hi(d6)
36; CHECK-NEXT:    fld fs11, %lo(d6)(a0)
37; CHECK-NEXT:    lui a0, %hi(d5)
38; CHECK-NEXT:    fld fs10, %lo(d5)(a0)
39; CHECK-NEXT:    lui a0, %hi(d4)
40; CHECK-NEXT:    fld fs9, %lo(d4)(a0)
41; CHECK-NEXT:    lui a0, %hi(d3)
42; CHECK-NEXT:    fld fs8, %lo(d3)(a0)
43; CHECK-NEXT:    lui a0, %hi(d2)
44; CHECK-NEXT:    fld fs7, %lo(d2)(a0)
45; CHECK-NEXT:    lui a0, %hi(d1)
46; CHECK-NEXT:    fld fs6, %lo(d1)(a0)
47; CHECK-NEXT:    lui a0, %hi(f6)
48; CHECK-NEXT:    flw fs5, %lo(f6)(a0)
49; CHECK-NEXT:    lui a0, %hi(f5)
50; CHECK-NEXT:    flw fs4, %lo(f5)(a0)
51; CHECK-NEXT:    lui a0, %hi(f4)
52; CHECK-NEXT:    flw fs3, %lo(f4)(a0)
53; CHECK-NEXT:    lui a0, %hi(f3)
54; CHECK-NEXT:    flw fs2, %lo(f3)(a0)
55; CHECK-NEXT:    lui a0, %hi(f2)
56; CHECK-NEXT:    flw fs1, %lo(f2)(a0)
57; CHECK-NEXT:    lui a0, %hi(f1)
58; CHECK-NEXT:    flw fs0, %lo(f1)(a0)
59; CHECK-NEXT:    lui a0, %hi(splim)
60; CHECK-NEXT:    lw s11, %lo(splim)(a0)
61; CHECK-NEXT:    lui a0, %hi(r7)
62; CHECK-NEXT:    lw s10, %lo(r7)(a0)
63; CHECK-NEXT:    lui a0, %hi(r6)
64; CHECK-NEXT:    lw s9, %lo(r6)(a0)
65; CHECK-NEXT:    lui a0, %hi(r5)
66; CHECK-NEXT:    lw s8, %lo(r5)(a0)
67; CHECK-NEXT:    lui a0, %hi(r4)
68; CHECK-NEXT:    lw s7, %lo(r4)(a0)
69; CHECK-NEXT:    lui a0, %hi(r3)
70; CHECK-NEXT:    lw s6, %lo(r3)(a0)
71; CHECK-NEXT:    lui a0, %hi(r2)
72; CHECK-NEXT:    lw s5, %lo(r2)(a0)
73; CHECK-NEXT:    lui a0, %hi(r1)
74; CHECK-NEXT:    lw s4, %lo(r1)(a0)
75; CHECK-NEXT:    lui a0, %hi(hp)
76; CHECK-NEXT:    lw s3, %lo(hp)(a0)
77; CHECK-NEXT:    lui a0, %hi(sp)
78; CHECK-NEXT:    lw s2, %lo(sp)(a0)
79; CHECK-NEXT:    lui a0, %hi(base)
80; CHECK-NEXT:    lw s1, %lo(base)(a0)
81; CHECK-NEXT:    tail bar
82entry:
83  %0  = load double, double* @d6
84  %1  = load double, double* @d5
85  %2  = load double, double* @d4
86  %3  = load double, double* @d3
87  %4  = load double, double* @d2
88  %5  = load double, double* @d1
89  %6  = load float, float* @f6
90  %7  = load float, float* @f5
91  %8  = load float, float* @f4
92  %9  = load float, float* @f3
93  %10 = load float, float* @f2
94  %11 = load float, float* @f1
95  %12 = load i32, i32* @splim
96  %13 = load i32, i32* @r7
97  %14 = load i32, i32* @r6
98  %15 = load i32, i32* @r5
99  %16 = load i32, i32* @r4
100  %17 = load i32, i32* @r3
101  %18 = load i32, i32* @r2
102  %19 = load i32, i32* @r1
103  %20 = load i32, i32* @hp
104  %21 = load i32, i32* @sp
105  %22 = load i32, i32* @base
106  tail call ghccc void @bar(i32 %22, i32 %21, i32 %20, i32 %19, i32 %18, i32 %17, i32 %16, i32 %15, i32 %14, i32 %13, i32 %12,
107                            float %11, float %10, float %9, float %8, float %7, float %6,
108                            double %5, double %4, double %3, double %2, double %1, double %0) nounwind
109  ret void
110}
111
112declare ghccc void @bar(i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32,
113                        float, float, float, float, float, float,
114                        double, double, double, double, double, double)
115