File: shrink-wrap-frame-pointer.ll

package info (click to toggle)
llvm-toolchain-21 1%3A21.1.6-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,245,028 kB
  • sloc: cpp: 7,619,726; ansic: 1,434,018; asm: 1,058,748; python: 252,740; f90: 94,671; objc: 70,685; lisp: 42,813; pascal: 18,401; sh: 8,601; ml: 5,111; perl: 4,720; makefile: 3,675; awk: 3,523; javascript: 2,409; xml: 892; fortran: 770
file content (96 lines) | stat: -rw-r--r-- 3,658 bytes parent folder | download | duplicates (2)
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
}