rustc_target/spec/targets/
armv7a_vex_v5.rs1use crate::spec::{
2 Cc, FloatAbi, LinkerFlavor, Lld, PanicStrategy, RelocModel, Target, TargetMetadata,
3 TargetOptions,
4};
5
6const LINKER_SCRIPT: &str = include_str!("./armv7a_vex_v5_linker_script.ld");
7
8pub(crate) fn target() -> Target {
9 let opts = TargetOptions {
10 vendor: "vex".into(),
11 env: "v5".into(),
12 os: "vexos".into(),
13 cpu: "cortex-a9".into(),
14 abi: "eabihf".into(),
15 is_like_vexos: true,
16 llvm_floatabi: Some(FloatAbi::Hard),
17 linker_flavor: LinkerFlavor::Gnu(Cc::No, Lld::Yes),
18 linker: Some("rust-lld".into()),
19 features: "+v7,+neon,+vfp3d16,+thumb2".into(),
20 relocation_model: RelocModel::Static,
21 disable_redzone: true,
22 max_atomic_width: Some(64),
23 panic_strategy: PanicStrategy::Abort,
24 emit_debug_gdb_scripts: false,
25 c_enum_min_bits: Some(8),
26 default_uwtable: true,
27 has_thumb_interworking: true,
28 link_script: Some(LINKER_SCRIPT.into()),
29 ..Default::default()
30 };
31 Target {
32 llvm_target: "armv7a-none-eabihf".into(),
33 metadata: TargetMetadata {
34 description: Some("ARMv7-A Cortex-A9 VEX V5 Brain".into()),
35 tier: Some(3),
36 host_tools: Some(false),
37 std: Some(false),
38 },
39 pointer_width: 32,
40 data_layout: "e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64".into(),
41 arch: "arm".into(),
42 options: opts,
43 }
44}