[OE-core] [PATCH] libc6: improve reproducibility
Richard Purdie
richard.purdie at linuxfoundation.org
Sat Jan 13 10:11:13 UTC 2018
On Fri, 2018-01-12 at 13:04 -0800, Juro Bystricky wrote:
> Building various libraries (libc6, libc6-pic, libc6-staticdev, libc6-
> dbg, ...)
> can be non-deterministic because they may be built with two different
> versions
> of intl/plural.c. in two otherwise identical builds. We may or may
> not re-generate
> the file plural.c from the file plural.y, based on bison being
> installed or not
> and based on mtimes of those two files, as the Makefile contains:
>
> plural.c: plural.y
> $(BISON) $(BISONFLAGS) $@ $^
>
> If the above rule does not fire, we use a "fallback" plural.c,
> otherwise
> we use plural.c re-generated from plural.y.
> The fix is to always require bison to be installed and
> unconditionally
> re-generate plural.c. (This is achieved by touching plural.y).
>
> [YOCTO #12291]
>
> Signed-off-by: Juro Bystricky <juro.bystricky at intel.com>
> ---
> meta/recipes-core/glibc/glibc_2.26.bb | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
Hi Juro,
Can you put a comment alongside the touch in the recipe as we're not
going to know why we're doing this in a few years time...
Cheers,
Richard
> diff --git a/meta/recipes-core/glibc/glibc_2.26.bb b/meta/recipes-
> core/glibc/glibc_2.26.bb
> index 04d9773..4d9b23f 100644
> --- a/meta/recipes-core/glibc/glibc_2.26.bb
> +++ b/meta/recipes-core/glibc/glibc_2.26.bb
> @@ -5,7 +5,7 @@ LIC_FILES_CHKSUM = "file://LICENSES;md5=e9a558e243b36
> d3209f380deb394b213 \
> file://posix/rxspencer/COPYRIGHT;md5=dc5485bb394a13b2332ec1c78
> 5f5d83a \
> file://COPYING.LIB;md5=4fbd65380cdd255951079008b364516c"
>
> -DEPENDS += "gperf-native"
> +DEPENDS += "gperf-native bison-native"
>
> SRCREV ?= "77f921dac17c5fa99bd9e926d926c327982895f7"
>
> @@ -103,6 +103,7 @@ do_configure () {
> # version check and doesn't really help with anything
> (cd ${S} && gnu-configize) || die "failure in running gnu-
> configize"
> find ${S} -name "configure" | xargs touch
> + find ${S}/intl -name "plural.y" | xargs touch
> CPPFLAGS="" oe_runconf
> }
>
More information about the Openembedded-core
mailing list