| # RUN: llc -mtriple=aarch64-none-linux-gnu -run-pass none -o - %s | FileCheck %s |
| |
| --- | |
| define i32 @swp(i32* %addr) #0 { |
| entry: |
| %0 = atomicrmw xchg i32* %addr, i32 1 monotonic |
| ret i32 %0 |
| } |
| |
| attributes #0 = { "target-features"="+lse" } |
| ... |
| --- |
| name: swp |
| alignment: 2 |
| tracksRegLiveness: true |
| registers: |
| - { id: 0, class: gpr64common } |
| - { id: 1, class: gpr32 } |
| - { id: 2, class: gpr32 } |
| liveins: |
| - { reg: '$x0', virtual-reg: '%0' } |
| body: | |
| bb.0.entry: |
| liveins: $x0 |
| |
| ; CHECK-LABEL: swp |
| ; CHECK: {{[0-9]+}}:gpr32 = SWPW killed %1, %0 :: (volatile load store monotonic 4 on %ir.addr) |
| %0:gpr64common = COPY $x0 |
| %1:gpr32 = MOVi32imm 1 |
| %2:gpr32 = SWPW killed %1, %0 :: (volatile load store monotonic 4 on %ir.addr) |
| $w0 = COPY %2 |
| RET_ReallyLR implicit $w0 |
| ... |