summaryrefslogtreecommitdiff
path: root/test/CodeGen/AArch64/machine-outliner.mir
blob: ee3daf11c9f73ff2946fa7e28176921c29633d77 (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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# RUN: llc -mtriple=aarch64--- -run-pass=machine-outliner %s -o - | FileCheck %s
--- |

  define i32 @main() #0 {
    ret i32 0
  }
  
  define void @bar(i32 %a) #0 {
    ret void
  }
  
  attributes #0 = { noinline noredzone "no-frame-pointer-elim"="true" }
...
---
# This test ensures that we
# - Create outlined functions
# - Don't outline anything to do with LR or W30
# - Save LR when it's not available
#
# CHECK-LABEL: name: main
# CHECK: BL @OUTLINED_FUNCTION_[[F0:[0-9]+]]
# CHECK-NEXT: early-clobber %sp, %lr = LDRXpost %sp, 16
# CHECK-NEXT: STRHHroW %w16, %x9, %w30, 1, 1
# CHECK-NEXT: %lr = ORRXri %xzr, 1
# CHECK: BL @OUTLINED_FUNCTION_[[F0]]
# CHECK-NEXT: early-clobber %sp, %lr = LDRXpost %sp, 16
# CHECK-NEXT: STRHHroW %w16, %x9, %w30, 1, 1
# CHECK-NEXT: %lr = ORRXri %xzr, 1
# CHECK: BL @OUTLINED_FUNCTION_[[F0]]
# CHECK-NEXT: early-clobber %sp, %lr = LDRXpost %sp, 16
# CHECK-NEXT: STRHHroW %w16, %x9, %w30, 1, 1
# CHECK-NEXT: %lr = ORRXri %xzr, 1
name:            main
body:             |
  bb.0:
    %sp = frame-setup SUBXri %sp, 16, 0
    %x9 = ORRXri %xzr, 1
    %w16 = ORRWri %wzr, 1
    %w30 = ORRWri %wzr, 1
    %lr = ORRXri %xzr, 1

    %x20, %x19 = LDPXi %sp, 10
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    STRHHroW %w16, %x9, %w30, 1, 1
    %lr = ORRXri %xzr, 1

    %w3 = ORRWri %wzr, 1993

    %x20, %x19 = LDPXi %sp, 10
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    STRHHroW %w16, %x9, %w30, 1, 1
    %lr = ORRXri %xzr, 1

    %w4 = ORRWri %wzr, 1994

    %x20, %x19 = LDPXi %sp, 10
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    %w16 = ORRWri %wzr, 1
    STRHHroW %w16, %x9, %w30, 1, 1
    %lr = ORRXri %xzr, 1

    %sp = ADDXri %sp, 16, 0
    RET undef %lr

...
---
# This test ensures that we can avoid saving LR when it's available.
# CHECK-LABEL: bb.1:
# CHECK: BL @OUTLINED_FUNCTION_[[F1:[0-9]+]], implicit-def %lr, implicit %sp
# CHECK-NEXT: %w17 = ORRWri %wzr, 2
# CHECK-NEXT: BL @OUTLINED_FUNCTION_[[F1]], implicit-def %lr, implicit %sp
# CHECK-NEXT: %w8 = ORRWri %wzr, 0
name:            bar
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: %w0, %lr, %w8
    %sp = frame-setup SUBXri %sp, 32, 0
    %fp = frame-setup ADDXri %sp, 16, 0

  bb.1:
    %w17 = ORRWri %wzr, 1
    %w17 = ORRWri %wzr, 1
    %w17 = ORRWri %wzr, 1
    %w17 = ORRWri %wzr, 1
    %w17 = ORRWri %wzr, 2
    %w17 = ORRWri %wzr, 1
    %w17 = ORRWri %wzr, 1
    %w17 = ORRWri %wzr, 1
    %w17 = ORRWri %wzr, 1
    %w8 = ORRWri %wzr, 0
  
  bb.2:
    %fp, %lr = LDPXi %sp, 2
    %sp = ADDXri %sp, 32, 0
    RET undef %lr

...

# CHECK-LABEL: name:            OUTLINED_FUNCTION_{{[0-9]}}
# CHECK=LABEL: name:            OUTLINED_FUNCTION_{{[1-9]}}