Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / MC / ARM / ltorg-darwin.s
blobe62aceaa6d271e80a238f671f21601395bf37ea0
1 @ This test has a partner (ltorg.s) that contains matching
2 @ tests for the .ltorg on linux targets. We need separate files
3 @ because the syntax for switching sections and temporary labels differs
4 @ between darwin and linux. Any tests added here should have a matching
5 @ test added there.
7 @RUN: llvm-mc -triple armv7-apple-darwin %s | FileCheck %s
8 @RUN: llvm-mc -triple thumbv5-apple-darwin %s | FileCheck %s
9 @RUN: llvm-mc -triple thumbv7-apple-darwin %s | FileCheck %s
11 @ check that ltorg dumps the constant pool at the current location
12 .section __TEXT,a,regular,pure_instructions
13 @ CHECK-LABEL: f2:
14 f2:
15 ldr r0, =0x10002
16 @ CHECK: ldr r0, Ltmp0
17 adds r0, r0, #1
18 adds r0, r0, #1
19 b f3
20 .ltorg
21 @ constant pool
22 @ CHECK: .data_region
23 @ CHECK: .p2align 2
24 @ CHECK-LABEL: Ltmp0:
25 @ CHECK: .long 65538
26 @ CHECK: .end_data_region
28 @ CHECK-LABEL: f3:
29 f3:
30 adds r0, r0, #1
31 adds r0, r0, #1
33 @ check that ltorg clears the constant pool after dumping it
34 .section __TEXT,b,regular,pure_instructions
35 @ CHECK-LABEL: f4:
36 f4:
37 ldr r0, =0x10003
38 @ CHECK: ldr r0, Ltmp1
39 adds r0, r0, #1
40 adds r0, r0, #1
41 b f5
42 .ltorg
43 @ constant pool
44 @ CHECK: .data_region
45 @ CHECK: .p2align 2
46 @ CHECK-LABEL: Ltmp1:
47 @ CHECK: .long 65539
48 @ CHECK: .end_data_region
50 @ CHECK-LABEL: f5:
51 f5:
52 adds r0, r0, #1
53 adds r0, r0, #1
54 ldr r0, =0x10004
55 @ CHECK: ldr r0, Ltmp2
56 adds r0, r0, #1
57 b f6
58 .ltorg
59 @ constant pool
60 @ CHECK: .data_region
61 @ CHECK: .p2align 2
62 @ CHECK-LABEL: Ltmp2:
63 @ CHECK: .long 65540
64 @ CHECK: .end_data_region
66 @ CHECK-LABEL: f6:
67 f6:
68 adds r0, r0, #1
69 adds r0, r0, #1
71 @ check that ltorg does not issue an error if there is no constant pool
72 .section __TEXT,c,regular,pure_instructions
73 @ CHECK-LABEL: f7:
74 f7:
75 adds r0, r0, #1
76 b f8
77 .ltorg
78 f8:
79 adds r0, r0, #1
81 @ check that ltorg works for labels
82 .section __TEXT,d,regular,pure_instructions
83 @ CHECK-LABEL: f9:
84 f9:
85 adds r0, r0, #1
86 adds r0, r0, #1
87 ldr r0, =bar
88 @ CHECK: ldr r0, Ltmp3
89 adds r0, r0, #1
90 adds r0, r0, #1
91 adds r0, r0, #1
92 b f10
93 .ltorg
94 @ constant pool
95 @ CHECK: .data_region
96 @ CHECK: .p2align 2
97 @ CHECK-LABEL: Ltmp3:
98 @ CHECK: .long bar
99 @ CHECK: .end_data_region
101 @ CHECK-LABEL: f10:
102 f10:
103 adds r0, r0, #1
104 adds r0, r0, #1
106 @ check that use of ltorg does not prevent dumping non-empty constant pools at end of section
107 .section __TEXT,e,regular,pure_instructions
108 @ CHECK-LABEL: f11:
109 f11:
110 adds r0, r0, #1
111 adds r0, r0, #1
112 ldr r0, =0x10005
113 @ CHECK: ldr r0, Ltmp4
114 b f12
115 .ltorg
116 @ constant pool
117 @ CHECK: .data_region
118 @ CHECK: .p2align 2
119 @ CHECK-LABEL: Ltmp4:
120 @ CHECK: .long 65541
121 @ CHECK: .end_data_region
123 @ CHECK-LABEL: f12:
124 f12:
125 adds r0, r0, #1
126 ldr r0, =0x10006
127 @ CHECK: ldr r0, Ltmp5
129 .section __TEXT,f,regular,pure_instructions
130 @ CHECK-LABEL: f13
131 f13:
132 adds r0, r0, #1
133 adds r0, r0, #1
135 @ should not have a constant pool at end of section with empty constant pools
136 @ CHECK-NOT: .section __TEXT,a,regular,pure_instructions
137 @ CHECK-NOT: .section __TEXT,b,regular,pure_instructions
138 @ CHECK-NOT: .section __TEXT,c,regular,pure_instructions
139 @ CHECK-NOT: .section __TEXT,d,regular,pure_instructions
141 @ should have a non-empty constant pool at end of this section
142 @ CHECK: .section __TEXT,e,regular,pure_instructions
143 @ constant pool
144 @ CHECK: .data_region
145 @ CHECK: .p2align 2
146 @ CHECK-LABEL: Ltmp5:
147 @ CHECK: .long 65542
148 @ CHECK: .end_data_region
150 @ should not have a constant pool at end of section with empty constant pools
151 @ CHECK-NOT: .section __TEXT,f,regular,pure_instructions