aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/PowerPC/shrink-wrap-frame-pointer.ll
blob: 1b30a56253b75d2ccc72665b4ae665cde159433f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
; Test file to verify the prologue and epilogue insertion point computation by the shrink-wrap pass

; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64le-unknown-unknown -mcpu=pwr9 | FileCheck %s --check-prefixes=POWERPC64
; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc-ibm-aix-xcoff -mcpu=pwr9 | FileCheck %s --check-prefixes=POWERPC32-AIX
; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64-ibm-aix-xcoff -mcpu=pwr9 | FileCheck %s --check-prefixes=POWERPC64-AIX

define void @foo(ptr noundef readnone %parent_frame_pointer) {
; POWERPC64-LABEL:      foo
; POWERPC64:            # %bb.0:
; POWERPC64:                mflr [[REG1:[0-9]+]]
; POWERPC64-NEXT:           stdu 1, -32(1)
; POWERPC64-NEXT:           std [[REG1]], 48(1)
; POWERPC64:                cmpld [[REG2:[0-9]+]], 1
; POWERPC64:            # %bb.1:
; POWERPC64-NEXT:           addi 1, 1, 32
; POWERPC64-NEXT:           ld [[REG1]], 16(1)
; POWERPC64-NEXT:           mtlr [[REG1]]
; POWERPC64-NEXT:           blr

; POWERPC32-AIX-LABEL:  .foo:
; POWERPC32-AIX:        # %bb.0:
; POWERPC32-AIX-NEXT:       mflr [[REG1:[0-9]+]]
; POWERPC32-AIX-NEXT:       stwu 1, -64(1)
; POWERPC32-AIX-NEXT:       cmplw [[REG2:[0-9]+]], 1
; POWERPC32-AIX:        # %bb.1:
; POWERPC32-AIX-NEXT:       addi 1, 1, 64
; POWERPC32-AIX-NEXT:       lwz [[REG1]], 8(1)
; POWERPC32-AIX-NEXT:       mtlr [[REG1]]
; POWERPC32-AIX-NEXT:       blr

; POWERPC64-AIX-LABEL:  .foo:
; POWERPC64-AIX:        # %bb.0:
; POWERPC64-AIX-NEXT:       mflr [[REG1:[0-9]+]]
; POWERPC64-AIX-NEXT:       stdu 1, -112(1)
; POWERPC64-AIX-NEXT:       cmpld [[REG2:[0-9]+]], 1
; POWERPC64-AIX:        # %bb.1:
; POWERPC64-AIX-NEXT:       addi 1, 1, 112
; POWERPC64-AIX-NEXT:       ld [[REG1]], 16(1)
; POWERPC64-AIX-NEXT:       mtlr [[REG1]]
; POWERPC64-AIX-NEXT:       blr

entry:
  %frameaddress = tail call ptr @llvm.frameaddress.p0(i32 0)
  %cmp = icmp ugt ptr %parent_frame_pointer, %frameaddress
  br i1 %cmp, label %cond.end, label %cond.false

cond.false:                                       ; preds = %entry
  tail call void @abort()
  unreachable

cond.end:                                         ; preds = %entry
  ret void
}

declare ptr @llvm.frameaddress.p0(i32 immarg)
declare void @abort()

define noundef i32 @main() {
; POWERPC64-LABEL:      main
; POWERPC64:            # %bb.0:
; POWERPC64-NEXT:           mflr [[REG1:[0-9]+]]
; POWERPC64-NEXT:           stdu 1, -32(1)
; POWERPC64-NEXT:           std [[REG1]], 48(1)
; POWERPC64:                mr [[REG2:[0-9]+]], 1
; POWERPC64:                addi 1, 1, 32
; POWERPC64-NEXT:           ld [[REG1]], 16(1)
; POWERPC64-NEXT:           mtlr [[REG1]]
; POWERPC64-NEXT:           blr

; POWERPC32-AIX-LABEL:  .main:
; POWERPC32-AIX:        # %bb.0:
; POWERPC32-AIX-NEXT:       mflr [[REG1:[0-9]+]]
; POWERPC32-AIX-NEXT:       stwu 1, -64(1)
; POWERPC32-AIX-NEXT:       mr [[REG2:[0-9]+]], 1
; POWERPC32-AIX-NEXT:       stw [[REG1]], 72(1)
; POWERPC32-AIX:            addi 1, 1, 64
; POWERPC32-AIX-NEXT:       lwz [[REG1]], 8(1)
; POWERPC32-AIX-NEXT:       mtlr [[REG1]]
; POWERPC32-AIX-NEXT:       blr

; POWERPC64-AIX-LABEL: .main:
; POWERPC64-AIX:       # %bb.0:
; POWERPC64-AIX-NEXT:       mflr [[REG1:[0-9]+]]
; POWERPC64-AIX-NEXT:       stdu 1, -112(1)
; POWERPC64-AIX-NEXT:       mr [[REG2:[0-9]+]], 1
; POWERPC64-AIX-NEXT:       std [[REG1]], 128(1)
; POWERPC64-AIX:            addi 1, 1, 112
; POWERPC64-AIX-NEXT:       ld [[REG1]], 16(1)
; POWERPC64-AIX-NEXT:       mtlr [[REG1]]
; POWERPC64-AIX-NEXT:       blr

entry:
  %frameaddress = tail call ptr @llvm.frameaddress.p0(i32 0)
  tail call void @foo(ptr noundef %frameaddress)
  ret i32 0
}