Bump version to 19.1.0 (final)
[llvm-project.git] / libc / docs / full_cross_build.rst
blob100e17a977e764b2744a4647fed4b6c4cd306e39
1 .. _full_cross_build:
3 ================
4 Full Cross Build
5 ================
7 .. contents:: Table of Contents
8    :depth: 1
9    :local:
11 In this document, we will present recipes to cross build the full libc. When we
12 say *cross build* a full libc, we mean that we will build the full libc for a
13 target system which is not the same as the system on which the libc is being
14 built. For example, you could be building for a bare metal aarch64 *target* on a
15 Linux x86_64 *host*.
17 There are three main recipes to cross build the full libc. Each one serves a
18 different use case. Below is a short description of these recipes to help users
19 pick the recipe that best suites their needs and contexts.
21 * **Standalone cross build** - Using this recipe one can build the libc using a
22   compiler of their choice. One should use this recipe if their compiler can
23   build for the host as well as the target.
24 * **Runtimes cross build** - In this recipe, one will have to first build the
25   libc build tools for the host separately and then use those build tools to
26   build the libc. Users can use the compiler of their choice to build the
27   libc build tools as well as the libc. One should use this recipe if they
28   have to use a host compiler to build the build tools for the host and then
29   use a target compiler (which is different from the host compiler) to build
30   the libc.
31 * **Bootstrap cross build** - In this recipe, one will build the ``clang``
32   compiler and the libc build tools for the host first, and then use them to
33   build the libc for the target. Unlike with the runtimes build recipe, the
34   user does not have explicitly build ``clang`` and other libc build tools.
35   They get built automatically before building the libc. One should use this
36   recipe if they intend use the built ``clang`` and the libc as part of their
37   toolchain for the target.
39 The following sections present the three recipes in detail.
41 Standalone cross build
42 ======================
44 In the *standalone crossbuild* recipe, the system compiler or a custom compiler
45 of user's choice is used to build the libc. The necessary build tools for the
46 host are built first, and those build tools are then used to build the libc for
47 the target. Both these steps happen automatically, as in, the user does not have
48 to explicitly build the build tools first and then build the libc. A point to
49 keep in mind is that the compiler used should be capable of building for the
50 host as well as the target.
52 CMake configure step
53 --------------------
55 Below is the CMake command to configure the standalone crossbuild of the libc.
57 .. code-block:: sh
59   $> cd llvm-project  # The llvm-project checkout
60   $> mkdir build
61   $> cd build
62   $> C_COMPILER=<C compiler> # For example "clang"
63   $> CXX_COMPILER=<C++ compiler> # For example "clang++"
64   $> cmake ../llvm  \
65      -G Ninja \
66      -DLLVM_ENABLE_PROJECTS=libc  \
67      -DCMAKE_C_COMPILER=$C_COMPILER \
68      -DCMAKE_CXX_COMPILER=$CXX_COMPILER \
69      -DLLVM_LIBC_FULL_BUILD=ON \
70      -DLIBC_TARGET_TRIPLE=<Your target triple> \
71      -DCMAKE_BUILD_TYPE=<Release|Debug>
73 We will go over the special options passed to the ``cmake`` command above.
75 * **Enabled Projects** - Since we want to build the libc project, we list
76   ``libc`` as the enabled project.
77 * **The full build option** - Since we want to build the full libc, we pass
78   ``-DLLVM_LIBC_FULL_BUILD=ON``.
79 * **The target triple** - This is the target triple of the target for which
80   we are building the libc. For example, for a Linux 32-bit Arm target,
81   one can specify it as ``arm-linux-eabi``.
83 Build step
84 ----------
86 After configuring the build with the above ``cmake`` command, one can build the
87 the libc for the target with the following command:
89 .. code-block:: sh
91    $> ninja libc libm
93 The above ``ninja`` command will build the libc static archives ``libc.a`` and
94 ``libm.a`` for the target specified with ``-DLIBC_TARGET_TRIPLE`` in the CMake
95 configure step.
97 .. _runtimes_cross_build:
99 Runtimes cross build
100 ====================
102 The *runtimes cross build* is very similar to the standalone crossbuild but the
103 user will have to first build the libc build tools for the host separately. One
104 should use this recipe if they want to use a different host and target compiler.
105 Note that the libc build tools MUST be in sync with the libc. That is, the
106 libc build tools and the libc, both should be built from the same source
107 revision. At the time of this writing, there is only one libc build tool that
108 has to be built separately. It is done as follows:
110 .. code-block:: sh
112   $> cd llvm-project  # The llvm-project checkout
113   $> mkdir build-libc-tools # A different build directory for the build tools
114   $> cd build-libc-tools
115   $> HOST_C_COMPILER=<C compiler for the host> # For example "clang"
116   $> HOST_CXX_COMPILER=<C++ compiler for the host> # For example "clang++"
117   $> cmake ../llvm  \
118      -G Ninja \
119      -DLLVM_ENABLE_PROJECTS=libc  \
120      -DCMAKE_C_COMPILER=$HOST_C_COMPILER \
121      -DCMAKE_CXX_COMPILER=$HOST_CXX_COMPILER  \
122      -DLLVM_LIBC_FULL_BUILD=ON \
123      -DCMAKE_BUILD_TYPE=Debug # User can choose to use "Release" build type
124   $> ninja libc-hdrgen
126 The above commands should build a binary named ``libc-hdrgen``. Copy this binary
127 to a directory of your choice.
129 CMake configure step
130 --------------------
132 After copying the ``libc-hdrgen`` binary to say ``/path/to/libc-hdrgen``,
133 configure the libc build using the following command:
135 .. code-block:: sh
137   $> cd llvm-project  # The llvm-project checkout
138   $> mkdir build
139   $> cd build
140   $> TARGET_C_COMPILER=<C compiler for the target>
141   $> TARGET_CXX_COMPILER=<C++ compiler for the target>
142   $> HDRGEN=</path/to/libc-hdrgen>
143   $> TARGET_TRIPLE=<Your target triple>
144   $> cmake ../runtimes  \
145      -G Ninja \
146      -DLLVM_ENABLE_RUNTIMES=libc  \
147      -DCMAKE_C_COMPILER=$TARGET_C_COMPILER \
148      -DCMAKE_CXX_COMPILER=$TARGET_CXX_COMPILER \
149      -DLLVM_LIBC_FULL_BUILD=ON \
150      -DLIBC_HDRGEN_EXE=$HDRGEN \
151      -DLIBC_TARGET_TRIPLE=$TARGET_TRIPLE \
152      -DCMAKE_BUILD_TYPE=Debug # User can choose to use "Release" build type
154 Note the differences in the above cmake command versus the one used in the
155 CMake configure step of the standalone build recipe:
157 * Instead of listing ``libc`` in ``LLVM_ENABLED_PROJECTS``, we list it in
158   ``LLVM_ENABLED_RUNTIMES``.
159 * Instead of using ``llvm-project/llvm`` as the root CMake source directory,
160   we use ``llvm-project/runtimes`` as the root CMake source directory.
161 * The path to the ``libc-hdrgen`` binary built earlier is specified with
162   ``-DLIBC_HDRGEN_EXE=/path/to/libc-hdrgen``.
164 Build step
165 ----------
167 The build step in the runtimes build recipe is exactly the same as that of
168 the standalone build recipe:
170 .. code-block:: sh
172     $> ninja libc libm
174 As with the standalone build recipe, the above ninja command will build the
175 libc static archives for the target specified with ``-DLIBC_TARGET_TRIPLE`` in
176 the CMake configure step.
179 Bootstrap cross build
180 =====================
182 In this recipe, the clang compiler and the ``libc-hdrgen`` binary, both are
183 built automatically before building the libc for the target.
185 CMake configure step
186 --------------------
188 .. code-block:: sh
190   $> cd llvm-project  # The llvm-project checkout
191   $> mkdir build
192   $> cd build
193   $> C_COMPILER=<C compiler> # For example "clang"
194   $> CXX_COMPILER=<C++ compiler> # For example "clang++"
195   $> TARGET_TRIPLE=<Your target triple>
196   $> cmake ../llvm \
197      -G Ninja \
198      -DCMAKE_C_COMPILER=$C_COMPILER \
199      -DCMAKE_CXX_COMPILER=$CXX_COMPILER \
200      -DLLVM_ENABLE_PROJECTS=clang \
201      -DLLVM_ENABLE_RUNTIMES=libc \
202      -DLLVM_LIBC_FULL_BUILD=ON \
203      -DLLVM_RUNTIME_TARGETS=$TARGET_TRIPLE \
204      -DCMAKE_BUILD_TYPE=Debug
206 Note how the above cmake command differs from the one used in the other two
207 recipes:
209 * ``clang`` is listed in ``-DLLVM_ENABLE_PROJECTS`` and ``libc`` is
210   listed in ``-DLLVM_ENABLE_RUNTIMES``.
211 * The CMake root source directory is ``llvm-project/llvm``.
212 * The target triple is specified with ``-DLLVM_RUNTIME_TARGETS``.
214 Build step
215 ----------
217 The build step is similar to the other two recipes:
219 .. code-block:: sh
221   $> ninja libc
223 The above ninja command should build the libc static archives for the target
224 specified with ``-DLLVM_RUNTIME_TARGETS``.
226 Building for bare metal
227 =======================
229 To build for bare metal, all one has to do is to specify the
230 `system <https://clang.llvm.org/docs/CrossCompilation.html#target-triple>`_
231 component of the target triple as ``none``. For example, to build for a
232 32-bit arm target on bare metal, one can use a target triple like
233 ``arm-none-eabi``. Other than that, the libc for a bare metal target can be
234 built using any of the three recipes described above.
236 Building for the GPU
237 ====================
239 To build for a GPU architecture, it should only be necessary to specify the 
240 target triple as one of the supported GPU targets. Currently, this is either 
241 ``nvptx64-nvidia-cuda`` for NVIDIA GPUs or ``amdgcn-amd-amdhsa`` for AMD GPUs. 
242 More detailed information is provided in the :ref:`GPU 
243 documentation<libc_gpu_building>`.