diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2011-08-31 18:26:09 +0000 | 
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2011-08-31 18:26:09 +0000 | 
| commit | 7c3bdede25a09d7bfd677bb724a6a03b16fa90dd (patch) | |
| tree | f2f70839a1a7dbfdd2c5e9de8f6f408e79cbab27 /llvm/test | |
| parent | af8c3cc710eb93f83cbbd00313482b632c12f3a1 (diff) | |
| download | bcm5719-llvm-7c3bdede25a09d7bfd677bb724a6a03b16fa90dd.tar.gz bcm5719-llvm-7c3bdede25a09d7bfd677bb724a6a03b16fa90dd.zip | |
Generic expansion for atomic load/store into cmpxchg/atomicrmw xchg; implements 64-bit atomic load/store for ARM.
llvm-svn: 138872
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/CodeGen/ARM/atomic-64bit.ll | 44 | 
1 files changed, 37 insertions, 7 deletions
| diff --git a/llvm/test/CodeGen/ARM/atomic-64bit.ll b/llvm/test/CodeGen/ARM/atomic-64bit.ll index abe1acc6d11..e9609ac0f9e 100644 --- a/llvm/test/CodeGen/ARM/atomic-64bit.ll +++ b/llvm/test/CodeGen/ARM/atomic-64bit.ll @@ -6,7 +6,7 @@ define i64 @test1(i64* %ptr, i64 %val) {  ; CHECK: ldrexd r2, r3  ; CHECK: adds r0, r2  ; CHECK: adc r1, r3 -; CHECK: strexd {{r[0-9]+}}, r0, r1 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1  ; CHECK: cmp  ; CHECK: bne  ; CHECK: dmb ish @@ -20,7 +20,7 @@ define i64 @test2(i64* %ptr, i64 %val) {  ; CHECK: ldrexd r2, r3  ; CHECK: subs r0, r2  ; CHECK: sbc r1, r3 -; CHECK: strexd {{r[0-9]+}}, r0, r1 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1  ; CHECK: cmp  ; CHECK: bne  ; CHECK: dmb ish @@ -34,7 +34,7 @@ define i64 @test3(i64* %ptr, i64 %val) {  ; CHECK: ldrexd r2, r3  ; CHECK: and r0, r2  ; CHECK: and r1, r3 -; CHECK: strexd {{r[0-9]+}}, r0, r1 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1  ; CHECK: cmp  ; CHECK: bne  ; CHECK: dmb ish @@ -48,7 +48,7 @@ define i64 @test4(i64* %ptr, i64 %val) {  ; CHECK: ldrexd r2, r3  ; CHECK: orr r0, r2  ; CHECK: orr r1, r3 -; CHECK: strexd {{r[0-9]+}}, r0, r1 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1  ; CHECK: cmp  ; CHECK: bne  ; CHECK: dmb ish @@ -62,7 +62,7 @@ define i64 @test5(i64* %ptr, i64 %val) {  ; CHECK: ldrexd r2, r3  ; CHECK: eor r0, r2  ; CHECK: eor r1, r3 -; CHECK: strexd {{r[0-9]+}}, r0, r1 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1  ; CHECK: cmp  ; CHECK: bne  ; CHECK: dmb ish @@ -74,7 +74,7 @@ define i64 @test6(i64* %ptr, i64 %val) {  ; CHECK: test6  ; CHECK: dmb ish  ; CHECK: ldrexd r2, r3 -; CHECK: strexd {{r[0-9]+}}, r0, r1 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1  ; CHECK: cmp  ; CHECK: bne  ; CHECK: dmb ish @@ -89,10 +89,40 @@ define i64 @test7(i64* %ptr, i64 %val1, i64 %val2) {  ; CHECK: cmp r2  ; CHECK: cmpeq r3  ; CHECK: bne -; CHECK: strexd {{r[0-9]+}}, r0, r1 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1  ; CHECK: cmp  ; CHECK: bne  ; CHECK: dmb ish    %r = cmpxchg i64* %ptr, i64 %val1, i64 %val2 seq_cst    ret i64 %r  } + +; Compiles down to cmpxchg +; FIXME: Should compile to a single ldrexd +define i64 @test8(i64* %ptr) { +; CHECK: test8 +; CHECK: ldrexd r2, r3 +; CHECK: cmp r2 +; CHECK: cmpeq r3 +; CHECK: bne +; CHECK: strexd {{[a-z0-9]+}}, r0, r1 +; CHECK: cmp +; CHECK: bne +; CHECK: dmb ish +  %r = load atomic i64* %ptr seq_cst, align 8 +  ret i64 %r +} + +; Compiles down to atomicrmw xchg; there really isn't any more efficient +; way to write it. +define void @test9(i64* %ptr, i64 %val) { +; CHECK: test9 +; CHECK: dmb ish +; CHECK: ldrexd r2, r3 +; CHECK: strexd {{[a-z0-9]+}}, r0, r1 +; CHECK: cmp +; CHECK: bne +; CHECK: dmb ish +  store atomic i64 %val, i64* %ptr seq_cst, align 8 +  ret void +} | 

