| use crate::spec::{ |
| Arch, FramePointer, SanitizerSet, StackProbeType, Target, TargetMetadata, TargetOptions, base, |
| }; |
| |
| pub(crate) fn target() -> Target { |
| let mut base = base::linux_ohos::opts(); |
| base.max_atomic_width = Some(128); |
| |
| Target { |
| llvm_target: "aarch64-unknown-linux-ohos".into(), |
| metadata: TargetMetadata { |
| description: Some("ARM64 OpenHarmony".into()), |
| tier: Some(2), |
| host_tools: Some(true), |
| std: Some(true), |
| }, |
| pointer_width: 64, |
| data_layout: "e-m:e-p270:32:32-p271:32:32-p272:64:64-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128-Fn32".into(), |
| arch: Arch::AArch64, |
| options: TargetOptions { |
| // the AAPCS64 expects use of non-leaf frame pointers per |
| // https://github.com/ARM-software/abi-aa/blob/4492d1570eb70c8fd146623e0db65b2d241f12e7/aapcs64/aapcs64.rst#the-frame-pointer |
| // and we tend to encounter interesting bugs in AArch64 unwinding code if we do not |
| frame_pointer: FramePointer::NonLeaf, |
| mcount: "\u{1}_mcount".into(), |
| stack_probes: StackProbeType::Inline, |
| supported_sanitizers: SanitizerSet::ADDRESS |
| | SanitizerSet::CFI |
| | SanitizerSet::LEAK |
| | SanitizerSet::MEMORY |
| | SanitizerSet::MEMTAG |
| | SanitizerSet::THREAD |
| | SanitizerSet::HWADDRESS, |
| ..base |
| }, |
| } |
| } |