diff options
author | Bruce Ashfield <bruce.ashfield@gmail.com> | 2020-05-13 10:24:35 -0400 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2020-05-15 16:31:45 +0100 |
commit | 68ad04722892f547990c2aa7fc21aa009f8f00b6 (patch) | |
tree | 5dfb1f4b4cdb10b7a995a16b851028c06968d058 /meta/classes/kernel.bbclass | |
parent | 36a0e7e045767706d5557adda9be1b08ca2a6010 (diff) | |
download | poky-68ad04722892f547990c2aa7fc21aa009f8f00b6.tar.gz |
kernel/reproducibility: kernel modules need SOURCE_DATE_EPOCH export
If CONFIG_IKHEADERS is set to =m, then reproducibility issues creep
into the modules build, since the variables we are setting for the
main kernel build are not present.
Since the source code must be available for a possibly git query
on the timestamp, there didn't seem to be an easy way to move the
environment variable setting to a common routine. As such, we
duplicate the block of code that exports the required variables for
reproducible builds. There is a maintenance risk to this, but any
issues should be easy enough to catch.
(From OE-Core rev: 82cdfcdccfedd320ebc0cdc778c7d4966198b96f)
Signed-off-by: Bruce Ashfield <bruce.ashfield@gmail.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/kernel.bbclass')
-rw-r--r-- | meta/classes/kernel.bbclass | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/meta/classes/kernel.bbclass b/meta/classes/kernel.bbclass index 6846d6040d..0935196f6f 100644 --- a/meta/classes/kernel.bbclass +++ b/meta/classes/kernel.bbclass | |||
@@ -331,6 +331,21 @@ kernel_do_compile() { | |||
331 | 331 | ||
332 | do_compile_kernelmodules() { | 332 | do_compile_kernelmodules() { |
333 | unset CFLAGS CPPFLAGS CXXFLAGS LDFLAGS MACHINE | 333 | unset CFLAGS CPPFLAGS CXXFLAGS LDFLAGS MACHINE |
334 | if [ "${BUILD_REPRODUCIBLE_BINARIES}" = "1" ]; then | ||
335 | # kernel sources do not use do_unpack, so SOURCE_DATE_EPOCH may not | ||
336 | # be set.... | ||
337 | if [ "${SOURCE_DATE_EPOCH}" = "" -o "${SOURCE_DATE_EPOCH}" = "0" ]; then | ||
338 | # The source directory is not necessarily a git repository, so we | ||
339 | # specify the git-dir to ensure that git does not query a | ||
340 | # repository in any parent directory. | ||
341 | SOURCE_DATE_EPOCH=`git --git-dir="${S}/.git" log -1 --pretty=%ct 2>/dev/null || echo "${REPRODUCIBLE_TIMESTAMP_ROOTFS}"` | ||
342 | fi | ||
343 | |||
344 | ts=`LC_ALL=C date -d @$SOURCE_DATE_EPOCH` | ||
345 | export KBUILD_BUILD_TIMESTAMP="$ts" | ||
346 | export KCONFIG_NOTIMESTAMP=1 | ||
347 | bbnote "KBUILD_BUILD_TIMESTAMP: $ts" | ||
348 | fi | ||
334 | if (grep -q -i -e '^CONFIG_MODULES=y$' ${B}/.config); then | 349 | if (grep -q -i -e '^CONFIG_MODULES=y$' ${B}/.config); then |
335 | cc_extra=$(get_cc_option) | 350 | cc_extra=$(get_cc_option) |
336 | oe_runmake -C ${B} ${PARALLEL_MAKE} modules CC="${KERNEL_CC} $cc_extra " LD="${KERNEL_LD}" ${KERNEL_EXTRA_ARGS} | 351 | oe_runmake -C ${B} ${PARALLEL_MAKE} modules CC="${KERNEL_CC} $cc_extra " LD="${KERNEL_LD}" ${KERNEL_EXTRA_ARGS} |