Re: [PATCH v6 2/2] kbuild: distributed build support for Clang ThinLTO

From: Nicolas Schier

Date: Fri Mar 27 2026 - 04:09:12 EST


On Mon, Mar 16, 2026 at 09:29:30PM +0000, xur@xxxxxxxxxx wrote:
> From: Rong Xu <xur@xxxxxxxxxx>
>
> Add distributed ThinLTO build support for the Linux kernel.
> This new mode offers several advantages: (1) Increased
> flexibility in handling user-specified build options.
> (2) Improved user-friendliness for developers. (3) Greater
> convenience for integrating with objtool and livepatch.
>
> Note that "distributed" in this context refers to a term
> that differentiates in-process ThinLTO builds by invoking
> backend compilation through the linker, not necessarily
> building in distributed environments.
>
> Distributed ThinLTO is enabled via the
> `CONFIG_LTO_CLANG_THIN_DIST` Kconfig option. For example:
> > make LLVM=1 defconfig
> > scripts/config -e LTO_CLANG_THIN_DIST
> > make LLVM=1 oldconfig
> > make LLVM=1 vmlinux -j <..>
>
> The build flow proceeds in four stages:
> 1. Perform FE compilation, mirroring the in-process ThinLTO mode.
> 2. Thin-link the generated IR files and object files.
> 3. Find all IR files and perform BE compilation, using the flags
> stored in the .*.o.cmd files.
> 4. Link the BE results to generate the final vmlinux.o.
>
> NOTE: This patch currently implements the build for the main kernel
> image (vmlinux) only. Kernel module support is planned for a
> subsequent patch.
>
> Tested on the following arch: x86, arm64, loongarch, and
> riscv.
>
> The earlier implementation details can be found here:
> https://discourse.llvm.org/t/rfc-distributed-thinlto-build-for-kernel/85934
>
> Signed-off-by: Rong Xu <xur@xxxxxxxxxx>
> Co-developed-by: Masahiro Yamada <masahiroy@xxxxxxxxxx>
> Signed-off-by: Masahiro Yamada <masahiroy@xxxxxxxxxx>
> Tested-by: Piotr Gorski <piotrgorski@xxxxxxxxxxx>
> Reviewed-by: Nathan Chancellor <nathan@xxxxxxxxxx>
> Tested-by: Nathan Chancellor <nathan@xxxxxxxxxx>
> ---
> .gitignore | 2 ++
> Makefile | 9 +++++----
> arch/Kconfig | 19 ++++++++++++++++++
> scripts/Makefile.lib | 7 +++++++
> scripts/Makefile.thinlto | 40 ++++++++++++++++++++++++++++++++++++++
> scripts/Makefile.vmlinux_a | 37 +++++++++++++++++++++++++++++++++++
> scripts/mod/modpost.c | 15 +++++++++++---
> 7 files changed, 122 insertions(+), 7 deletions(-)
> create mode 100644 scripts/Makefile.thinlto
>
> diff --git a/.gitignore b/.gitignore
> index 3a7241c941f5..c12bdf5a97f9 100644
> --- a/.gitignore
> +++ b/.gitignore
> @@ -56,6 +56,7 @@
> *.zst
> Module.symvers
> dtbs-list
> +builtin.order
> modules.order
>
> #
> @@ -67,6 +68,7 @@ modules.order
> /vmlinux.32
> /vmlinux.map
> /vmlinux.symvers
> +/vmlinux.thinlto-index
> /vmlinux.unstripped
> /vmlinux-gdb.py
> /vmlinuz
> diff --git a/Makefile b/Makefile
> index ba5eee68d5d2..4a399b7f3b48 100644
> --- a/Makefile
> +++ b/Makefile
> @@ -1033,10 +1033,10 @@ export CC_FLAGS_SCS
> endif
>
> ifdef CONFIG_LTO_CLANG
> -ifdef CONFIG_LTO_CLANG_THIN
> -CC_FLAGS_LTO := -flto=thin -fsplit-lto-unit
> -else
> +ifdef CONFIG_LTO_CLANG_FULL
> CC_FLAGS_LTO := -flto
> +else
> +CC_FLAGS_LTO := -flto=thin -fsplit-lto-unit
> endif
> CC_FLAGS_LTO += -fvisibility=hidden
>

This hunk does not apply on kbuild-next-unstable [1] (a possible
conflict resolution: [2]). Can you please rebase the patch set on
kbuild-next-unstable as Nathan suggested [3] ?

Thanks and kind regards
Nicolas

[1]: https://git.kernel.org/kbuild/l/kbuild-next-unstable
[2]: https://git.kernel.org/nsc/kbuild/c/505471374cfb107
[3]: https://lore.kernel.org/linux-kbuild/20260316204311.GA1329928@ax162/