rustc_target/spec/targets/
armv7a_vex_v5.rs

1use 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}