[libc-commits] [libc] [libc] update host build docs (PR #120147)
Michael Jones via libc-commits
libc-commits at lists.llvm.org
Thu Dec 19 10:24:39 PST 2024
https://github.com/michaelrj-google updated https://github.com/llvm/llvm-project/pull/120147
>From 8d375c5b399714ddc9a812bc3e340291e698ee30 Mon Sep 17 00:00:00 2001
From: Michael Jones <michaelrj at google.com>
Date: Wed, 11 Dec 2024 10:37:07 -0800
Subject: [PATCH 1/5] [libc] update host build docs
Update the host build docs to better reflect the current recommended
process.
---
libc/docs/dev/index.rst | 1 +
libc/docs/full_host_build.rst | 90 +++++++++++++-------------
libc/test/src/__support/CMakeLists.txt | 38 +++++------
3 files changed, 66 insertions(+), 63 deletions(-)
diff --git a/libc/docs/dev/index.rst b/libc/docs/dev/index.rst
index c16121feb3a45d..9ed50bb6683aae 100644
--- a/libc/docs/dev/index.rst
+++ b/libc/docs/dev/index.rst
@@ -7,6 +7,7 @@ Developer Guides
Navigate to the links below for information on the respective topics:
.. toctree::
+ :maxdepth: 1
code_style
source_tree_layout
diff --git a/libc/docs/full_host_build.rst b/libc/docs/full_host_build.rst
index f687c2fdab213e..c45fc7c94f1c82 100644
--- a/libc/docs/full_host_build.rst
+++ b/libc/docs/full_host_build.rst
@@ -8,7 +8,7 @@ Full Host Build
:depth: 1
:local:
-.. note::
+.. note::
Fullbuild requires running headergen, which is a python program that depends on
pyyaml. The minimum versions are listed on the :ref:`header_generation`
page, as well as additional information.
@@ -99,11 +99,16 @@ a C++ standard library (like libc++). Hence, we do not include
`libc++ <https://libcxx.llvm.org/>`_, libcxx-abi and libunwind in the
LLVM only toolchain and use them to build and link C++ applications.
-Below is the list of commands for a simple recipe to build and install the
-libc components along with other components of an LLVM only toolchain. In this
-we've set the Ninja generator, enabled a full compiler suite, set the build
-type to "Debug", and enabled the Scudo allocator. The build also tells clang
-to use the freshly built lld and compiler-rt.
+Below is the cmake command for a bootstrapping build of LLVM. This will build
+clang and lld with the current system's toolchain, then build compiler-rt and
+LLVM-libc with that freshly built clang. This ensures that LLVM-libc can take
+advantage of the latest clang features and optimizations.
+
+This build also uses Ninja as cmake's generator, and sets lld and compiler-rt as
+the default for the fresh clang. Those settings are recommended, but the build
+should still work without them. The compiler-rt options are required for
+building `Scudo <https://llvm.org/docs/ScudoHardenedAllocator.html>`_ as the
+allocator for LLVM-libc.
.. note::
if your build fails with an error saying the compiler can't find
@@ -113,7 +118,6 @@ to use the freshly built lld and compiler-rt.
this command:
``sudo ln -s /usr/include/<TARGET TRIPLE>/asm /usr/include/asm``
-.. TODO: Move from projects to runtimes for libc, compiler-rt
.. code-block:: sh
$> cd llvm-project # The llvm-project checkout
@@ -121,36 +125,20 @@ to use the freshly built lld and compiler-rt.
$> cd build
$> SYSROOT=/path/to/sysroot # Remember to set this!
$> cmake ../llvm \
- -G Ninja \
- -DLLVM_ENABLE_PROJECTS="clang;lld;libc;compiler-rt" \
- -DCMAKE_BUILD_TYPE=Debug \
- -DCMAKE_C_COMPILER=clang \
- -DCMAKE_CXX_COMPILER=clang++ \
- -DLLVM_LIBC_FULL_BUILD=ON \
- -DLLVM_LIBC_INCLUDE_SCUDO=ON \
- -DCOMPILER_RT_BUILD_SCUDO_STANDALONE_WITH_LLVM_LIBC=ON \
- -DCOMPILER_RT_BUILD_GWP_ASAN=OFF \
- -DCOMPILER_RT_SCUDO_STANDALONE_BUILD_SHARED=OFF \
- -DCLANG_DEFAULT_LINKER=lld \
- -DCLANG_DEFAULT_RTLIB=compiler-rt \
- -DDEFAULT_SYSROOT=$SYSROOT \
- -DCMAKE_INSTALL_PREFIX=$SYSROOT
-
-We will go over some of the special options passed to the ``cmake`` command
-above.
-
-* **Enabled Projects** - Since we want to build and install clang, lld
- and compiler-rt along with the libc, we specify
- ``clang;libc;lld;compiler-rt`` as the list of enabled projects.
-* **The full build option** - Since we want to do build the full libc, we pass
- ``-DLLVM_LIBC_FULL_BUILD=ON``.
-* **Scudo related options** - LLVM's libc uses
- `Scudo <https://llvm.org/docs/ScudoHardenedAllocator.html>`_ as its allocator.
- So, when building the full libc, we should specify that we want to include
- Scudo in the libc. Since the libc currently only supports static linking, we
- also specify that we do not want to build the Scudo shared library.
-* **Default sysroot and install prefix** - This is the path to the tool chain
- install directory. This is the directory where you intend to set up the sysroot.
+ -G Ninja \
+ -DLLVM_ENABLE_PROJECTS="clang;lld" \
+ -DLLVM_ENABLE_RUNTIMES="libc;compiler-rt" \
+ -DCMAKE_BUILD_TYPE=Release \
+ -DCMAKE_C_COMPILER=clang \
+ -DCMAKE_CXX_COMPILER=clang++ \
+ -DLLVM_LIBC_FULL_BUILD=ON \
+ -DLLVM_LIBC_INCLUDE_SCUDO=ON \
+ -DCOMPILER_RT_BUILD_SCUDO_STANDALONE_WITH_LLVM_LIBC=ON \
+ -DCOMPILER_RT_BUILD_GWP_ASAN=OFF \
+ -DCOMPILER_RT_SCUDO_STANDALONE_BUILD_SHARED=OFF \
+ -DCLANG_DEFAULT_LINKER=lld \
+ -DCLANG_DEFAULT_RTLIB=compiler-rt \
+ -DCMAKE_INSTALL_PREFIX=$SYSROOT
Build and install
=================
@@ -164,13 +152,12 @@ Build and install
you may need to delete them from ``/usr/local/include``.
After configuring the build with the above ``cmake`` command, one can build and
-install the libc, clang (and its support libraries and builtins), lld and
-compiler-rt, with the following command:
+install the toolchain with
.. code-block:: sh
- $> ninja install-clang install-builtins install-compiler-rt \
- install-core-resource-headers install-libc install-lld
+ $> ninja all
+ $> ninja install
Once the above command completes successfully, the ``$SYSROOT`` directory you
have specified with the CMake configure step above will contain a full LLVM-only
@@ -190,9 +177,9 @@ These instructions should work on a Debian-based x86_64 system:
$> apt download linux-libc-dev
$> dpkg -x linux-libc-dev*deb .
- $> mv usr/include/* /path/to/sysroot/include
- $> rm -rf usr linux-libc-dev*deb
- $> ln -s x86_64-linux-gnu/asm ~/Programming/sysroot/include/asm
+ $> cp -r usr/* /path/to/sysroot/
+ $> rm -r usr linux-libc-dev*deb
+ $> ln -s /path/to/sysroot/include/x86_64-linux-gnu/asm /path/to/sysroot/include/asm
Using your newly built libc
===========================
@@ -208,3 +195,18 @@ invocation:
Because the libc does not yet support dynamic linking, the -static parameter
must be added to all clang invocations.
+
+You can make sure you're using the newly built toolchain by trying out features
+that aren't yet supported by the system toolchain, such as fixed point. The
+following is an example program that demonstrates the difference:
+
+.. code-block:: C
+
+ #include <stdio.h>
+ int main() {
+ printf("Hello, World!\n%.9f\n%.9lK\n",
+ 4294967295.000000001,
+ 4294967295.000000001ulK);
+ return 0;
+ }
+
diff --git a/libc/test/src/__support/CMakeLists.txt b/libc/test/src/__support/CMakeLists.txt
index bcc86effd9a52c..14302c185b6357 100644
--- a/libc/test/src/__support/CMakeLists.txt
+++ b/libc/test/src/__support/CMakeLists.txt
@@ -252,29 +252,29 @@ add_libc_test(
# FIXME: We shouldn't have regular executables created because we could be
# cross-compiling the tests and running through an emulator.
if(NOT LIBC_TARGET_OS_IS_GPU)
- add_executable(
- libc_str_to_float_comparison_test
- str_to_float_comparison_test.cpp
- )
+ # add_executable(
+ # libc_str_to_float_comparison_test
+ # str_to_float_comparison_test.cpp
+ # )
- target_link_libraries(libc_str_to_float_comparison_test
- PRIVATE
- "${LIBC_TARGET}"
- )
+ # target_link_libraries(libc_str_to_float_comparison_test
+ # PRIVATE
+ # "${LIBC_TARGET}"
+ # )
- add_executable(
- libc_system_str_to_float_comparison_test
- str_to_float_comparison_test.cpp
- )
+ # add_executable(
+ # libc_system_str_to_float_comparison_test
+ # str_to_float_comparison_test.cpp
+ # )
- set(float_test_file ${CMAKE_CURRENT_SOURCE_DIR}/str_to_float_comparison_data.txt)
+ # set(float_test_file ${CMAKE_CURRENT_SOURCE_DIR}/str_to_float_comparison_data.txt)
- add_custom_command(TARGET libc_str_to_float_comparison_test
- POST_BUILD
- COMMAND ${CMAKE_CROSSCOMPILING_EMULATOR} $<TARGET_FILE:libc_str_to_float_comparison_test> ${float_test_file}
- DEPENDS ${float_test_file}
- COMMENT "Test the strtof and strtod implementations against precomputed results."
- VERBATIM)
+ # add_custom_command(TARGET libc_str_to_float_comparison_test
+ # POST_BUILD
+ # COMMAND ${CMAKE_CROSSCOMPILING_EMULATOR} $<TARGET_FILE:libc_str_to_float_comparison_test> ${float_test_file}
+ # DEPENDS ${float_test_file}
+ # COMMENT "Test the strtof and strtod implementations against precomputed results."
+ # VERBATIM)
endif()
add_subdirectory(CPP)
>From 81eea419bf00c1a9cf18913f67a664afefbedbfe Mon Sep 17 00:00:00 2001
From: Michael Jones <michaelrj at google.com>
Date: Wed, 18 Dec 2024 09:37:17 -0800
Subject: [PATCH 2/5] address comments
---
libc/docs/full_host_build.rst | 9 ++++++++-
1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/libc/docs/full_host_build.rst b/libc/docs/full_host_build.rst
index c45fc7c94f1c82..02c0739a6bc434 100644
--- a/libc/docs/full_host_build.rst
+++ b/libc/docs/full_host_build.rst
@@ -156,7 +156,13 @@ install the toolchain with
.. code-block:: sh
- $> ninja all
+ $> ninja install-clang install-builtins install-compiler-rt \
+ install-core-resource-headers install-libc install-lld
+
+or
+
+.. code-block:: sh
+
$> ninja install
Once the above command completes successfully, the ``$SYSROOT`` directory you
@@ -201,6 +207,7 @@ that aren't yet supported by the system toolchain, such as fixed point. The
following is an example program that demonstrates the difference:
.. code-block:: C
+ // $ $SYSROOT/bin/clang example.c -static -ffixed-point --sysroot=$SYSROOT
#include <stdio.h>
int main() {
>From 9791c7a3ec29bac0cda97fd502ccfd94b0743243 Mon Sep 17 00:00:00 2001
From: Michael Jones <michaelrj at google.com>
Date: Wed, 18 Dec 2024 09:40:04 -0800
Subject: [PATCH 3/5] remove cmake changes
---
libc/test/src/__support/CMakeLists.txt | 38 +++++++++++++-------------
1 file changed, 19 insertions(+), 19 deletions(-)
diff --git a/libc/test/src/__support/CMakeLists.txt b/libc/test/src/__support/CMakeLists.txt
index 14302c185b6357..bcc86effd9a52c 100644
--- a/libc/test/src/__support/CMakeLists.txt
+++ b/libc/test/src/__support/CMakeLists.txt
@@ -252,29 +252,29 @@ add_libc_test(
# FIXME: We shouldn't have regular executables created because we could be
# cross-compiling the tests and running through an emulator.
if(NOT LIBC_TARGET_OS_IS_GPU)
- # add_executable(
- # libc_str_to_float_comparison_test
- # str_to_float_comparison_test.cpp
- # )
+ add_executable(
+ libc_str_to_float_comparison_test
+ str_to_float_comparison_test.cpp
+ )
- # target_link_libraries(libc_str_to_float_comparison_test
- # PRIVATE
- # "${LIBC_TARGET}"
- # )
+ target_link_libraries(libc_str_to_float_comparison_test
+ PRIVATE
+ "${LIBC_TARGET}"
+ )
- # add_executable(
- # libc_system_str_to_float_comparison_test
- # str_to_float_comparison_test.cpp
- # )
+ add_executable(
+ libc_system_str_to_float_comparison_test
+ str_to_float_comparison_test.cpp
+ )
- # set(float_test_file ${CMAKE_CURRENT_SOURCE_DIR}/str_to_float_comparison_data.txt)
+ set(float_test_file ${CMAKE_CURRENT_SOURCE_DIR}/str_to_float_comparison_data.txt)
- # add_custom_command(TARGET libc_str_to_float_comparison_test
- # POST_BUILD
- # COMMAND ${CMAKE_CROSSCOMPILING_EMULATOR} $<TARGET_FILE:libc_str_to_float_comparison_test> ${float_test_file}
- # DEPENDS ${float_test_file}
- # COMMENT "Test the strtof and strtod implementations against precomputed results."
- # VERBATIM)
+ add_custom_command(TARGET libc_str_to_float_comparison_test
+ POST_BUILD
+ COMMAND ${CMAKE_CROSSCOMPILING_EMULATOR} $<TARGET_FILE:libc_str_to_float_comparison_test> ${float_test_file}
+ DEPENDS ${float_test_file}
+ COMMENT "Test the strtof and strtod implementations against precomputed results."
+ VERBATIM)
endif()
add_subdirectory(CPP)
>From f604330ae1ef0f77f07df3b4eebaecbf9f79f1b8 Mon Sep 17 00:00:00 2001
From: Michael Jones <michaelrj at google.com>
Date: Wed, 18 Dec 2024 09:41:51 -0800
Subject: [PATCH 4/5] fix formatting
---
libc/docs/full_host_build.rst | 28 ++++++++++++++--------------
1 file changed, 14 insertions(+), 14 deletions(-)
diff --git a/libc/docs/full_host_build.rst b/libc/docs/full_host_build.rst
index 02c0739a6bc434..0f42e24999f310 100644
--- a/libc/docs/full_host_build.rst
+++ b/libc/docs/full_host_build.rst
@@ -125,20 +125,20 @@ allocator for LLVM-libc.
$> cd build
$> SYSROOT=/path/to/sysroot # Remember to set this!
$> cmake ../llvm \
- -G Ninja \
- -DLLVM_ENABLE_PROJECTS="clang;lld" \
- -DLLVM_ENABLE_RUNTIMES="libc;compiler-rt" \
- -DCMAKE_BUILD_TYPE=Release \
- -DCMAKE_C_COMPILER=clang \
- -DCMAKE_CXX_COMPILER=clang++ \
- -DLLVM_LIBC_FULL_BUILD=ON \
- -DLLVM_LIBC_INCLUDE_SCUDO=ON \
- -DCOMPILER_RT_BUILD_SCUDO_STANDALONE_WITH_LLVM_LIBC=ON \
- -DCOMPILER_RT_BUILD_GWP_ASAN=OFF \
- -DCOMPILER_RT_SCUDO_STANDALONE_BUILD_SHARED=OFF \
- -DCLANG_DEFAULT_LINKER=lld \
- -DCLANG_DEFAULT_RTLIB=compiler-rt \
- -DCMAKE_INSTALL_PREFIX=$SYSROOT
+ -G Ninja \
+ -DLLVM_ENABLE_PROJECTS="clang;lld" \
+ -DLLVM_ENABLE_RUNTIMES="libc;compiler-rt" \
+ -DCMAKE_BUILD_TYPE=Release \
+ -DCMAKE_C_COMPILER=clang \
+ -DCMAKE_CXX_COMPILER=clang++ \
+ -DLLVM_LIBC_FULL_BUILD=ON \
+ -DLLVM_LIBC_INCLUDE_SCUDO=ON \
+ -DCOMPILER_RT_BUILD_SCUDO_STANDALONE_WITH_LLVM_LIBC=ON \
+ -DCOMPILER_RT_BUILD_GWP_ASAN=OFF \
+ -DCOMPILER_RT_SCUDO_STANDALONE_BUILD_SHARED=OFF \
+ -DCLANG_DEFAULT_LINKER=lld \
+ -DCLANG_DEFAULT_RTLIB=compiler-rt \
+ -DCMAKE_INSTALL_PREFIX=$SYSROOT
Build and install
=================
>From c665b048fdf999dbb780411d60cce57e2a319853 Mon Sep 17 00:00:00 2001
From: Michael Jones <michaelrj at google.com>
Date: Thu, 19 Dec 2024 10:24:20 -0800
Subject: [PATCH 5/5] fix code block
---
libc/docs/full_host_build.rst | 1 +
1 file changed, 1 insertion(+)
diff --git a/libc/docs/full_host_build.rst b/libc/docs/full_host_build.rst
index 0f42e24999f310..e25079141f47b2 100644
--- a/libc/docs/full_host_build.rst
+++ b/libc/docs/full_host_build.rst
@@ -207,6 +207,7 @@ that aren't yet supported by the system toolchain, such as fixed point. The
following is an example program that demonstrates the difference:
.. code-block:: C
+
// $ $SYSROOT/bin/clang example.c -static -ffixed-point --sysroot=$SYSROOT
#include <stdio.h>
More information about the libc-commits
mailing list