summaryrefslogtreecommitdiffstats
path: root/compiler/rustc_target/src/spec/targets/aarch64_apple_tvos_sim.rs
diff options
context:
space:
mode:
Diffstat (limited to 'compiler/rustc_target/src/spec/targets/aarch64_apple_tvos_sim.rs')
-rw-r--r--compiler/rustc_target/src/spec/targets/aarch64_apple_tvos_sim.rs31
1 files changed, 31 insertions, 0 deletions
diff --git a/compiler/rustc_target/src/spec/targets/aarch64_apple_tvos_sim.rs b/compiler/rustc_target/src/spec/targets/aarch64_apple_tvos_sim.rs
new file mode 100644
index 000000000..7b0bbb28e
--- /dev/null
+++ b/compiler/rustc_target/src/spec/targets/aarch64_apple_tvos_sim.rs
@@ -0,0 +1,31 @@
+use crate::spec::base::apple::{opts, tvos_sim_llvm_target, Arch};
+use crate::spec::{FramePointer, Target, TargetOptions};
+
+pub fn target() -> Target {
+ let arch = Arch::Arm64_sim;
+ Target {
+ llvm_target: tvos_sim_llvm_target(arch).into(),
+ pointer_width: 64,
+ data_layout: "e-m:o-i64:64-i128:128-n32:64-S128".into(),
+ arch: arch.target_arch(),
+ options: TargetOptions {
+ features: "+neon,+fp-armv8,+apple-a7".into(),
+ max_atomic_width: Some(128),
+ forces_embed_bitcode: true,
+ frame_pointer: FramePointer::NonLeaf,
+ // Taken from (and slightly modified) the aarch64-apple-ios-sim spec which says:
+ // Taken from a clang build on Xcode 11.4.1.
+ // These arguments are not actually invoked - they just have
+ // to look right to pass App Store validation.
+ bitcode_llvm_cmdline: "-triple\0\
+ arm64-apple-tvos15.0-simulator\0\
+ -emit-obj\0\
+ -disable-llvm-passes\0\
+ -target-abi\0\
+ darwinpcs\0\
+ -Os\0"
+ .into(),
+ ..opts("tvos", arch)
+ },
+ }
+}