xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/fp128-calling-conv.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -O2 -mtriple=x86_64-linux-android -mattr=+mmx | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -O2 -mtriple=x86_64-linux-gnu -mattr=+mmx | FileCheck %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker; __float128 myFP128 = 1.0L;  // x86_64-linux-android
5*9880d681SAndroid Build Coastguard Worker@myFP128 = global fp128 0xL00000000000000003FFF000000000000, align 16
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Worker; The first few parameters are passed in registers and the other are on stack.
8*9880d681SAndroid Build Coastguard Worker
9*9880d681SAndroid Build Coastguard Workerdefine fp128 @TestParam_FP128_0(fp128 %d0, fp128 %d1, fp128 %d2, fp128 %d3, fp128 %d4, fp128 %d5, fp128 %d6, fp128 %d7, fp128 %d8, fp128 %d9, fp128 %d10, fp128 %d11, fp128 %d12, fp128 %d13, fp128 %d14, fp128 %d15, fp128 %d16, fp128 %d17, fp128 %d18, fp128 %d19) {
10*9880d681SAndroid Build Coastguard Workerentry:
11*9880d681SAndroid Build Coastguard Worker  ret fp128 %d0
12*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: TestParam_FP128_0:
13*9880d681SAndroid Build Coastguard Worker; CHECK-NOT:   mov
14*9880d681SAndroid Build Coastguard Worker; CHECK:       retq
15*9880d681SAndroid Build Coastguard Worker}
16*9880d681SAndroid Build Coastguard Worker
17*9880d681SAndroid Build Coastguard Workerdefine fp128 @TestParam_FP128_1(fp128 %d0, fp128 %d1, fp128 %d2, fp128 %d3, fp128 %d4, fp128 %d5, fp128 %d6, fp128 %d7, fp128 %d8, fp128 %d9, fp128 %d10, fp128 %d11, fp128 %d12, fp128 %d13, fp128 %d14, fp128 %d15, fp128 %d16, fp128 %d17, fp128 %d18, fp128 %d19) {
18*9880d681SAndroid Build Coastguard Workerentry:
19*9880d681SAndroid Build Coastguard Worker  ret fp128 %d1
20*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: TestParam_FP128_1:
21*9880d681SAndroid Build Coastguard Worker; CHECK:       movaps  %xmm1, %xmm0
22*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:  retq
23*9880d681SAndroid Build Coastguard Worker}
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Workerdefine fp128 @TestParam_FP128_7(fp128 %d0, fp128 %d1, fp128 %d2, fp128 %d3, fp128 %d4, fp128 %d5, fp128 %d6, fp128 %d7, fp128 %d8, fp128 %d9, fp128 %d10, fp128 %d11, fp128 %d12, fp128 %d13, fp128 %d14, fp128 %d15, fp128 %d16, fp128 %d17, fp128 %d18, fp128 %d19) {
26*9880d681SAndroid Build Coastguard Workerentry:
27*9880d681SAndroid Build Coastguard Worker  ret fp128 %d7
28*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: TestParam_FP128_7:
29*9880d681SAndroid Build Coastguard Worker; CHECK:       movaps  %xmm7, %xmm0
30*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:  retq
31*9880d681SAndroid Build Coastguard Worker}
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Workerdefine fp128 @TestParam_FP128_8(fp128 %d0, fp128 %d1, fp128 %d2, fp128 %d3, fp128 %d4, fp128 %d5, fp128 %d6, fp128 %d7, fp128 %d8, fp128 %d9, fp128 %d10, fp128 %d11, fp128 %d12, fp128 %d13, fp128 %d14, fp128 %d15, fp128 %d16, fp128 %d17, fp128 %d18, fp128 %d19) {
34*9880d681SAndroid Build Coastguard Workerentry:
35*9880d681SAndroid Build Coastguard Worker  ret fp128 %d8
36*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: TestParam_FP128_8:
37*9880d681SAndroid Build Coastguard Worker; CHECK:       movaps 8(%rsp), %xmm0
38*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:  retq
39*9880d681SAndroid Build Coastguard Worker}
40*9880d681SAndroid Build Coastguard Worker
41*9880d681SAndroid Build Coastguard Workerdefine fp128 @TestParam_FP128_9(fp128 %d0, fp128 %d1, fp128 %d2, fp128 %d3, fp128 %d4, fp128 %d5, fp128 %d6, fp128 %d7, fp128 %d8, fp128 %d9, fp128 %d10, fp128 %d11, fp128 %d12, fp128 %d13, fp128 %d14, fp128 %d15, fp128 %d16, fp128 %d17, fp128 %d18, fp128 %d19) {
42*9880d681SAndroid Build Coastguard Workerentry:
43*9880d681SAndroid Build Coastguard Worker  ret fp128 %d9
44*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: TestParam_FP128_9:
45*9880d681SAndroid Build Coastguard Worker; CHECK:       movaps 24(%rsp), %xmm0
46*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:  retq
47*9880d681SAndroid Build Coastguard Worker}
48