xref: /aosp_15_r20/external/llvm/test/CodeGen/PowerPC/ppc64-fastcc-fast-isel.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mcpu=pwr7 -mattr=-vsx -fast-isel -fast-isel-abort=1 < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Workertarget datalayout = "E-m:e-i64:64-n32:64"
3*9880d681SAndroid Build Coastguard Workertarget triple = "powerpc64-unknown-linux-gnu"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine fastcc i64 @g1(i64 %g1, double %f1, i64 %g2, double %f2, i64 %g3, double %f3, i64 %g4, double %f4) #0 {
6*9880d681SAndroid Build Coastguard Worker  ret i64 %g1
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @g1
9*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: mr 3,
10*9880d681SAndroid Build Coastguard Worker; CHECK: blr
11*9880d681SAndroid Build Coastguard Worker}
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Workerdefine fastcc i64 @g2(i64 %g1, double %f1, i64 %g2, double %f2, i64 %g3, double %f3, i64 %g4, double %f4) #0 {
14*9880d681SAndroid Build Coastguard Worker  ret i64 %g2
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @g2
17*9880d681SAndroid Build Coastguard Worker; CHECK: mr 3, 4
18*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: blr
19*9880d681SAndroid Build Coastguard Worker}
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Workerdefine fastcc i64 @g3(i64 %g1, double %f1, i64 %g2, double %f2, i64 %g3, double %f3, i64 %g4, double %f4) #0 {
22*9880d681SAndroid Build Coastguard Worker  ret i64 %g3
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @g3
25*9880d681SAndroid Build Coastguard Worker; CHECK: mr 3, 5
26*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: blr
27*9880d681SAndroid Build Coastguard Worker}
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Workerdefine fastcc double @f2(i64 %g1, double %f1, i64 %g2, double %f2, i64 %g3, double %f3, i64 %g4, double %f4) #0 {
30*9880d681SAndroid Build Coastguard Worker  ret double %f2
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @f2
33*9880d681SAndroid Build Coastguard Worker; CHECK: fmr 1, 2
34*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: blr
35*9880d681SAndroid Build Coastguard Worker}
36*9880d681SAndroid Build Coastguard Worker
37*9880d681SAndroid Build Coastguard Workerdefine void @cg2(i64 %v) #0 {
38*9880d681SAndroid Build Coastguard Worker  call fastcc i64 @g1(i64 0, double 0.0, i64 %v, double 0.0, i64 0, double 0.0, i64 0, double 0.0)
39*9880d681SAndroid Build Coastguard Worker  ret void
40*9880d681SAndroid Build Coastguard Worker
41*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @cg2
42*9880d681SAndroid Build Coastguard Worker; CHECK: mr 4, 3
43*9880d681SAndroid Build Coastguard Worker; CHECK: blr
44*9880d681SAndroid Build Coastguard Worker}
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Workerdefine void @cf2(double %v) #0 {
47*9880d681SAndroid Build Coastguard Worker  call fastcc i64 @g1(i64 0, double 0.0, i64 0, double %v, i64 0, double 0.0, i64 0, double 0.0)
48*9880d681SAndroid Build Coastguard Worker  ret void
49*9880d681SAndroid Build Coastguard Worker
50*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @cf2
51*9880d681SAndroid Build Coastguard Worker; CHECK: fmr 2, 1
52*9880d681SAndroid Build Coastguard Worker; CHECK: blr
53*9880d681SAndroid Build Coastguard Worker}
54*9880d681SAndroid Build Coastguard Worker
55*9880d681SAndroid Build Coastguard Workerattributes #0 = { nounwind }
56*9880d681SAndroid Build Coastguard Worker
57