|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| 2 | +; RUN: llc -mtriple=arm64_32-apple-darwin -O0 -fast-isel -verify-machineinstrs \ |
| 3 | +; RUN: -aarch64-enable-atomic-cfg-tidy=0 -aarch64-enable-collect-loh=0 \ |
| 4 | +; RUN: < %s | FileCheck %s |
| 5 | + |
| 6 | +; FastISel doesn't support cstexprs as operands here, but make |
| 7 | +; sure it knows to fallback, at least. |
| 8 | + |
| 9 | +define void @atomic_store_cstexpr_addr(i32 %val) #0 { |
| 10 | +; CHECK-LABEL: atomic_store_cstexpr_addr: |
| 11 | +; CHECK: ; %bb.0: |
| 12 | +; CHECK-NEXT: adrp x8, _g@PAGE |
| 13 | +; CHECK-NEXT: add x8, x8, _g@PAGEOFF |
| 14 | +; CHECK-NEXT: ; kill: def $w1 killed $w8 killed $x8 |
| 15 | +; CHECK-NEXT: adrp x8, _g@PAGE |
| 16 | +; CHECK-NEXT: add x8, x8, _g@PAGEOFF |
| 17 | +; CHECK-NEXT: stlr w0, [x8] |
| 18 | +; CHECK-NEXT: ret |
| 19 | + store atomic i32 %val, ptr inttoptr (i32 ptrtoint (ptr @g to i32) to ptr) release, align 4 |
| 20 | + ret void |
| 21 | +} |
| 22 | + |
| 23 | +define i32 @cmpxchg_cstexpr_addr(i32 %cmp, i32 %new, ptr %ps) #0 { |
| 24 | +; CHECK-LABEL: cmpxchg_cstexpr_addr: |
| 25 | +; CHECK: ; %bb.0: |
| 26 | +; CHECK-NEXT: mov w8, w0 |
| 27 | +; CHECK-NEXT: adrp x9, _g@PAGE |
| 28 | +; CHECK-NEXT: add x9, x9, _g@PAGEOFF |
| 29 | +; CHECK-NEXT: ; kill: def $w0 killed $w9 killed $x9 |
| 30 | +; CHECK-NEXT: adrp x10, _g@PAGE |
| 31 | +; CHECK-NEXT: add x10, x10, _g@PAGEOFF |
| 32 | +; CHECK-NEXT: LBB1_1: ; =>This Inner Loop Header: Depth=1 |
| 33 | +; CHECK-NEXT: ldaxr w0, [x10] |
| 34 | +; CHECK-NEXT: cmp w0, w8 |
| 35 | +; CHECK-NEXT: b.ne LBB1_3 |
| 36 | +; CHECK-NEXT: ; %bb.2: ; in Loop: Header=BB1_1 Depth=1 |
| 37 | +; CHECK-NEXT: stlxr w9, w1, [x10] |
| 38 | +; CHECK-NEXT: cbnz w9, LBB1_1 |
| 39 | +; CHECK-NEXT: LBB1_3: |
| 40 | +; CHECK-NEXT: subs w8, w0, w8 |
| 41 | +; CHECK-NEXT: cset w8, eq |
| 42 | +; CHECK-NEXT: and w8, w8, #0x1 |
| 43 | +; CHECK-NEXT: str w8, [x2] |
| 44 | +; CHECK-NEXT: ret |
| 45 | + %tmp0 = cmpxchg ptr inttoptr (i32 ptrtoint (ptr @g to i32) to ptr), i32 %cmp, i32 %new seq_cst seq_cst |
| 46 | + %tmp1 = extractvalue { i32, i1 } %tmp0, 0 |
| 47 | + %tmp2 = extractvalue { i32, i1 } %tmp0, 1 |
| 48 | + %tmp3 = zext i1 %tmp2 to i32 |
| 49 | + store i32 %tmp3, ptr %ps |
| 50 | + ret i32 %tmp1 |
| 51 | +} |
| 52 | + |
| 53 | +@g = global i32 0 |
0 commit comments