This behavior matches clang's behavior, and makes cross-language LTO possible. Fixes #60235.
34 lines
1.2 KiB
Rust
34 lines
1.2 KiB
Rust
use crate::spec::{LinkerFlavor, Target, TargetOptions, TargetResult};
|
|
|
|
pub fn target() -> TargetResult {
|
|
let mut base = super::apple_base::opts();
|
|
base.cpu = "core2".to_string();
|
|
base.max_atomic_width = Some(128); // core2 support cmpxchg16b
|
|
base.eliminate_frame_pointer = false;
|
|
base.pre_link_args.insert(LinkerFlavor::Gcc, vec!["-m64".to_string()]);
|
|
base.stack_probes = true;
|
|
|
|
// Clang automatically chooses a more specific target based on
|
|
// MACOSX_DEPLOYMENT_TARGET. To enable cross-language LTO to work
|
|
// correctly, we do too.
|
|
let arch = "x86_64";
|
|
let llvm_target = super::apple_base::macos_llvm_target(&arch);
|
|
|
|
Ok(Target {
|
|
llvm_target: llvm_target,
|
|
target_endian: "little".to_string(),
|
|
target_pointer_width: "64".to_string(),
|
|
target_c_int_width: "32".to_string(),
|
|
data_layout: "e-m:o-i64:64-f80:128-n8:16:32:64-S128".to_string(),
|
|
arch: arch.to_string(),
|
|
target_os: "macos".to_string(),
|
|
target_env: String::new(),
|
|
target_vendor: "apple".to_string(),
|
|
linker_flavor: LinkerFlavor::Gcc,
|
|
options: TargetOptions {
|
|
target_mcount: "\u{1}mcount".to_string(),
|
|
.. base
|
|
},
|
|
})
|
|
}
|