xref: /llvm-project/llvm/test/CodeGen/SystemZ/systemz-large-stack-frames.ll (revision 1de1818fabb474d724741ee28baa5a7e1d972b00)
1; REQUIRES: asserts
2; REQUIRES: systemz-registered-target
3; Used to fail with: LLVM ERROR: Error while trying to spill R5D from class ADDR64Bit: Cannot scavenge register without an emergency spill slot!
4
5
6; RUN: llc %s --mtriple s390x-ibm-zos -filetype obj -o %t
7
8; ModuleID = 'main.cpp'
9source_filename = "main.cpp"
10target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128"
11target triple = "x86_64-unknown-linux-gnu"
12
13; ModuleID = 'large-stack-frames.cpp'
14source_filename = "large-stack-frames.cpp"
15target datalayout = "E-m:l-p1:32:32-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64"
16target triple = "s390x-ibm-zos"
17%struct.slice.108 = type { ptr, ptr, [8 x i64], [8 x i64], [8 x i64] }
18declare void @dealloc(ptr) local_unnamed_addr #0
19define internal void @foo([26 x i64] %co1, [26 x i64] %co2, [26 x i64] %co3, [26 x i64] %co4, [26 x i64] %co5, [26 x i64] %co6, [26 x i64] %co7, [26 x i64] %co8, i32 %skip_dispatch, ptr %0, i1 %1) #0 {
20entry:
21  %ref.tmp = alloca %struct.slice.108, align 8
22  br i1 %1, label %error, label %if.end95
23if.end95:
24  br i1 %1, label %if.else.i1546, label %object.exit1547
25if.else.i1546:
26  tail call void @dealloc(ptr noundef nonnull %0)
27  br label %object.exit1547
28object.exit1547:
29  %call96 = tail call fastcc noundef ptr @slice([26 x i64] inreg %co7, i32 noundef signext 1, ptr noundef nonnull @get_float, ptr noundef nonnull @object, i32 noundef signext 0)
30  ret void
31error:
32  ret void
33}
34declare dso_local fastcc ptr @slice([26 x i64], i32, ptr, ptr, i32) unnamed_addr #0
35define internal ptr @get_float(ptr %itemp, ptr %2) #0 {
36entry:
37  ret ptr %2
38}
39define internal i32 @object(ptr %itemp, ptr %obj) #0 {
40entry:
41  ret i32 1
42}
43