Revert r354244 "[DAGCombiner] Eliminate dead stores to stack."
[llvm-complete.git] / test / CodeGen / ARM / ldstrex-m.ll
blob713fb9e3df011ab1b64bcb746398dc82bb1ceafb
1 ; RUN: llc < %s -mtriple=thumbv7m-none-eabi -mcpu=cortex-m4 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-V7
2 ; RUN: llc < %s -mtriple=thumbv8m.main-none-eabi | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-V8
3 ; RUN: llc < %s -mtriple=thumbv8m.base-none-eabi | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-V8
5 ; CHECK-LABEL: f0:
6 ; CHECK-NOT: ldrexd
7 define i64 @f0(i64* %p) nounwind readonly {
8 entry:
9   %0 = load atomic i64, i64* %p seq_cst, align 8
10   ret i64 %0
13 ; CHECK-LABEL: f1:
14 ; CHECK-NOT: strexd
15 define void @f1(i64* %p) nounwind readonly {
16 entry:
17   store atomic i64 0, i64* %p seq_cst, align 8
18   ret void
21 ; CHECK-LABEL: f2:
22 ; CHECK-NOT: ldrexd
23 ; CHECK-NOT: strexd
24 define i64 @f2(i64* %p) nounwind readonly {
25 entry:
26   %0 = atomicrmw add i64* %p, i64 1 seq_cst
27   ret i64 %0
30 ; CHECK-LABEL: f3:
31 ; CHECK-V7: ldr
32 ; CHECK-V8: lda
33 define i32 @f3(i32* %p) nounwind readonly {
34 entry:
35   %0 = load atomic i32, i32* %p seq_cst, align 4
36   ret i32 %0
39 ; CHECK-LABEL: f4:
40 ; CHECK-V7: ldrb
41 ; CHECK-V8: ldab
42 define i8 @f4(i8* %p) nounwind readonly {
43 entry:
44   %0 = load atomic i8, i8* %p seq_cst, align 4
45   ret i8 %0
48 ; CHECK-LABEL: f5:
49 ; CHECK-V7: str
50 ; CHECK-V8: stl
51 define void @f5(i32* %p) nounwind readonly {
52 entry:
53   store atomic i32 0, i32* %p seq_cst, align 4
54   ret void
57 ; CHECK-LABEL: f6:
58 ; CHECK-V7: ldrex
59 ; CHECK-V7: strex
60 ; CHECK-V8: ldaex
61 ; CHECK-V8: stlex
62 define i32 @f6(i32* %p) nounwind readonly {
63 entry:
64   %0 = atomicrmw add i32* %p, i32 1 seq_cst
65   ret i32 %0