Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Building host tools for Solaris #114162

Open
4 of 9 tasks
inferiorhumanorgans opened this issue Jul 28, 2023 · 3 comments
Open
4 of 9 tasks

Building host tools for Solaris #114162

inferiorhumanorgans opened this issue Jul 28, 2023 · 3 comments
Labels
A-cross Area: Cross compilation C-discussion Category: Discussion or questions that doesn't represent real issues. O-solaris Operating system: Solaris O-SPARC Target: SPARC processors

Comments

@inferiorhumanorgans
Copy link

inferiorhumanorgans commented Jul 28, 2023

I'm not quite sure if this is the right place to track these things, but I've been trying to cross build the native host tools for Solaris (both x86 and SPARC).

x86_64

Environment

Cross: x86_64-apple-darwinx86_64-pc-solaris
Sysroot: see below
Compiler: gcc 11.2.0
binutils: GNU binutils 2.40 + ar LLVM 16 (todo: test with GNU ar)
rust 1.70.0
Local changes to rust: #114078

Known issues

  • The rust build process sets -nodefaultlibs for reasons that aren't entirely clear to me. To get the build working successfully I had to wrap gcc and g++ with a small script to ensure that CFLAGS/CXXFLAGS always included --sysroot=${SYSROOT} -L${SYSROOT}/lib/amd64 -L${SYSROOT}/lib -Wl,-rpath-link,${SYSROOT}/lib/amd64
  • Linking to OpenSSL does not work. Headers seem to be from ≥ 1.1.0, linker finds libraries for 1.0.2. The build is stopped at cargo. Linker errors are all missing symbols (e.g. OPENSSL_init_ssl, BIO_meth_new). Solved by building sysroot from Solaris packages. Note: Ensure that the build picks up the pkg-config info at ${SYSROOT}/usr/openssl/3/lib/64/pkgconfig/libssl.pc or set OPENSSL_LIB_DIR="${SYSROOT}/usr/openssl/3/lib/64" and OPENSSL_INCLUDE_DIR="${SYSROOT}/usr/openssl/3/include"
  • The installer complains of various uninitialized variables and panics as the script is run with set -u. Related:
  • LLVM does not like the Solaris headers[1]. There appears to be a workaround in LLVM but it's not being triggered (at least during a cross compile). Manually undefining the registers in the Solaris headers fixed the build for me, but this seems like it should work out of the box. Solved by building sysroot from Solaris packages.
  • ar and ranlib need to be modern-ish. When using an older ar the static LLVM support libraries are empty and the build fails with a load of undefined references to LLVM symbols. For the x86_64 build I used an LLVM ar from macports via CMAKE_AR and resolved the issue. For the sparc build I used ar and ranlib from GNU binutils 2.40. Setting ar and ranlib in config.toml should fix @3eka's issue with undefined symbols. This is set per-target e.g. target.x86_64-pc-solaris.ar or target.sparcv9-sun-solaris.ar and must be an absolute path.
  • rust-analyzer does not compile due to nix incorrectly assuming flock exists in Solaris (apparently it hasn't since at least 5.x) [1, 2]. Related:

Status

With this in place I can build these artifacts from 1.70.0:

cargo-nightly-x86_64-pc-solaris.tar.xz
rust-analysis-nightly-x86_64-pc-solaris.tar.xz
rust-analyzer-nightly-x86_64-pc-solaris.tar.xz
rust-demangler-nightly-x86_64-pc-solaris.tar.xz
rust-dev-nightly-x86_64-pc-solaris.tar.xz
rust-nightly-x86_64-pc-solaris.tar.xz
rust-std-nightly-x86_64-pc-solaris.tar.xz
rustc-dev-nightly-x86_64-pc-solaris.tar.xz
rustc-nightly-x86_64-pc-solaris.tar.xz
rustfmt-nightly-x86_64-pc-solaris.tar.xz

Manually installing the rust-std-nightly and rustc-nightly tarballs got me an install that successfully compiled a "Hello, world" program with the Oracle provided gcc as the linker.

SPARCv9

Environment

Cross: x86_64-apple-darwinsparcv9-sun-solaris
Sysroot: see below
Compiler: gcc 11.2.0
binutils: GNU binutils 2.40
rust 1.70.0
Local changes to rust: #114078

Known issues

  • ar and ranlib need to be modern-ish. See above.
  • Due to using gcc as the cross compiler(?) I had to explicitly set LLVM_TOOL_LLVM_LIBTOOL_DARWIN_BUILD to OFF in src/bootstrap/llvm.rs because Apple's libtool(1) doesn't seem to know what to do with ELF/SPARC objects. This should probably be part of a larger discussion on whether cross compiling from an Apple → non-Apple target is a worthwhile goal.
  • llvm-wrapper/PassWrapper.cpp calls llvm::sys::getHostCPUName which on Solaris/SPARC calls into libkstat. libLLVMTargetParser which contains getHostCPUName does not appear to link against libkstat Somewhere along the way we should be linking against libkstat. Related:

Status

I can build these artifacts from 1.70.0:

cargo-nightly-sparcv9-sun-solaris.tar.xz
rust-analysis-nightly-sparcv9-sun-solaris.tar.xz
rust-analyzer-nightly-sparcv9-sun-solaris.tar.xz
rust-demangler-nightly-sparcv9-sun-solaris.tar.xz
rust-dev-nightly-sparcv9-sun-solaris.tar.xz
rust-nightly-sparcv9-sun-solaris.tar.xz
rust-std-nightly-sparcv9-sun-solaris.tar.xz
rustc-dev-nightly-sparcv9-sun-solaris.tar.xz
rustc-nightly-sparcv9-sun-solaris.tar.xz
rustfmt-nightly-sparcv9-sun-solaris.tar.xz

Sysroot

Package information from Oracle is available here:

http://pkg.oracle.com/solaris/release/en/catalog.shtml

Solaris packages contain files for both x86 and SPARC architectures. The following packages should be sufficient to create a usable sysroot for cross compiling:

# system headers
system/header@11.4,5.11-11.4.42.0.0.111.1:20211203T213657Z

# Core system libraries
system/library@11.4,5.11-11.4.42.0.0.111.1:20211203T214210Z

# ld.so, crt*
system/linker@11.4-11.4.0.0.1.15.0:20180817T003258Z

# libc
system/library/libc@11.4-11.4.42.0.0.111.1:20211203T214042Z

# libm
system/library/math@11.4-11.4.0.1.0.17.0:20200221T005425Z

# libucrypto
system/library/security/crypto@11.4,5.11-11.4.42.0.0.111.1:20211203T214125Z

# libssl v3
library/security/openssl-3@3,11.4-11.4.42.0.0.111.0:20211203T203706Z

# libz
library/zlib@1.2.11,11.4-11.4.42.0.0.111.0:20211203T203816Z
@rustbot rustbot added the needs-triage This issue may need triage. Remove it if it has been sufficiently triaged. label Jul 28, 2023
@workingjubilee workingjubilee added O-solaris Operating system: Solaris and removed needs-triage This issue may need triage. Remove it if it has been sufficiently triaged. labels Jul 28, 2023
@workingjubilee
Copy link
Member

workingjubilee commented Jul 28, 2023

( please feel free to add whatever labels you think it should have via rustbot label: +label, if you want to potentially bring it to the more attention, I removed needs-triage because it looks like you're just tracking a work in progress, which I don't mind either way. )

@inferiorhumanorgans
Copy link
Author

@rustbot label: +A-cross +O-SPARC

@workingjubilee thanks! For the stuff that won't get fixed (e.g. needing to specify ar and ranlib by hand, is there a good place to land some documentation?

@rustbot rustbot added A-cross Area: Cross compilation O-SPARC Target: SPARC processors labels Jul 29, 2023
@workingjubilee
Copy link
Member

We have been linking documentation to platform quirks from src/doc/rustc/src/platform-support.md, because that gets rendered as https://doc.rust-lang.org/nightly/rustc/platform-support.html

@jieyouxu jieyouxu added the C-discussion Category: Discussion or questions that doesn't represent real issues. label Nov 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-cross Area: Cross compilation C-discussion Category: Discussion or questions that doesn't represent real issues. O-solaris Operating system: Solaris O-SPARC Target: SPARC processors
Projects
None yet
Development

No branches or pull requests

4 participants