xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/ghc-cc64.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -tailcallopt -mtriple=x86_64-linux-gnu | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; Check the GHC call convention works (x86-64)
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker@base  = external global i64 ; assigned to register: R13
6*9880d681SAndroid Build Coastguard Worker@sp    = external global i64 ; assigned to register: RBP
7*9880d681SAndroid Build Coastguard Worker@hp    = external global i64 ; assigned to register: R12
8*9880d681SAndroid Build Coastguard Worker@r1    = external global i64 ; assigned to register: RBX
9*9880d681SAndroid Build Coastguard Worker@r2    = external global i64 ; assigned to register: R14
10*9880d681SAndroid Build Coastguard Worker@r3    = external global i64 ; assigned to register: RSI
11*9880d681SAndroid Build Coastguard Worker@r4    = external global i64 ; assigned to register: RDI
12*9880d681SAndroid Build Coastguard Worker@r5    = external global i64 ; assigned to register: R8
13*9880d681SAndroid Build Coastguard Worker@r6    = external global i64 ; assigned to register: R9
14*9880d681SAndroid Build Coastguard Worker@splim = external global i64 ; assigned to register: R15
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Worker@f1 = external global float  ; assigned to register: XMM1
17*9880d681SAndroid Build Coastguard Worker@f2 = external global float  ; assigned to register: XMM2
18*9880d681SAndroid Build Coastguard Worker@f3 = external global float  ; assigned to register: XMM3
19*9880d681SAndroid Build Coastguard Worker@f4 = external global float  ; assigned to register: XMM4
20*9880d681SAndroid Build Coastguard Worker@d1 = external global double ; assigned to register: XMM5
21*9880d681SAndroid Build Coastguard Worker@d2 = external global double ; assigned to register: XMM6
22*9880d681SAndroid Build Coastguard Worker
23*9880d681SAndroid Build Coastguard Workerdefine void @zap(i64 %a, i64 %b) nounwind {
24*9880d681SAndroid Build Coastguard Workerentry:
25*9880d681SAndroid Build Coastguard Worker  ; CHECK:      movq %rdi, %r13
26*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq %rsi, %rbp
27*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: callq addtwo
28*9880d681SAndroid Build Coastguard Worker  %0 = call ghccc i64 @addtwo(i64 %a, i64 %b)
29*9880d681SAndroid Build Coastguard Worker  ; CHECK:      callq foo
30*9880d681SAndroid Build Coastguard Worker  call void @foo() nounwind
31*9880d681SAndroid Build Coastguard Worker  ret void
32*9880d681SAndroid Build Coastguard Worker}
33*9880d681SAndroid Build Coastguard Worker
34*9880d681SAndroid Build Coastguard Workerdefine ghccc i64 @addtwo(i64 %x, i64 %y) nounwind {
35*9880d681SAndroid Build Coastguard Workerentry:
36*9880d681SAndroid Build Coastguard Worker  ; CHECK:      leaq (%r13,%rbp), %rax
37*9880d681SAndroid Build Coastguard Worker  %0 = add i64 %x, %y
38*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: ret
39*9880d681SAndroid Build Coastguard Worker  ret i64 %0
40*9880d681SAndroid Build Coastguard Worker}
41*9880d681SAndroid Build Coastguard Worker
42*9880d681SAndroid Build Coastguard Workerdefine ghccc void @foo() nounwind {
43*9880d681SAndroid Build Coastguard Workerentry:
44*9880d681SAndroid Build Coastguard Worker  ; CHECK:      movsd d2(%rip), %xmm6
45*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movsd d1(%rip), %xmm5
46*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movss f4(%rip), %xmm4
47*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movss f3(%rip), %xmm3
48*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movss f2(%rip), %xmm2
49*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movss f1(%rip), %xmm1
50*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq splim(%rip), %r15
51*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq r6(%rip), %r9
52*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq r5(%rip), %r8
53*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq r4(%rip), %rdi
54*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq r3(%rip), %rsi
55*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq r2(%rip), %r14
56*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq r1(%rip), %rbx
57*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq hp(%rip), %r12
58*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq sp(%rip), %rbp
59*9880d681SAndroid Build Coastguard Worker  ; CHECK-NEXT: movq base(%rip), %r13
60*9880d681SAndroid Build Coastguard Worker  %0 = load double, double* @d2
61*9880d681SAndroid Build Coastguard Worker  %1 = load double, double* @d1
62*9880d681SAndroid Build Coastguard Worker  %2 = load float, float* @f4
63*9880d681SAndroid Build Coastguard Worker  %3 = load float, float* @f3
64*9880d681SAndroid Build Coastguard Worker  %4 = load float, float* @f2
65*9880d681SAndroid Build Coastguard Worker  %5 = load float, float* @f1
66*9880d681SAndroid Build Coastguard Worker  %6 = load i64, i64* @splim
67*9880d681SAndroid Build Coastguard Worker  %7 = load i64, i64* @r6
68*9880d681SAndroid Build Coastguard Worker  %8 = load i64, i64* @r5
69*9880d681SAndroid Build Coastguard Worker  %9 = load i64, i64* @r4
70*9880d681SAndroid Build Coastguard Worker  %10 = load i64, i64* @r3
71*9880d681SAndroid Build Coastguard Worker  %11 = load i64, i64* @r2
72*9880d681SAndroid Build Coastguard Worker  %12 = load i64, i64* @r1
73*9880d681SAndroid Build Coastguard Worker  %13 = load i64, i64* @hp
74*9880d681SAndroid Build Coastguard Worker  %14 = load i64, i64* @sp
75*9880d681SAndroid Build Coastguard Worker  %15 = load i64, i64* @base
76*9880d681SAndroid Build Coastguard Worker  ; CHECK: jmp bar
77*9880d681SAndroid Build Coastguard Worker  tail call ghccc void @bar( i64 %15, i64 %14, i64 %13, i64 %12, i64 %11,
78*9880d681SAndroid Build Coastguard Worker                             i64 %10, i64 %9, i64 %8, i64 %7, i64 %6,
79*9880d681SAndroid Build Coastguard Worker                             float %5, float %4, float %3, float %2, double %1,
80*9880d681SAndroid Build Coastguard Worker                             double %0 ) nounwind
81*9880d681SAndroid Build Coastguard Worker  ret void
82*9880d681SAndroid Build Coastguard Worker}
83*9880d681SAndroid Build Coastguard Worker
84*9880d681SAndroid Build Coastguard Workerdeclare ghccc void @bar(i64, i64, i64, i64, i64, i64, i64, i64, i64, i64,
85*9880d681SAndroid Build Coastguard Worker                        float, float, float, float, double, double)
86