| //! Targets the ARMv5TE, with code as `a32` code by default. |
| |
| use crate::spec::{cvs, FramePointer, Target, TargetOptions}; |
| |
| pub fn target() -> Target { |
| Target { |
| llvm_target: "armv5te-none-eabi".into(), |
| pointer_width: 32, |
| arch: "arm".into(), |
| /* Data layout args are '-' separated: |
| * little endian |
| * stack is 64-bit aligned (EABI) |
| * pointers are 32-bit |
| * i64 must be 64-bit aligned (EABI) |
| * mangle names with ELF style |
| * native integers are 32-bit |
| * All other elements are default |
| */ |
| data_layout: "e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64".into(), |
| |
| options: TargetOptions { |
| abi: "eabi".into(), |
| // extra args passed to the external assembler (assuming `arm-none-eabi-as`): |
| // * activate t32/a32 interworking |
| // * use arch ARMv5TE |
| // * use little-endian |
| asm_args: cvs!["-mthumb-interwork", "-march=armv5te", "-mlittle-endian",], |
| // minimum extra features, these cannot be disabled via -C |
| // Also force-enable 32-bit atomics, which allows the use of atomic load/store only. |
| // The resulting atomics are ABI incompatible with atomics backed by libatomic. |
| features: "+soft-float,+strict-align,+atomics-32".into(), |
| frame_pointer: FramePointer::MayOmit, |
| main_needs_argc_argv: false, |
| // don't have atomic compare-and-swap |
| atomic_cas: false, |
| has_thumb_interworking: true, |
| |
| ..super::thumb_base::opts() |
| }, |
| } |
| } |