[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / ARM / machine-outliner-unoutlinable.mir
blobda032019c568365784ca10d0dfc6a3594ad5d625
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=thumbv7-- -run-pass=machine-outliner -verify-machineinstrs \
3 # RUN: %s -o - | FileCheck %s
5 --- |
6   define void @dont_outline_asm() #0 { ret void }
7   define void @dont_outline_lr() #0 { ret void }
8   define void @dont_outline_lr2() #0 { ret void }
9   define void @dont_outline_it() #0 { ret void }
10   define void @dont_outline_pic() #0 { ret void }
11   define void @dont_outline_mve() #0 { ret void }
12   declare void @z(i32, i32, i32, i32)
14   attributes #0 = { minsize optsize }
15 ...
16 ---
18 name:           dont_outline_asm
19 tracksRegLiveness: true
20 body:             |
21   ; CHECK-LABEL: name: dont_outline_asm
22   ; CHECK: bb.0:
23   ; CHECK:   INLINEASM &"movs  r0, #42", 1
24   ; CHECK:   tBL 14 /* CC::al */, $noreg, @OUTLINED_FUNCTION_0
25   ; CHECK: bb.1:
26   ; CHECK:   INLINEASM &"movs  r0, #42", 1
27   ; CHECK:   tBL 14 /* CC::al */, $noreg, @OUTLINED_FUNCTION_0
28   bb.0:
29     INLINEASM &"movs  r0, #42", 1
30     $r0, dead $cpsr = tMOVi8 1, 14, $noreg
31     $r1, dead $cpsr = tMOVi8 1, 14, $noreg
32     $r2, dead $cpsr = tMOVi8 1, 14, $noreg
33     $r3, dead $cpsr = tMOVi8 1, 14, $noreg
34     tBL 14, $noreg, @z
35   bb.1:
36     INLINEASM &"movs  r0, #42", 1
37     $r0, dead $cpsr = tMOVi8 1, 14, $noreg
38     $r1, dead $cpsr = tMOVi8 1, 14, $noreg
39     $r2, dead $cpsr = tMOVi8 1, 14, $noreg
40     $r3, dead $cpsr = tMOVi8 1, 14, $noreg
41     tBL 14, $noreg, @z
42   bb.2:
43     tBX_RET 14, $noreg
44 ...
45 ---
47 name:           dont_outline_lr
48 tracksRegLiveness: true
49 body:             |
50   ; CHECK-LABEL: name: dont_outline_lr
51   ; CHECK-NOT: tBL 14 /* CC::al */, $noreg, @OUTLINED_FUNCTION
52   bb.0:
53     liveins: $lr
54     $r0 = tMOVr $lr, 14, $noreg
55     $r1 = tMOVr $lr, 14, $noreg
56     $r2 = tMOVr $lr, 14, $noreg
57     $r3 = tMOVr $lr, 14, $noreg
58     tBL 14, $noreg, @z
59   bb.1:
60     liveins: $lr
61     $r0 = tMOVr $lr, 14, $noreg
62     $r1 = tMOVr $lr, 14, $noreg
63     $r2 = tMOVr $lr, 14, $noreg
64     $r3 = tMOVr $lr, 14, $noreg
65     tBL 14, $noreg, @z
66   bb.2:
67     tBX_RET 14, $noreg
68 ...
69 ---
71 name:           dont_outline_lr2
72 tracksRegLiveness: true
73 body:             |
74   ; CHECK-LABEL: name: dont_outline_lr2
75   ; CHECK-NOT: tBL 14 /* CC::al */, $noreg, @OUTLINED_FUNCTION
76   bb.0:
77     liveins: $r0
78     $lr = tMOVr $r0, 14, $noreg
79     $r1 = tMOVr $r0, 14, $noreg
80     $r2 = tMOVr $r0, 14, $noreg
81     $r3 = tMOVr $r0, 14, $noreg
82     $r4 = tMOVr $r0, 14, $noreg
83     tBLXr 14, $lr, $noreg
84   bb.1:
85     liveins: $r0
86     $lr = tMOVr $r0, 14, $noreg
87     $r1 = tMOVr $r0, 14, $noreg
88     $r2 = tMOVr $r0, 14, $noreg
89     $r3 = tMOVr $r0, 14, $noreg
90     $r4 = tMOVr $r0, 14, $noreg
91     tBLXr 14, $lr, $noreg
92   bb.2:
93     tBX_RET 14, $noreg
94 ...
95 ---
97 name:           dont_outline_it
98 tracksRegLiveness: true
99 body:             |
100   ; CHECK-LABEL: name: dont_outline_it
101   ; CHECK-NOT: tBL 14 /* CC::al */, $noreg, @OUTLINED_FUNCTION
102   bb.0:
103     t2IT 0, 1, implicit-def $itstate
104     $r0, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
105     $r1, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
106     $r2, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
107     $r3, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
108     tBL 14, $noreg, @z
109   bb.1:
110     t2IT 0, 1, implicit-def $itstate
111     $r0, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
112     $r1, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
113     $r2, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
114     $r3, dead $cpsr = tMOVi8 1, 0, $noreg, implicit $itstate
115     tBL 14, $noreg, @z
116   bb.2:
117     tBX_RET 14, $noreg
121 name:           dont_outline_pic
122 tracksRegLiveness: true
123 body:             |
124   ; CHECK-LABEL: name: dont_outline_pic
125   ; CHECK-NOT: tBL 14 /* CC::al */, $noreg, @OUTLINED_FUNCTION
126   bb.0:
127     $r0 = t2MOVi16_ga_pcrel target-flags(arm-lo16, arm-nonlazy) @z, 0
128     $r0 = t2MOVTi16_ga_pcrel $r0, target-flags(arm-lo16, arm-nonlazy) @z, 0
129     $r0 = PICADD $r0, 1, 14, $noreg
130     $r1 = PICLDR $r0, 2, 14, $noreg
131     PICSTR $r0, $r1, 3, 14, $noreg
132     tBL 14, $noreg, @z
133   bb.1:
134     $r0 = t2MOVi16_ga_pcrel target-flags(arm-lo16, arm-nonlazy) @z, 0
135     $r0 = t2MOVTi16_ga_pcrel $r0, target-flags(arm-lo16, arm-nonlazy) @z, 0
136     $r0 = PICADD $r0, 1, 14, $noreg
137     $r1 = PICLDR $r0, 2, 14, $noreg
138     PICSTR $r0, $r1, 3, 14, $noreg
139     tBL 14, $noreg, @z
140   bb.2:
141     tBX_RET 14, $noreg
145 name:           dont_outline_mve
146 tracksRegLiveness: true
147 body:             |
148   ; CHECK-LABEL: name: dont_outline_mve
149   ; CHECK-NOT: tBL 14 /* CC::al */, $noreg, @OUTLINED_FUNCTION
150   bb.0:
151     liveins: $r3, $r4, $q0, $q3, $q4, $q5
152     $q5 = MVE_VDUP32 $r3, 0, $noreg, $noreg, $q5
153     $q4 = MVE_VDUP32 $r4, 0, $noreg, $noreg, $q4
154     $q0 = MVE_VADDf32 $q4, $q5, 0, $noreg, $noreg, $q0
155     $lr = t2DoLoopStart $r4
156     $r0 = MVE_VMOV_from_lane_32 renamable $q0, 1, 14, $noreg
157     tBL 14, $noreg, @z
158   bb.1:
159     liveins: $r3, $r4, $q0, $q3, $q4, $q5
160     $q5 = MVE_VDUP32 $r3, 0, $noreg, $noreg, $q5
161     $q4 = MVE_VDUP32 $r4, 0, $noreg, $noreg, $q4
162     $q0 = MVE_VADDf32 $q4, $q5, 0, $noreg, $noreg, $q0
163     $lr = t2DoLoopStart $r4
164     $r0 = MVE_VMOV_from_lane_32 renamable $q0, 1, 14, $noreg
165     tBL 14, $noreg, @z
166   bb.2:
167     tBX_RET 14, $noreg