This guide will walk you through building CoreCLR on Linux.
First, set up your environment to build using the instructions here.
Choose one of the following options for building.
Building using Docker will require that you choose the correct image for your environment. Note that the OS is strictly speaking not extremely important, for example if you are on Ubuntu 18.04 and build using the Ubuntu 16.04 x64 image there should be no issues. The target architecture is more important, as building arm32 using the x64 image will not work: there will be missing rootfs components required by the build. See Docker Images, below, for more information on choosing an image to build with.
Please note that when choosing an image choosing the same image as the host os you are running on you will allow you to run the product/tests outside of the docker container you built in.
Once you have chosen an image the build is one command run from the root of the runtime repository:
docker run --rm -v <RUNTIME_REPO_PATH>:/runtime -w /runtime mcr.microsoft.com/dotnet-buildtools/prereqs:ubuntu-16.04-20200508132555-78cbb55 ./build.sh -subset clr -clang9
Dissecting the command:
--rm
: erase the created container after use.-v <RUNTIME_REPO_PATH>:/runtime
: mount the runtime repository under/runtime
. Replace<RUNTIME_REPO_PATH>
with the full path to yourruntime
repo clone, e.g.,-v /home/user/runtime:/runtime
.-w: /runtime
: set /runtime as working directory for the container.mcr.microsoft.com/dotnet-buildtools/prereqs:ubuntu-16.04-20200508132555-78cbb55
: Docker image name../build.sh
: command to be run in the container: run the root build command.-subset clr
: build the clr subset (excluding libraries and installers).-clang9
: argument to use clang 9 for the build (the only compiler in the build image).
If you are attempting to cross build for arm or arm64 then use the crossrootfs location to set the ROOTFS_DIR. The command would add -e ROOTFS_DIR=<crossrootfs location>
. See Docker Images for the crossrootfs location. In addition you will need to specify -cross
. For example:
docker run --rm -v <RUNTIME_REPO_PATH>:/runtime -w /runtime -e ROOTFS_DIR=/crossrootfs/arm64 mcr.microsoft.com/dotnet-buildtools/prereqs:ubuntu-16.04-cross-arm64-20200508132638-b2c2436 ./build.sh -arch arm64 -subset clr -cross -clang9
Note that instructions on building the crossrootfs location can be found at cross-building.md. These instructions are suggested only if there are plans to change the rootfs, or the Docker images for arm/arm64 are insufficient for you build.
This table of images might often become stale as we change our images as our requirements change. The images used for our our official builds can be found in the platform matrix of our Azure DevOps builds under the container
key of the platform you plan to build.
OS | Target Arch | Image location | crossrootfs location | Clang Version |
---|---|---|---|---|
Ubuntu 16.04 | x64 | mcr.microsoft.com/dotnet-buildtools/prereqs:ubuntu-16.04-a50a721-20191120200116 |
- | -clang9 |
Alpine | x64 | mcr.microsoft.com/dotnet-buildtools/prereqs:alpine-3.9-WithNode-20200602002639-0fc54a3 |
- | -clang5.0 |
CentOS 7 (build for RHEL 7) | x64 | mcr.microsoft.com/dotnet-buildtools/prereqs:centos-7-359e48e-20200313130914 |
- | -clang9 |
Ubuntu 16.04 | arm32 (armhf) | mcr.microsoft.com/dotnet-buildtools/prereqs:ubuntu-16.04-cross-20200413125008-09ec757 |
/crossrootfs/arm |
-clang9 |
Ubuntu 16.04 | arm64 (arm64v8) | mcr.microsoft.com/dotnet-buildtools/prereqs:ubuntu-16.04-cross-arm64-20201022204150-b2c2436 |
/crossrootfs/arm64 |
-clang9 |
Alpine | arm64 (arm64v8) | mcr.microsoft.com/dotnet-buildtools/prereqs:ubuntu-16.04-cross-arm64-alpine-20200413125008-406629a |
/crossrootfs/arm64 |
-clang9 |
This guide assumes that you've cloned the runtime repository.
To ensure that your system can allocate enough file-handles for the libraries build run sysctl fs.file-max
. If it is less than 100000, add fs.file-max = 100000
to /etc/sysctl.conf
, and then run sudo sysctl -p
.
To build the runtime on Linux, run build.sh to build the CoreCLR subset category of the runtime:
./build.sh -subset clr
After the build is completed, there should some files placed in artifacts/bin/coreclr/Linux.x64.Debug
. The ones we are most interested in are:
corerun
: The command line host. This program loads and starts the CoreCLR runtime and passes the managed program you want to run to it.libcoreclr.so
: The CoreCLR runtime itself.System.Private.CoreLib.dll
: The core managed library, containing definitions ofObject
and base functionality.
The Core_Root folder will contain the built binaries, generated by build.sh
, as well as the library packages required to run tests. Note that you need to build
the libraries subset (-subset libs
) before this command can be run.
./src/tests/build.sh generatelayoutonly
After the build is complete you will find the output in the artifacts/tests/coreclr/Linux.x64.Debug/Tests/Core_Root
folder.
After src/tests/build.sh
is run, corerun
from the Core_Root folder is ready to be run. This can be done by using the full absolute path to corerun
, or by setting an environment variable to the Core_Root folder.
export CORE_ROOT=/runtime/artifacts/tests/coreclr/Linux.x64.Debug/Tests/Core_Root
$CORE_ROOT/corerun hello_world.dll