mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-10 23:06:23 +00:00
enable strict alignment (+strict-align) on ARMv6
As discovered in #44538 ARMv6 devices may or may not support unaligned memory accesses. ARMv6 Linux *seems* to have no problem with unaligned accesses but this is because the kernel is stepping in to fix each unaligned memory access -- this incurs in a performance penalty. This commit enforces aligned memory accesses on all our in-tree ARM targets that may be used with ARMv6 devices. This should improve performance of Rust programs on ARMv6 devices. For the record, clang also applies this attribute when targeting ARMv6 devices that are not running Darwin or NetBSD.
This commit is contained in:
parent
bb4d149146
commit
2b8f190d63
@ -14,7 +14,7 @@ use target::{Target, TargetOptions, TargetResult};
|
|||||||
pub fn target() -> TargetResult {
|
pub fn target() -> TargetResult {
|
||||||
let mut base = super::android_base::opts();
|
let mut base = super::android_base::opts();
|
||||||
// https://developer.android.com/ndk/guides/abis.html#armeabi
|
// https://developer.android.com/ndk/guides/abis.html#armeabi
|
||||||
base.features = "+v5te".to_string();
|
base.features = "+strict-align,+v5te".to_string();
|
||||||
base.max_atomic_width = Some(64);
|
base.max_atomic_width = Some(64);
|
||||||
|
|
||||||
Ok(Target {
|
Ok(Target {
|
||||||
|
@ -27,7 +27,7 @@ pub fn target() -> TargetResult {
|
|||||||
linker_flavor: LinkerFlavor::Gcc,
|
linker_flavor: LinkerFlavor::Gcc,
|
||||||
|
|
||||||
options: TargetOptions {
|
options: TargetOptions {
|
||||||
features: "+v6".to_string(),
|
features: "+strict-align,+v6".to_string(),
|
||||||
abi_blacklist: super::arm_base::abi_blacklist(),
|
abi_blacklist: super::arm_base::abi_blacklist(),
|
||||||
.. base
|
.. base
|
||||||
},
|
},
|
||||||
|
@ -27,7 +27,7 @@ pub fn target() -> TargetResult {
|
|||||||
linker_flavor: LinkerFlavor::Gcc,
|
linker_flavor: LinkerFlavor::Gcc,
|
||||||
|
|
||||||
options: TargetOptions {
|
options: TargetOptions {
|
||||||
features: "+v6,+vfp2".to_string(),
|
features: "+strict-align,+v6,+vfp2".to_string(),
|
||||||
abi_blacklist: super::arm_base::abi_blacklist(),
|
abi_blacklist: super::arm_base::abi_blacklist(),
|
||||||
.. base
|
.. base
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@ pub fn target() -> TargetResult {
|
|||||||
|
|
||||||
// Most of these settings are copied from the arm_unknown_linux_gnueabi
|
// Most of these settings are copied from the arm_unknown_linux_gnueabi
|
||||||
// target.
|
// target.
|
||||||
base.features = "+v6".to_string();
|
base.features = "+strict-align,+v6".to_string();
|
||||||
base.max_atomic_width = Some(64);
|
base.max_atomic_width = Some(64);
|
||||||
Ok(Target {
|
Ok(Target {
|
||||||
// It's important we use "gnueabi" and not "musleabi" here. LLVM uses it
|
// It's important we use "gnueabi" and not "musleabi" here. LLVM uses it
|
||||||
|
@ -16,7 +16,7 @@ pub fn target() -> TargetResult {
|
|||||||
|
|
||||||
// Most of these settings are copied from the arm_unknown_linux_gnueabihf
|
// Most of these settings are copied from the arm_unknown_linux_gnueabihf
|
||||||
// target.
|
// target.
|
||||||
base.features = "+v6,+vfp2".to_string();
|
base.features = "+strict-align,+v6,+vfp2".to_string();
|
||||||
base.max_atomic_width = Some(64);
|
base.max_atomic_width = Some(64);
|
||||||
Ok(Target {
|
Ok(Target {
|
||||||
// It's important we use "gnueabihf" and not "musleabihf" here. LLVM
|
// It's important we use "gnueabihf" and not "musleabihf" here. LLVM
|
||||||
|
Loading…
Reference in New Issue
Block a user