This repository provides compiler toolchains and additional build tools that are acquired via Bootstrappable Builds. For details about the bootstrap process, see BOOTSTRAP.md.
Available compiler toolchains are:
gcc-latest-native
gcc-14.1.0-native
gcc-13.3.0-native
clang-latest-native
clang-18.1.8-native
clang-17.0.6-native
clang-16.0.6-native
gcc-latest-musl
gcc-14.1.0-musl
gcc-13.3.0-musl
gcc-latest-musl-static
gcc-14.1.0-musl-static
gcc-13.3.0-musl-static
For details about how these compilers are built, see COMPILERS.md.
Available build tools are:
busybox-latest
busybox-1.36.1
make-latest
make-4.4.1
cmake-latest
cmake-3.27.1
python-latest
python-3.12.0
tools-all
(bundle of all latest tools)
All tools are statically linked so that they can run on systems without any existing C library. For details about how these tools are built, see TOOLS.md.
Details about toolchain variants:
<compiler>-native
: native compiler- runs on the build host
- supports native compilation for the host architecture
<compiler>-musl
: cross compiler with musl support- runs on the build host
- links against bundled musl libc
(note that dynamically linked binaries require a working musl ld+libc on the target system) - supports fully static linking (unlike glibc toolchains)
- supports cross-compilation for project's
TARGET_ARCH
<compiler>-musl-static
: statically linked cross compiler with musl support- runs on systems without any existing C library
- links against bundled musl libc
(note that dynamically linked binaries require a working musl ld+libc on the target system) - supports fully static linking (unlike glibc toolchains)
- supports cross-compilation for project's
TARGET_ARCH
<toolchain>+tools
(e.g.,gcc-latest-native+tools
)<toolchain>
bundled with all latest tools (seetools-all
above)
All musl
variants support cross-compilation. In your project, make sure
that the variables ARCH
and TARGET_ARCH
are set to one of the following
values: x86
, x86_64
, arm
, or arm64
.
All provided toolchains can be
- imported to an existing Justbuild project, or
- installed to local disk to obtain a portable toolchain.
If your project includes its toolchain via an open name (usually a repository
named toolchain
), you can create that repository by importing any of the
provided toolchains (e.g., gcc-latest-musl+tools
) with the tool
just-import-git
:
$ just-import-git -C repos.template.json --as toolchain -b master \
https://github.com/just-buildsystem/bootstrappable-toolchain gcc-latest-musl+tools \
> repos.json
You can install a portable version of any provided toolchain (e.g.,
gcc-latest-musl
) to your local disk with:
$ just-mr --main gcc-latest-musl install toolchain -D'{"ARCH":"x86_64"}' -o /opt/gcc
Note that the configuration variable ARCH
should be set to the build host
architecture.
For installing a cross compiler, you can additionally set BUILD_ARCH
to
specify the architecture the compiler should build for:
$ just-mr --main gcc-latest-musl install toolchain \
-D'{"ARCH":"x86_64","BUILD_ARCH":"arm64"}' -o /opt/gcc-for-arm64
For installing a crossed native compiler, you have to also set the variable
TARGET_ARCH
(the architecture the compiler is build for) to the same value as
BUILD_ARCH
:
$ just-mr --main gcc-latest-musl install toolchain \
-D'{"ARCH":"x86_64","TARGET_ARCH":"arm64","BUILD_ARCH":"arm64"}' -o /opt/arm64-gcc-for-arm64
For bootstrapping the toolchains, the build host must be a Linux system with:
- C compiler (e.g., TinyCC, old GCC)
- POSIX-compliant shell located at
/bin/sh
The C compiler for bootstrapping can be specified by setting the fields
BOOTSTRAP_CC
, BOOTSTRAP_CFLAGS
, and BOOTSTRAP_PATH
in configuration
variable TOOLCHAIN_CONFIG
(e.g., on command line -D'{"TOOLCHAIN_CONFIG": {"BOOTSTRAP_CC": "gcc"}}'
). If not set, the C compiler is assumed to be cc
available in the search paths /bin
or /usr/bin
.
Note that currently supported build hosts are required to be an x86_64
architecture and use either the GNU or musl C library.
All toolchains provide the following target:
["", "toolchain"]
: The portable toolchain file tree (e.g.,bin
,lib
, etc.)
SetBUILD_ARCH
to specify the target architecture for cross-compilers.
All compiler toolchains additionally provide:
["CC", "defaults"]
: TheCC
toolchain definition for use with rules-cc
All tool toolchains (including <toolchain>+tools
) provide:
["CC/foreign", "defaults"]
: TheCC/foreign
toolchain definition for use with rules-cc
The busybox
toolchains (including <toolchain>+tools
) additionally provide:
["patch", "defaults"]
: Thepatch
toolchain definition for use with rules-cc
The toolchains can be configured via the variable TOOLCHAIN_CONFIG
, which
contains an object that may specify multiple fields.
Fields for building the toolchains:
BOOTSTRAP_CC
: The initial C compiler for bootstrapping (default:"cc"
)BOOTSTRAP_CFLAGS
: The initial C compile flags for bootstrapping (default:["-w"]
)BOOTSTRAP_PATH
: Search path for the initial C compiler (default:["/bin", "/usr/bin"]
)HOST_SYSTEM_HDR_DIR
: Header directory of the C library on the build host (default: not set)HOST_SYSTEM_LIB_DIR
: Library directory of the C library on the build host (default: not set)HOST_DYNAMIC_LINKER
: Absolute path to the dynamic linker on the build host (default: not set)BOOTSTRAP_WRAP_CC
: If true, when using the bootstrap C compiler with autotools, use a wrapper script calling the compiler with theBOOTSTRAP_CFLAGS
instead. In this way, it can be avoided that the autotools draw wrong conclusions from calling the compiler without the specified flags (as some tests do).INCLUDE_LINTER
: Add linter to toolchain if supported, e.g.,clang-tidy
(default:false
)
Fields for using the toolchains (within Justbuild projects):
STATIC_RUNLIBS
: Statically link runtime libraries, e.g.,libgcc_s
,libstdc++
(default:false
)USE_LIBCXX
: Use LLVM'slibc++
instead of GNU'slibstdc++
(only forclang
toolchains, default:false
)
Some systems (e.g., NixOS) use custom paths for Coreutils, the C library, and
the dynamic linker that the autotools cannot determine. On such systems, PATH
is used to locate Coreutils and TOOLCHAIN_CONFIG
may set additional system
paths.
Example configuration for bootstrapping on NixOS (hashes may vary):
{ "ENV": {"PATH": "/root/.nix-profile/bin"}
, "TOOLCHAIN_CONFIG":
{ "HOST_SYSTEM_HDR_DIR": "/nix/store/y8wfrgk7br5rfz4221lfb9v8w3n0cnyd-glibc-2.37-8-dev/include"
, "HOST_SYSTEM_LIB_DIR": "/nix/store/ld03l52xq2ssn4x0g5asypsxqls40497-glibc-2.37-8/lib"
, "HOST_DYNAMIC_LINKER": "/nix/store/ld03l52xq2ssn4x0g5asypsxqls40497-glibc-2.37-8/lib/ld-linux-x86-64.so.2"
}
}
Musl has huge allocator contention issues with multithreading. For that reason,
all our musl
compilers are shipped with the alternative allocator
mimalloc that solves these issues. If
you notice any performance slowdowns with your Musl-linked binaries, consider
using the alternative allocator by appending -l:mimalloc.o
to your LDFLAGS
.
All files are copyright Huawei Cloud Computing Technology Co., Ltd., license
Apache-2.0, except for the patches in etc/patches
, which are license GPL-2.0
(the same license as the respective upstream project).