From 728ec85e9af04784263acaf2993b2dbf4c07519f Mon Sep 17 00:00:00 2001 From: Jorge Aparicio Date: Fri, 30 Dec 2016 01:34:06 -0500 Subject: [PATCH] sparc64-linux support --- mk/cfg/sparc64-unknown-linux-gnu.mk | 1 + src/liballoc_jemalloc/build.rs | 6 ++++ src/liblibc | 2 +- src/librustc_back/target/mod.rs | 2 ++ .../target/sparc64_unknown_linux_gnu.rs | 30 +++++++++++++++++++ src/libstd/os/linux/raw.rs | 9 ++---- 6 files changed, 43 insertions(+), 7 deletions(-) create mode 100644 mk/cfg/sparc64-unknown-linux-gnu.mk create mode 100644 src/librustc_back/target/sparc64_unknown_linux_gnu.rs diff --git a/mk/cfg/sparc64-unknown-linux-gnu.mk b/mk/cfg/sparc64-unknown-linux-gnu.mk new file mode 100644 index 00000000000..34aee77ae21 --- /dev/null +++ b/mk/cfg/sparc64-unknown-linux-gnu.mk @@ -0,0 +1 @@ +# rustbuild-only target diff --git a/src/liballoc_jemalloc/build.rs b/src/liballoc_jemalloc/build.rs index 2bbec9e5fc2..1edcb0b1f24 100644 --- a/src/liballoc_jemalloc/build.rs +++ b/src/liballoc_jemalloc/build.rs @@ -151,6 +151,12 @@ fn main() { cmd.arg(format!("--host={}", build_helper::gnu_target(&target))); cmd.arg(format!("--build={}", build_helper::gnu_target(&host))); + // for some reason, jemalloc configure doesn't detect this value + // automatically for this target + if target == "sparc64-unknown-linux-gnu" { + cmd.arg("--with-lg-quantum=4"); + } + run(&mut cmd); let mut make = Command::new(build_helper::make(&host)); make.current_dir(&build_dir) diff --git a/src/liblibc b/src/liblibc index e49e9bb7c3d..98589876259 160000 --- a/src/liblibc +++ b/src/liblibc @@ -1 +1 @@ -Subproject commit e49e9bb7c3d9c7f2fd893f0ee0db81617b8db21f +Subproject commit 98589876259e19f13eab81b033ced95bbb6deca0 diff --git a/src/librustc_back/target/mod.rs b/src/librustc_back/target/mod.rs index 975bb6328c4..88791617077 100644 --- a/src/librustc_back/target/mod.rs +++ b/src/librustc_back/target/mod.rs @@ -157,6 +157,8 @@ fn $module() { ("mips-unknown-linux-uclibc", mips_unknown_linux_uclibc), ("mipsel-unknown-linux-uclibc", mipsel_unknown_linux_uclibc), + ("sparc64-unknown-linux-gnu", sparc64_unknown_linux_gnu), + ("i686-linux-android", i686_linux_android), ("arm-linux-androideabi", arm_linux_androideabi), ("armv7-linux-androideabi", armv7_linux_androideabi), diff --git a/src/librustc_back/target/sparc64_unknown_linux_gnu.rs b/src/librustc_back/target/sparc64_unknown_linux_gnu.rs new file mode 100644 index 00000000000..f627cc18f0b --- /dev/null +++ b/src/librustc_back/target/sparc64_unknown_linux_gnu.rs @@ -0,0 +1,30 @@ +// Copyright 2016 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +use target::{Target, TargetResult}; + +pub fn target() -> TargetResult { + let mut base = super::linux_base::opts(); + base.cpu = "v9".to_string(); + base.max_atomic_width = Some(64); + base.exe_allocation_crate = "alloc_system".to_string(); + + Ok(Target { + llvm_target: "sparc64-unknown-linux-gnu".to_string(), + target_endian: "big".to_string(), + target_pointer_width: "64".to_string(), + data_layout: "E-m:e-i64:64-n32:64-S128".to_string(), + arch: "sparc64".to_string(), + target_os: "linux".to_string(), + target_env: "gnu".to_string(), + target_vendor: "unknown".to_string(), + options: base, + }) +} diff --git a/src/libstd/os/linux/raw.rs b/src/libstd/os/linux/raw.rs index 7c9274d0601..bb1830a147e 100644 --- a/src/libstd/os/linux/raw.rs +++ b/src/libstd/os/linux/raw.rs @@ -157,12 +157,9 @@ pub struct stat { } } -#[cfg(target_arch = "mips64")] -mod arch { - pub use libc::{off_t, ino_t, nlink_t, blksize_t, blkcnt_t, stat, time_t}; -} - -#[cfg(target_arch = "s390x")] +#[cfg(any(target_arch = "mips64", + target_arch = "s390x", + target_arch = "sparc64"))] mod arch { pub use libc::{off_t, ino_t, nlink_t, blksize_t, blkcnt_t, stat, time_t}; } -- 2.44.0