Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / M68k / Atomics / load-store.ll
blob7608edb220d3c9042b2384f2213682b1e274c91f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc %s -o - -mtriple=m68k -mcpu=M68000 | FileCheck %s --check-prefix=NO-ATOMIC
3 ; RUN: llc %s -o - -mtriple=m68k -mcpu=M68010 | FileCheck %s --check-prefix=NO-ATOMIC
4 ; RUN: llc %s -o - -mtriple=m68k -mcpu=M68020 | FileCheck %s --check-prefix=ATOMIC
5 ; RUN: llc %s -o - -mtriple=m68k -mcpu=M68030 | FileCheck %s --check-prefix=ATOMIC
6 ; RUN: llc %s -o - -mtriple=m68k -mcpu=M68040 | FileCheck %s --check-prefix=ATOMIC
8 define i8 @atomic_load_i8_unordered(i8 *%a) nounwind {
9 ; NO-ATOMIC-LABEL: atomic_load_i8_unordered:
10 ; NO-ATOMIC:       ; %bb.0:
11 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
12 ; NO-ATOMIC-NEXT:    move.b (%a0), %d0
13 ; NO-ATOMIC-NEXT:    rts
15 ; ATOMIC-LABEL: atomic_load_i8_unordered:
16 ; ATOMIC:       ; %bb.0:
17 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
18 ; ATOMIC-NEXT:    move.b (%a0), %d0
19 ; ATOMIC-NEXT:    rts
20   %1 = load atomic i8, i8* %a unordered, align 1
21   ret i8 %1
24 define i8 @atomic_load_i8_monotonic(i8 *%a) nounwind {
25 ; NO-ATOMIC-LABEL: atomic_load_i8_monotonic:
26 ; NO-ATOMIC:       ; %bb.0:
27 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
28 ; NO-ATOMIC-NEXT:    move.b (%a0), %d0
29 ; NO-ATOMIC-NEXT:    rts
31 ; ATOMIC-LABEL: atomic_load_i8_monotonic:
32 ; ATOMIC:       ; %bb.0:
33 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
34 ; ATOMIC-NEXT:    move.b (%a0), %d0
35 ; ATOMIC-NEXT:    rts
36   %1 = load atomic i8, i8* %a monotonic, align 1
37   ret i8 %1
40 define i8 @atomic_load_i8_acquire(i8 *%a) nounwind {
41 ; NO-ATOMIC-LABEL: atomic_load_i8_acquire:
42 ; NO-ATOMIC:       ; %bb.0:
43 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
44 ; NO-ATOMIC-NEXT:    move.b (%a0), %d0
45 ; NO-ATOMIC-NEXT:    rts
47 ; ATOMIC-LABEL: atomic_load_i8_acquire:
48 ; ATOMIC:       ; %bb.0:
49 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
50 ; ATOMIC-NEXT:    move.b (%a0), %d0
51 ; ATOMIC-NEXT:    rts
52   %1 = load atomic i8, i8* %a acquire, align 1
53   ret i8 %1
56 define i8 @atomic_load_i8_seq_cst(i8 *%a) nounwind {
57 ; NO-ATOMIC-LABEL: atomic_load_i8_seq_cst:
58 ; NO-ATOMIC:       ; %bb.0:
59 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
60 ; NO-ATOMIC-NEXT:    move.b (%a0), %d0
61 ; NO-ATOMIC-NEXT:    rts
63 ; ATOMIC-LABEL: atomic_load_i8_seq_cst:
64 ; ATOMIC:       ; %bb.0:
65 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
66 ; ATOMIC-NEXT:    move.b (%a0), %d0
67 ; ATOMIC-NEXT:    rts
68   %1 = load atomic i8, i8* %a seq_cst, align 1
69   ret i8 %1
72 define i16 @atomic_load_i16_unordered(i16 *%a) nounwind {
73 ; NO-ATOMIC-LABEL: atomic_load_i16_unordered:
74 ; NO-ATOMIC:       ; %bb.0:
75 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
76 ; NO-ATOMIC-NEXT:    move.w (%a0), %d0
77 ; NO-ATOMIC-NEXT:    rts
79 ; ATOMIC-LABEL: atomic_load_i16_unordered:
80 ; ATOMIC:       ; %bb.0:
81 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
82 ; ATOMIC-NEXT:    move.w (%a0), %d0
83 ; ATOMIC-NEXT:    rts
84   %1 = load atomic i16, i16* %a unordered, align 2
85   ret i16 %1
88 define i16 @atomic_load_i16_monotonic(i16 *%a) nounwind {
89 ; NO-ATOMIC-LABEL: atomic_load_i16_monotonic:
90 ; NO-ATOMIC:       ; %bb.0:
91 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
92 ; NO-ATOMIC-NEXT:    move.w (%a0), %d0
93 ; NO-ATOMIC-NEXT:    rts
95 ; ATOMIC-LABEL: atomic_load_i16_monotonic:
96 ; ATOMIC:       ; %bb.0:
97 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
98 ; ATOMIC-NEXT:    move.w (%a0), %d0
99 ; ATOMIC-NEXT:    rts
100   %1 = load atomic i16, i16* %a monotonic, align 2
101   ret i16 %1
104 define i16 @atomic_load_i16_acquire(i16 *%a) nounwind {
105 ; NO-ATOMIC-LABEL: atomic_load_i16_acquire:
106 ; NO-ATOMIC:       ; %bb.0:
107 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
108 ; NO-ATOMIC-NEXT:    move.w (%a0), %d0
109 ; NO-ATOMIC-NEXT:    rts
111 ; ATOMIC-LABEL: atomic_load_i16_acquire:
112 ; ATOMIC:       ; %bb.0:
113 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
114 ; ATOMIC-NEXT:    move.w (%a0), %d0
115 ; ATOMIC-NEXT:    rts
116   %1 = load atomic i16, i16* %a acquire, align 2
117   ret i16 %1
120 define i16 @atomic_load_i16_seq_cst(i16 *%a) nounwind {
121 ; NO-ATOMIC-LABEL: atomic_load_i16_seq_cst:
122 ; NO-ATOMIC:       ; %bb.0:
123 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
124 ; NO-ATOMIC-NEXT:    move.w (%a0), %d0
125 ; NO-ATOMIC-NEXT:    rts
127 ; ATOMIC-LABEL: atomic_load_i16_seq_cst:
128 ; ATOMIC:       ; %bb.0:
129 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
130 ; ATOMIC-NEXT:    move.w (%a0), %d0
131 ; ATOMIC-NEXT:    rts
132   %1 = load atomic i16, i16* %a seq_cst, align 2
133   ret i16 %1
136 define i32 @atomic_load_i32_unordered(i32 *%a) nounwind {
137 ; NO-ATOMIC-LABEL: atomic_load_i32_unordered:
138 ; NO-ATOMIC:       ; %bb.0:
139 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
140 ; NO-ATOMIC-NEXT:    move.l (%a0), %d0
141 ; NO-ATOMIC-NEXT:    rts
143 ; ATOMIC-LABEL: atomic_load_i32_unordered:
144 ; ATOMIC:       ; %bb.0:
145 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
146 ; ATOMIC-NEXT:    move.l (%a0), %d0
147 ; ATOMIC-NEXT:    rts
148   %1 = load atomic i32, i32* %a unordered, align 4
149   ret i32 %1
152 define i32 @atomic_load_i32_monotonic(i32 *%a) nounwind {
153 ; NO-ATOMIC-LABEL: atomic_load_i32_monotonic:
154 ; NO-ATOMIC:       ; %bb.0:
155 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
156 ; NO-ATOMIC-NEXT:    move.l (%a0), %d0
157 ; NO-ATOMIC-NEXT:    rts
159 ; ATOMIC-LABEL: atomic_load_i32_monotonic:
160 ; ATOMIC:       ; %bb.0:
161 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
162 ; ATOMIC-NEXT:    move.l (%a0), %d0
163 ; ATOMIC-NEXT:    rts
164   %1 = load atomic i32, i32* %a monotonic, align 4
165   ret i32 %1
168 define i32 @atomic_load_i32_acquire(i32 *%a) nounwind {
169 ; NO-ATOMIC-LABEL: atomic_load_i32_acquire:
170 ; NO-ATOMIC:       ; %bb.0:
171 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
172 ; NO-ATOMIC-NEXT:    move.l (%a0), %d0
173 ; NO-ATOMIC-NEXT:    rts
175 ; ATOMIC-LABEL: atomic_load_i32_acquire:
176 ; ATOMIC:       ; %bb.0:
177 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
178 ; ATOMIC-NEXT:    move.l (%a0), %d0
179 ; ATOMIC-NEXT:    rts
180   %1 = load atomic i32, i32* %a acquire, align 4
181   ret i32 %1
184 define i32 @atomic_load_i32_seq_cst(i32 *%a) nounwind {
185 ; NO-ATOMIC-LABEL: atomic_load_i32_seq_cst:
186 ; NO-ATOMIC:       ; %bb.0:
187 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
188 ; NO-ATOMIC-NEXT:    move.l (%a0), %d0
189 ; NO-ATOMIC-NEXT:    rts
191 ; ATOMIC-LABEL: atomic_load_i32_seq_cst:
192 ; ATOMIC:       ; %bb.0:
193 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
194 ; ATOMIC-NEXT:    move.l (%a0), %d0
195 ; ATOMIC-NEXT:    rts
196   %1 = load atomic i32, i32* %a seq_cst, align 4
197   ret i32 %1
200 define i64 @atomic_load_i64_unordered(i64 *%a) nounwind {
201 ; NO-ATOMIC-LABEL: atomic_load_i64_unordered:
202 ; NO-ATOMIC:       ; %bb.0:
203 ; NO-ATOMIC-NEXT:    suba.l #12, %sp
204 ; NO-ATOMIC-NEXT:    move.l #0, (4,%sp)
205 ; NO-ATOMIC-NEXT:    move.l (16,%sp), (%sp)
206 ; NO-ATOMIC-NEXT:    jsr __atomic_load_8@PLT
207 ; NO-ATOMIC-NEXT:    adda.l #12, %sp
208 ; NO-ATOMIC-NEXT:    rts
210 ; ATOMIC-LABEL: atomic_load_i64_unordered:
211 ; ATOMIC:       ; %bb.0:
212 ; ATOMIC-NEXT:    suba.l #12, %sp
213 ; ATOMIC-NEXT:    move.l #0, (4,%sp)
214 ; ATOMIC-NEXT:    move.l (16,%sp), (%sp)
215 ; ATOMIC-NEXT:    jsr __atomic_load_8@PLT
216 ; ATOMIC-NEXT:    adda.l #12, %sp
217 ; ATOMIC-NEXT:    rts
218   %1 = load atomic i64, i64* %a unordered, align 8
219   ret i64 %1
222 define i64 @atomic_load_i64_monotonic(i64 *%a) nounwind {
223 ; NO-ATOMIC-LABEL: atomic_load_i64_monotonic:
224 ; NO-ATOMIC:       ; %bb.0:
225 ; NO-ATOMIC-NEXT:    suba.l #12, %sp
226 ; NO-ATOMIC-NEXT:    move.l #0, (4,%sp)
227 ; NO-ATOMIC-NEXT:    move.l (16,%sp), (%sp)
228 ; NO-ATOMIC-NEXT:    jsr __atomic_load_8@PLT
229 ; NO-ATOMIC-NEXT:    adda.l #12, %sp
230 ; NO-ATOMIC-NEXT:    rts
232 ; ATOMIC-LABEL: atomic_load_i64_monotonic:
233 ; ATOMIC:       ; %bb.0:
234 ; ATOMIC-NEXT:    suba.l #12, %sp
235 ; ATOMIC-NEXT:    move.l #0, (4,%sp)
236 ; ATOMIC-NEXT:    move.l (16,%sp), (%sp)
237 ; ATOMIC-NEXT:    jsr __atomic_load_8@PLT
238 ; ATOMIC-NEXT:    adda.l #12, %sp
239 ; ATOMIC-NEXT:    rts
240   %1 = load atomic i64, i64* %a monotonic, align 8
241   ret i64 %1
244 define i64 @atomic_load_i64_acquire(i64 *%a) nounwind {
245 ; NO-ATOMIC-LABEL: atomic_load_i64_acquire:
246 ; NO-ATOMIC:       ; %bb.0:
247 ; NO-ATOMIC-NEXT:    suba.l #12, %sp
248 ; NO-ATOMIC-NEXT:    move.l #2, (4,%sp)
249 ; NO-ATOMIC-NEXT:    move.l (16,%sp), (%sp)
250 ; NO-ATOMIC-NEXT:    jsr __atomic_load_8@PLT
251 ; NO-ATOMIC-NEXT:    adda.l #12, %sp
252 ; NO-ATOMIC-NEXT:    rts
254 ; ATOMIC-LABEL: atomic_load_i64_acquire:
255 ; ATOMIC:       ; %bb.0:
256 ; ATOMIC-NEXT:    suba.l #12, %sp
257 ; ATOMIC-NEXT:    move.l #2, (4,%sp)
258 ; ATOMIC-NEXT:    move.l (16,%sp), (%sp)
259 ; ATOMIC-NEXT:    jsr __atomic_load_8@PLT
260 ; ATOMIC-NEXT:    adda.l #12, %sp
261 ; ATOMIC-NEXT:    rts
262   %1 = load atomic i64, i64* %a acquire, align 8
263   ret i64 %1
266 define i64 @atomic_load_i64_seq_cst(i64 *%a) nounwind {
267 ; NO-ATOMIC-LABEL: atomic_load_i64_seq_cst:
268 ; NO-ATOMIC:       ; %bb.0:
269 ; NO-ATOMIC-NEXT:    suba.l #12, %sp
270 ; NO-ATOMIC-NEXT:    move.l #5, (4,%sp)
271 ; NO-ATOMIC-NEXT:    move.l (16,%sp), (%sp)
272 ; NO-ATOMIC-NEXT:    jsr __atomic_load_8@PLT
273 ; NO-ATOMIC-NEXT:    adda.l #12, %sp
274 ; NO-ATOMIC-NEXT:    rts
276 ; ATOMIC-LABEL: atomic_load_i64_seq_cst:
277 ; ATOMIC:       ; %bb.0:
278 ; ATOMIC-NEXT:    suba.l #12, %sp
279 ; ATOMIC-NEXT:    move.l #5, (4,%sp)
280 ; ATOMIC-NEXT:    move.l (16,%sp), (%sp)
281 ; ATOMIC-NEXT:    jsr __atomic_load_8@PLT
282 ; ATOMIC-NEXT:    adda.l #12, %sp
283 ; ATOMIC-NEXT:    rts
284   %1 = load atomic i64, i64* %a seq_cst, align 8
285   ret i64 %1
288 define void @atomic_store_i8_unordered(i8 *%a, i8 %val) nounwind {
289 ; NO-ATOMIC-LABEL: atomic_store_i8_unordered:
290 ; NO-ATOMIC:       ; %bb.0:
291 ; NO-ATOMIC-NEXT:    move.b (11,%sp), %d0
292 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
293 ; NO-ATOMIC-NEXT:    move.b %d0, (%a0)
294 ; NO-ATOMIC-NEXT:    rts
296 ; ATOMIC-LABEL: atomic_store_i8_unordered:
297 ; ATOMIC:       ; %bb.0:
298 ; ATOMIC-NEXT:    move.b (11,%sp), %d0
299 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
300 ; ATOMIC-NEXT:    move.b %d0, (%a0)
301 ; ATOMIC-NEXT:    rts
302   store atomic i8 %val, i8* %a unordered, align 1
303   ret void
306 define void @atomic_store_i8_monotonic(i8 *%a, i8 %val) nounwind {
307 ; NO-ATOMIC-LABEL: atomic_store_i8_monotonic:
308 ; NO-ATOMIC:       ; %bb.0:
309 ; NO-ATOMIC-NEXT:    move.b (11,%sp), %d0
310 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
311 ; NO-ATOMIC-NEXT:    move.b %d0, (%a0)
312 ; NO-ATOMIC-NEXT:    rts
314 ; ATOMIC-LABEL: atomic_store_i8_monotonic:
315 ; ATOMIC:       ; %bb.0:
316 ; ATOMIC-NEXT:    move.b (11,%sp), %d0
317 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
318 ; ATOMIC-NEXT:    move.b %d0, (%a0)
319 ; ATOMIC-NEXT:    rts
320   store atomic i8 %val, i8* %a monotonic, align 1
321   ret void
324 define void @atomic_store_i8_release(i8 *%a, i8 %val) nounwind {
325 ; NO-ATOMIC-LABEL: atomic_store_i8_release:
326 ; NO-ATOMIC:       ; %bb.0:
327 ; NO-ATOMIC-NEXT:    move.b (11,%sp), %d0
328 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
329 ; NO-ATOMIC-NEXT:    move.b %d0, (%a0)
330 ; NO-ATOMIC-NEXT:    rts
332 ; ATOMIC-LABEL: atomic_store_i8_release:
333 ; ATOMIC:       ; %bb.0:
334 ; ATOMIC-NEXT:    move.b (11,%sp), %d0
335 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
336 ; ATOMIC-NEXT:    move.b %d0, (%a0)
337 ; ATOMIC-NEXT:    rts
338   store atomic i8 %val, i8* %a release, align 1
339   ret void
342 define void @atomic_store_i8_seq_cst(i8 *%a, i8 %val) nounwind {
343 ; NO-ATOMIC-LABEL: atomic_store_i8_seq_cst:
344 ; NO-ATOMIC:       ; %bb.0:
345 ; NO-ATOMIC-NEXT:    move.b (11,%sp), %d0
346 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
347 ; NO-ATOMIC-NEXT:    move.b %d0, (%a0)
348 ; NO-ATOMIC-NEXT:    rts
350 ; ATOMIC-LABEL: atomic_store_i8_seq_cst:
351 ; ATOMIC:       ; %bb.0:
352 ; ATOMIC-NEXT:    move.b (11,%sp), %d0
353 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
354 ; ATOMIC-NEXT:    move.b %d0, (%a0)
355 ; ATOMIC-NEXT:    rts
356   store atomic i8 %val, i8* %a seq_cst, align 1
357   ret void
360 define void @atomic_store_i16_unordered(i16 *%a, i16 %val) nounwind {
361 ; NO-ATOMIC-LABEL: atomic_store_i16_unordered:
362 ; NO-ATOMIC:       ; %bb.0:
363 ; NO-ATOMIC-NEXT:    move.w (10,%sp), %d0
364 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
365 ; NO-ATOMIC-NEXT:    move.w %d0, (%a0)
366 ; NO-ATOMIC-NEXT:    rts
368 ; ATOMIC-LABEL: atomic_store_i16_unordered:
369 ; ATOMIC:       ; %bb.0:
370 ; ATOMIC-NEXT:    move.w (10,%sp), %d0
371 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
372 ; ATOMIC-NEXT:    move.w %d0, (%a0)
373 ; ATOMIC-NEXT:    rts
374   store atomic i16 %val, i16* %a unordered, align 2
375   ret void
378 define void @atomic_store_i16_monotonic(i16 *%a, i16 %val) nounwind {
379 ; NO-ATOMIC-LABEL: atomic_store_i16_monotonic:
380 ; NO-ATOMIC:       ; %bb.0:
381 ; NO-ATOMIC-NEXT:    move.w (10,%sp), %d0
382 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
383 ; NO-ATOMIC-NEXT:    move.w %d0, (%a0)
384 ; NO-ATOMIC-NEXT:    rts
386 ; ATOMIC-LABEL: atomic_store_i16_monotonic:
387 ; ATOMIC:       ; %bb.0:
388 ; ATOMIC-NEXT:    move.w (10,%sp), %d0
389 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
390 ; ATOMIC-NEXT:    move.w %d0, (%a0)
391 ; ATOMIC-NEXT:    rts
392   store atomic i16 %val, i16* %a monotonic, align 2
393   ret void
396 define void @atomic_store_i16_release(i16 *%a, i16 %val) nounwind {
397 ; NO-ATOMIC-LABEL: atomic_store_i16_release:
398 ; NO-ATOMIC:       ; %bb.0:
399 ; NO-ATOMIC-NEXT:    move.w (10,%sp), %d0
400 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
401 ; NO-ATOMIC-NEXT:    move.w %d0, (%a0)
402 ; NO-ATOMIC-NEXT:    rts
404 ; ATOMIC-LABEL: atomic_store_i16_release:
405 ; ATOMIC:       ; %bb.0:
406 ; ATOMIC-NEXT:    move.w (10,%sp), %d0
407 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
408 ; ATOMIC-NEXT:    move.w %d0, (%a0)
409 ; ATOMIC-NEXT:    rts
410   store atomic i16 %val, i16* %a release, align 2
411   ret void
414 define void @atomic_store_i16_seq_cst(i16 *%a, i16 %val) nounwind {
415 ; NO-ATOMIC-LABEL: atomic_store_i16_seq_cst:
416 ; NO-ATOMIC:       ; %bb.0:
417 ; NO-ATOMIC-NEXT:    move.w (10,%sp), %d0
418 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
419 ; NO-ATOMIC-NEXT:    move.w %d0, (%a0)
420 ; NO-ATOMIC-NEXT:    rts
422 ; ATOMIC-LABEL: atomic_store_i16_seq_cst:
423 ; ATOMIC:       ; %bb.0:
424 ; ATOMIC-NEXT:    move.w (10,%sp), %d0
425 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
426 ; ATOMIC-NEXT:    move.w %d0, (%a0)
427 ; ATOMIC-NEXT:    rts
428   store atomic i16 %val, i16* %a seq_cst, align 2
429   ret void
432 define void @atomic_store_i32_unordered(i32 *%a, i32 %val) nounwind {
433 ; NO-ATOMIC-LABEL: atomic_store_i32_unordered:
434 ; NO-ATOMIC:       ; %bb.0:
435 ; NO-ATOMIC-NEXT:    move.l (8,%sp), %d0
436 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
437 ; NO-ATOMIC-NEXT:    move.l %d0, (%a0)
438 ; NO-ATOMIC-NEXT:    rts
440 ; ATOMIC-LABEL: atomic_store_i32_unordered:
441 ; ATOMIC:       ; %bb.0:
442 ; ATOMIC-NEXT:    move.l (8,%sp), %d0
443 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
444 ; ATOMIC-NEXT:    move.l %d0, (%a0)
445 ; ATOMIC-NEXT:    rts
446   store atomic i32 %val, i32* %a unordered, align 4
447   ret void
450 define void @atomic_store_i32_monotonic(i32 *%a, i32 %val) nounwind {
451 ; NO-ATOMIC-LABEL: atomic_store_i32_monotonic:
452 ; NO-ATOMIC:       ; %bb.0:
453 ; NO-ATOMIC-NEXT:    move.l (8,%sp), %d0
454 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
455 ; NO-ATOMIC-NEXT:    move.l %d0, (%a0)
456 ; NO-ATOMIC-NEXT:    rts
458 ; ATOMIC-LABEL: atomic_store_i32_monotonic:
459 ; ATOMIC:       ; %bb.0:
460 ; ATOMIC-NEXT:    move.l (8,%sp), %d0
461 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
462 ; ATOMIC-NEXT:    move.l %d0, (%a0)
463 ; ATOMIC-NEXT:    rts
464   store atomic i32 %val, i32* %a monotonic, align 4
465   ret void
468 define void @atomic_store_i32_release(i32 *%a, i32 %val) nounwind {
469 ; NO-ATOMIC-LABEL: atomic_store_i32_release:
470 ; NO-ATOMIC:       ; %bb.0:
471 ; NO-ATOMIC-NEXT:    move.l (8,%sp), %d0
472 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
473 ; NO-ATOMIC-NEXT:    move.l %d0, (%a0)
474 ; NO-ATOMIC-NEXT:    rts
476 ; ATOMIC-LABEL: atomic_store_i32_release:
477 ; ATOMIC:       ; %bb.0:
478 ; ATOMIC-NEXT:    move.l (8,%sp), %d0
479 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
480 ; ATOMIC-NEXT:    move.l %d0, (%a0)
481 ; ATOMIC-NEXT:    rts
482   store atomic i32 %val, i32* %a release, align 4
483   ret void
486 define void @atomic_store_i32_seq_cst(i32 *%a, i32 %val) nounwind {
487 ; NO-ATOMIC-LABEL: atomic_store_i32_seq_cst:
488 ; NO-ATOMIC:       ; %bb.0:
489 ; NO-ATOMIC-NEXT:    move.l (8,%sp), %d0
490 ; NO-ATOMIC-NEXT:    move.l (4,%sp), %a0
491 ; NO-ATOMIC-NEXT:    move.l %d0, (%a0)
492 ; NO-ATOMIC-NEXT:    rts
494 ; ATOMIC-LABEL: atomic_store_i32_seq_cst:
495 ; ATOMIC:       ; %bb.0:
496 ; ATOMIC-NEXT:    move.l (8,%sp), %d0
497 ; ATOMIC-NEXT:    move.l (4,%sp), %a0
498 ; ATOMIC-NEXT:    move.l %d0, (%a0)
499 ; ATOMIC-NEXT:    rts
500   store atomic i32 %val, i32* %a seq_cst, align 4
501   ret void
504 define void @atomic_store_i64_unordered(i64 *%a, i64 %val) nounwind {
505 ; NO-ATOMIC-LABEL: atomic_store_i64_unordered:
506 ; NO-ATOMIC:       ; %bb.0:
507 ; NO-ATOMIC-NEXT:    suba.l #20, %sp
508 ; NO-ATOMIC-NEXT:    move.l #0, (12,%sp)
509 ; NO-ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
510 ; NO-ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
511 ; NO-ATOMIC-NEXT:    move.l (24,%sp), (%sp)
512 ; NO-ATOMIC-NEXT:    jsr __atomic_store_8@PLT
513 ; NO-ATOMIC-NEXT:    adda.l #20, %sp
514 ; NO-ATOMIC-NEXT:    rts
516 ; ATOMIC-LABEL: atomic_store_i64_unordered:
517 ; ATOMIC:       ; %bb.0:
518 ; ATOMIC-NEXT:    suba.l #20, %sp
519 ; ATOMIC-NEXT:    move.l #0, (12,%sp)
520 ; ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
521 ; ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
522 ; ATOMIC-NEXT:    move.l (24,%sp), (%sp)
523 ; ATOMIC-NEXT:    jsr __atomic_store_8@PLT
524 ; ATOMIC-NEXT:    adda.l #20, %sp
525 ; ATOMIC-NEXT:    rts
526   store atomic i64 %val, i64* %a unordered, align 8
527   ret void
530 define void @atomic_store_i64_monotonic(i64 *%a, i64 %val) nounwind {
531 ; NO-ATOMIC-LABEL: atomic_store_i64_monotonic:
532 ; NO-ATOMIC:       ; %bb.0:
533 ; NO-ATOMIC-NEXT:    suba.l #20, %sp
534 ; NO-ATOMIC-NEXT:    move.l #0, (12,%sp)
535 ; NO-ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
536 ; NO-ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
537 ; NO-ATOMIC-NEXT:    move.l (24,%sp), (%sp)
538 ; NO-ATOMIC-NEXT:    jsr __atomic_store_8@PLT
539 ; NO-ATOMIC-NEXT:    adda.l #20, %sp
540 ; NO-ATOMIC-NEXT:    rts
542 ; ATOMIC-LABEL: atomic_store_i64_monotonic:
543 ; ATOMIC:       ; %bb.0:
544 ; ATOMIC-NEXT:    suba.l #20, %sp
545 ; ATOMIC-NEXT:    move.l #0, (12,%sp)
546 ; ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
547 ; ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
548 ; ATOMIC-NEXT:    move.l (24,%sp), (%sp)
549 ; ATOMIC-NEXT:    jsr __atomic_store_8@PLT
550 ; ATOMIC-NEXT:    adda.l #20, %sp
551 ; ATOMIC-NEXT:    rts
552   store atomic i64 %val, i64* %a monotonic, align 8
553   ret void
556 define void @atomic_store_i64_release(i64 *%a, i64 %val) nounwind {
557 ; NO-ATOMIC-LABEL: atomic_store_i64_release:
558 ; NO-ATOMIC:       ; %bb.0:
559 ; NO-ATOMIC-NEXT:    suba.l #20, %sp
560 ; NO-ATOMIC-NEXT:    move.l #3, (12,%sp)
561 ; NO-ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
562 ; NO-ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
563 ; NO-ATOMIC-NEXT:    move.l (24,%sp), (%sp)
564 ; NO-ATOMIC-NEXT:    jsr __atomic_store_8@PLT
565 ; NO-ATOMIC-NEXT:    adda.l #20, %sp
566 ; NO-ATOMIC-NEXT:    rts
568 ; ATOMIC-LABEL: atomic_store_i64_release:
569 ; ATOMIC:       ; %bb.0:
570 ; ATOMIC-NEXT:    suba.l #20, %sp
571 ; ATOMIC-NEXT:    move.l #3, (12,%sp)
572 ; ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
573 ; ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
574 ; ATOMIC-NEXT:    move.l (24,%sp), (%sp)
575 ; ATOMIC-NEXT:    jsr __atomic_store_8@PLT
576 ; ATOMIC-NEXT:    adda.l #20, %sp
577 ; ATOMIC-NEXT:    rts
578   store atomic i64 %val, i64* %a release, align 8
579   ret void
582 define void @atomic_store_i64_seq_cst(i64 *%a, i64 %val) nounwind {
583 ; NO-ATOMIC-LABEL: atomic_store_i64_seq_cst:
584 ; NO-ATOMIC:       ; %bb.0:
585 ; NO-ATOMIC-NEXT:    suba.l #20, %sp
586 ; NO-ATOMIC-NEXT:    move.l #5, (12,%sp)
587 ; NO-ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
588 ; NO-ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
589 ; NO-ATOMIC-NEXT:    move.l (24,%sp), (%sp)
590 ; NO-ATOMIC-NEXT:    jsr __atomic_store_8@PLT
591 ; NO-ATOMIC-NEXT:    adda.l #20, %sp
592 ; NO-ATOMIC-NEXT:    rts
594 ; ATOMIC-LABEL: atomic_store_i64_seq_cst:
595 ; ATOMIC:       ; %bb.0:
596 ; ATOMIC-NEXT:    suba.l #20, %sp
597 ; ATOMIC-NEXT:    move.l #5, (12,%sp)
598 ; ATOMIC-NEXT:    move.l (32,%sp), (8,%sp)
599 ; ATOMIC-NEXT:    move.l (28,%sp), (4,%sp)
600 ; ATOMIC-NEXT:    move.l (24,%sp), (%sp)
601 ; ATOMIC-NEXT:    jsr __atomic_store_8@PLT
602 ; ATOMIC-NEXT:    adda.l #20, %sp
603 ; ATOMIC-NEXT:    rts
604   store atomic i64 %val, i64* %a seq_cst, align 8
605   ret void