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:
Jorge Aparicio 2017-10-07 20:48:25 +02:00
parent bb4d149146
commit 2b8f190d63
5 changed files with 5 additions and 5 deletions

View File

@ -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 {

View File

@ -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
}, },

View File

@ -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
} }

View File

@ -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

View File

@ -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