2021-01-05 01:13:27 +00:00
|
|
|
use crate::abi::Endian;
|
2020-10-08 22:22:28 +03:00
|
|
|
use crate::spec::{Target, TargetOptions};
|
2019-03-05 23:28:15 +08:00
|
|
|
|
2020-10-05 15:37:55 +03:00
|
|
|
pub fn target() -> Target {
|
|
|
|
Target {
|
2019-03-05 23:28:15 +08:00
|
|
|
llvm_target: "mipsisa64r6-unknown-linux-gnuabi64".to_string(),
|
2020-10-14 18:08:12 +02:00
|
|
|
pointer_width: 64,
|
2019-03-05 23:28:15 +08:00
|
|
|
data_layout: "E-m:e-i8:8:32-i16:16:32-i64:64-n32:64-S128".to_string(),
|
|
|
|
arch: "mips64".to_string(),
|
|
|
|
options: TargetOptions {
|
2021-07-06 22:00:53 -07:00
|
|
|
abi: "abi64".to_string(),
|
2021-01-05 01:13:27 +00:00
|
|
|
endian: Endian::Big,
|
2019-03-05 23:28:15 +08:00
|
|
|
// NOTE(mips64r6) matches C toolchain
|
|
|
|
cpu: "mips64r6".to_string(),
|
|
|
|
features: "+mips64r6".to_string(),
|
|
|
|
max_atomic_width: Some(64),
|
2020-11-08 14:57:55 +03:00
|
|
|
mcount: "_mcount".to_string(),
|
2019-03-05 23:28:15 +08:00
|
|
|
|
2020-11-10 23:32:58 +03:00
|
|
|
..super::linux_gnu_base::opts()
|
2019-03-05 23:28:15 +08:00
|
|
|
},
|
2020-10-05 15:37:55 +03:00
|
|
|
}
|
2019-03-05 23:28:15 +08:00
|
|
|
}
|