.. _BuildingCompilerRT:
=============== Building Compiler-RT
.. contents:: :local:
.. _build instructions:
The instructions on this page are aimed at vendors who ship Compiler-RT as part of an operating system distribution, a toolchain or similar shipping vehicles. If you are a user merely trying to use Compiler-RT in your program, you most likely want to refer to your vendor's documentation, or to the general documentation for using LLVM, Clang, the various santizers, etc.
CMake Options
Here are some of the CMake variables that are used often, along with a
brief explanation and LLVM-specific notes. For full documentation, check the
CMake docs or execute cmake --help-variable VARIABLE_NAME.
CMAKE_BUILD_TYPE:STRING
Sets the build type for make based generators. Possible values are
Release, Debug, RelWithDebInfo and MinSizeRel. On systems like Visual Studio
the user sets the build type with the IDE settings.
CMAKE_INSTALL_PREFIX:PATH Path where LLVM will be installed if "make install" is invoked or the "INSTALL" target is built.
CMAKE_CXX_COMPILER:STRING The C++ compiler to use when building and testing Compiler-RT.
.. _compiler-rt-specific options:
Compiler-RT specific options
.. option:: COMPILER_RT_INSTALL_PATH:PATH
Default: ```` (empty relative path)
Prefix for directories where built Compiler-RT artifacts should be installed.
Can be an absolute path, like the default empty string, in which case it is
relative CMAKE_INSTALL_PREFIX. If setting a relative path, make sure to
include the :PATH with your -D, i.e. use
-DCOMPILER_RT_INSTALL_PATH:PATH=... not
-DCOMPILER_RT_INSTALL_PATH=..., otherwise CMake will convert the
path to an absolute path.
.. option:: COMPILER_RT_INSTALL_LIBRARY_DIR:PATH
Default: lib
Path where built Compiler-RT libraries should be installed. If a relative
path, relative to COMPILER_RT_INSTALL_PATH.
.. option:: COMPILER_RT_INSTALL_BINARY_DIR:PATH
Default: bin
Path where built Compiler-RT executables should be installed. If a relative
path, relative to COMPILER_RT_INSTALL_PATH.
.. option:: COMPILER_RT_INSTALL_INCLUDE_DIR:PATH
Default: include
Path where Compiler-RT headers should be installed. If a relative
path, relative to COMPILER_RT_INSTALL_PATH.
.. option:: COMPILER_RT_INSTALL_DATA_DIR:PATH
Default: share
Path where Compiler-RT data should be installed. If a relative
path, relative to COMPILER_RT_INSTALL_PATH.
.. _LLVM-specific variables:
LLVM-specific options
.. option:: LLVM_LIBDIR_SUFFIX:STRING
Extra suffix to append to the directory where libraries are to be
installed. On a 64-bit architecture, one could use -DLLVM_LIBDIR_SUFFIX=64
to install libraries to /usr/lib64.