[PATCH/RFC] kernel-defaults.mk: get rid of BuildID
Felix Fietkau
nbd at nbd.name
Tue Apr 5 08:05:43 PDT 2022
On 05.04.22 03:14, Daniel Golle wrote:
> When building the Linux kernel, the linker generates a hash of all
> versions of tools involved in a build called BuildID in ELF header.
> This breaks reproducibility accross different buildhosts eventhough
> OpenWrt builds the toolchain from source -- the build-id hash ends up
> to be the only thing which differs in the resulting builds.
>
> The cause is most likely a result of the build hosts' architectures,
> OSs and standard C libraries being different.
>
> While in theory it is true that tools may produce a different output
> depending on archtecture, OS and libc of the buildhost, in practice
> this is (fortunately) hardly ever the case and hence it contradicts
> ld(1) which states:
>
> 'The "md5" and "sha1" styles produces an identifier that is always
> the same in an identical output file, but will be unique among all
> nonidentical output files.'
>
> (the kernel is using sha1 style build-id, rebuilding the kernel on a
> different buildhost results in everything being identical **except**
> for the build-id)
>
> Hence, to achieve reproducible builds we will either have to resort to
> identical containers/VMs for building or get rid of the BuildID hash
> alltogether (or use a different build-id style)
>
> At this point, this seems to be what Debian is doing as well in order
> to achieve reproducible kernel builds, see[1].
>
> [1]: https://wiki.debian.org/SameKernel#How_this_works
> Signed-off-by: Daniel Golle <daniel at makrotopia.org>
>
> diff --git a/include/kernel-defaults.mk b/include/kernel-defaults.mk
> index 1e82f7d739..9c8d5fbe97 100644
> --- a/include/kernel-defaults.mk
> +++ b/include/kernel-defaults.mk
> @@ -46,6 +46,7 @@ else
> if [ -d $(LINUX_DIR)/user_headers ]; then \
> rm -rf $(LINUX_DIR)/user_headers; \
> fi
> + $(SED) -i $(LINUX_DIR)/Makefile -e 's/--build-id=.*/--build-id=none/g'
I don't like running sed on the linux Makefile, as this interferes with
creating patches for it. I think it would be better to simply override
KBUILD_LDFLAGS_MODULE on the kernel/module build command line.
- Felix
More information about the openwrt-devel
mailing list