Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / CodeGen / SystemZ / systemz-large-stack-frames.ll
blob51997a6c17c658498c5361061c791d937cd2cbff
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!
6 ; RUN: llc %s --mtriple s390x-ibm-zos -filetype obj -o %t
8 ; ModuleID = 'main.cpp'
9 source_filename = "main.cpp"
10 target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128"
11 target triple = "x86_64-unknown-linux-gnu"
13 ; ModuleID = 'large-stack-frames.cpp'
14 source_filename = "large-stack-frames.cpp"
15 target datalayout = "E-m:l-p1:32:32-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64"
16 target triple = "s390x-ibm-zos"
17 %struct.slice.108 = type { ptr, ptr, [8 x i64], [8 x i64], [8 x i64] }
18 declare void @dealloc(ptr) local_unnamed_addr #0
19 define 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 {
20 entry:
21   %ref.tmp = alloca %struct.slice.108, align 8
22   br i1 %1, label %error, label %if.end95
23 if.end95:
24   br i1 %1, label %if.else.i1546, label %object.exit1547
25 if.else.i1546:
26   tail call void @dealloc(ptr noundef nonnull %0)
27   br label %object.exit1547
28 object.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
31 error:
32   ret void
34 declare dso_local fastcc ptr @slice([26 x i64], i32, ptr, ptr, i32) unnamed_addr #0
35 define internal ptr @get_float(ptr %itemp, ptr %2) #0 {
36 entry:
37   ret ptr %2
39 define internal i32 @object(ptr %itemp, ptr %obj) #0 {
40 entry:
41   ret i32 1