Skip to content

Commit

Permalink
riscv: Optimize 16-bit fetch_not when Zabha enabled
Browse files Browse the repository at this point in the history
Before:
```
lui     a1, 16
addi    a1, a1, -1
amoxor.h        a0, a1, (a0)
```

After:
```
li      a1, -1
amoxor.h        a0, a1, (a0)
```
  • Loading branch information
taiki-e committed Sep 28, 2024
1 parent 76d9ad5 commit a487a09
Showing 1 changed file with 12 additions and 5 deletions.
17 changes: 12 additions & 5 deletions src/imp/riscv.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,10 @@ Refs:
- atomic-maybe-uninit /~https://github.com/taiki-e/atomic-maybe-uninit
Generated asm:
- riscv64gc https://godbolt.org/z/q4fhcPEv4
- riscv64gc (+zabha) https://godbolt.org/z/hde3ao7hx
- riscv32imac https://godbolt.org/z/7PKMx5KK3
- riscv32imac (+zabha) https://godbolt.org/z/E1aTff9f7
- riscv64gc https://godbolt.org/z/Ws933n9jE
- riscv64gc (+zabha) https://godbolt.org/z/zEKPPW11f
- riscv32imac https://godbolt.org/z/TKbYdbaE9
- riscv32imac (+zabha) https://godbolt.org/z/TnePfK6co
*/

// TODO: Zacas extension
Expand Down Expand Up @@ -370,7 +370,14 @@ macro_rules! atomic {

#[inline]
pub(crate) fn fetch_not(&self, order: Ordering) -> $value_type {
self.fetch_xor(!0, order)
let dst = self.v.get();
#[cfg(target_arch = "riscv32")]
let val: u32 = !0;
#[cfg(target_arch = "riscv64")]
let val: u64 = !0;
// SAFETY: any data races are prevented by atomic intrinsics and the raw
// pointer passed in is valid because we got it from a reference.
unsafe { atomic_rmw_amo!(xor, dst, val, order, $asm_suffix) }
}
#[cfg(not(any(
portable_atomic_unsafe_assume_single_core,
Expand Down

0 comments on commit a487a09

Please sign in to comment.