Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / LoongArch / ghc-cc.ll
blob0ab125e875b9964dc46e89d99b5ee3c20590d82e
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
4 ; Check the GHC call convention works (la64)
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
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
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
26 define ghccc void @foo() nounwind {
27 ; LA64-LABEL: foo:
28 ; LA64:       # %bb.0: # %entry
29 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(base)
30 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(base)
31 ; LA64-NEXT:    ld.d $s0, $a0, 0
32 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(sp)
33 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(sp)
34 ; LA64-NEXT:    ld.d $s1, $a0, 0
35 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(hp)
36 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(hp)
37 ; LA64-NEXT:    ld.d $s2, $a0, 0
38 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r1)
39 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(r1)
40 ; LA64-NEXT:    ld.d $s3, $a0, 0
41 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r2)
42 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(r2)
43 ; LA64-NEXT:    ld.d $s4, $a0, 0
44 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r3)
45 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(r3)
46 ; LA64-NEXT:    ld.d $s5, $a0, 0
47 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r4)
48 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(r4)
49 ; LA64-NEXT:    ld.d $s6, $a0, 0
50 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(r5)
51 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(r5)
52 ; LA64-NEXT:    ld.d $s7, $a0, 0
53 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(splim)
54 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(splim)
55 ; LA64-NEXT:    ld.d $s8, $a0, 0
56 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f1)
57 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(f1)
58 ; LA64-NEXT:    fld.s $fs0, $a0, 0
59 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f2)
60 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(f2)
61 ; LA64-NEXT:    fld.s $fs1, $a0, 0
62 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f3)
63 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(f3)
64 ; LA64-NEXT:    fld.s $fs2, $a0, 0
65 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(f4)
66 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(f4)
67 ; LA64-NEXT:    fld.s $fs3, $a0, 0
68 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d1)
69 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(d1)
70 ; LA64-NEXT:    fld.d $fs4, $a0, 0
71 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d2)
72 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(d2)
73 ; LA64-NEXT:    fld.d $fs5, $a0, 0
74 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d3)
75 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(d3)
76 ; LA64-NEXT:    fld.d $fs6, $a0, 0
77 ; LA64-NEXT:    pcalau12i $a0, %pc_hi20(d4)
78 ; LA64-NEXT:    addi.d $a0, $a0, %pc_lo12(d4)
79 ; LA64-NEXT:    fld.d $fs7, $a0, 0
80 ; LA64-NEXT:    b %plt(bar)
82 entry:
83   %0  = load double, ptr @d4
84   %1  = load double, ptr @d3
85   %2  = load double, ptr @d2
86   %3  = load double, ptr @d1
87   %4  = load float, ptr @f4
88   %5  = load float, ptr @f3
89   %6 = load float, ptr @f2
90   %7 = load float, ptr @f1
91   %8 = load i64, ptr @splim
92   %9 = load i64, ptr @r5
93   %10 = load i64, ptr @r4
94   %11 = load i64, ptr @r3
95   %12 = load i64, ptr @r2
96   %13 = load i64, ptr @r1
97   %14 = load i64, ptr @hp
98   %15 = load i64, ptr @sp
99   %16 = load i64, ptr @base
100   tail call ghccc void @bar(i64 %16, i64 %15, i64 %14, i64 %13, i64 %12,
101                             i64 %11, i64 %10, i64 %9, i64 %8, float %7, float %6,
102                             float %5, float %4, double %3, double %2, double %1, double %0) nounwind
103   ret void
105 declare ghccc void @bar(i64, i64, i64, i64, i64, i64, i64, i64, i64,
106                         float, float, float, float,
107                         double, double, double, double)