[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