forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#83655 - sebpop:arm64-outline-atomics, r=jos…
…htriplett [aarch64] add target feature outline-atomics Enable outline-atomics by default as enabled in clang by the following commit https://reviews.llvm.org/rGc5e7e649d537067dec7111f3de1430d0fc8a4d11 Performance improves by several orders of magnitude when using the LSE instructions instead of the ARMv8.0 compatible load/store exclusive instructions. Tested on Graviton2 aarch64-linux with x.py build && x.py install && x.py test
- Loading branch information
Showing
3 changed files
with
17 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
// min-llvm-version: 12.0 | ||
// assembly-output: emit-asm | ||
// compile-flags: -O | ||
// compile-flags: --target aarch64-unknown-linux-gnu | ||
// needs-llvm-components: aarch64 | ||
|
||
#![crate_type = "rlib"] | ||
|
||
use std::sync::atomic::{AtomicI32, Ordering::*}; | ||
|
||
pub fn compare_exchange(a: &AtomicI32) { | ||
// On AArch64 LLVM should outline atomic operations. | ||
// CHECK: __aarch64_cas4_relax | ||
let _ = a.compare_exchange(0, 10, Relaxed, Relaxed); | ||
} |