[oe] [meta-networking][PATCH 1/4] libtalloc: fixes for deterministic builds

Martin Jansa martin.jansa at gmail.com
Tue Sep 20 06:46:30 UTC 2016


On Tue, Sep 20, 2016 at 01:42:23PM +0800, jackie.huang at windriver.com wrote:
> From: Jackie Huang <jackie.huang at windriver.com>
> 
> * Add configure option and PACKAGECONFIG for
>   the following packages:
>   - acl
>   - attr
>   - libaio
>   - libcap
>   - valgrind
> 
> * They are all optional, so disable by default
>   or control them based on DISTRO_FEATURES.
> 
> * Remove the direct dependency on libaio
> 
> Signed-off-by: Jackie Huang <jackie.huang at windriver.com>
> ---
>  ...talloc-Add-configure-options-for-packages.patch | 124 +++++++++++++++++++++
>  .../recipes-support/libtalloc/libtalloc_2.1.8.bb   |  16 ++-
>  2 files changed, 137 insertions(+), 3 deletions(-)
>  create mode 100644 meta-networking/recipes-support/libtalloc/libtalloc/talloc-Add-configure-options-for-packages.patch
> 
> diff --git a/meta-networking/recipes-support/libtalloc/libtalloc/talloc-Add-configure-options-for-packages.patch b/meta-networking/recipes-support/libtalloc/libtalloc/talloc-Add-configure-options-for-packages.patch
> new file mode 100644
> index 0000000..d383df4
> --- /dev/null
> +++ b/meta-networking/recipes-support/libtalloc/libtalloc/talloc-Add-configure-options-for-packages.patch
> @@ -0,0 +1,124 @@
> +From 77fd757624c9b20073a7abefaca8382caa4fd376 Mon Sep 17 00:00:00 2001
> +From: Jackie Huang <jackie.huang at windriver.com>
> +Date: Wed, 14 Sep 2016 11:11:35 +0800
> +Subject: [PATCH] talloc: Add configure options for packages
> +
> +Add configure options for the following packages:
> + - acl
> + - attr
> + - libaio
> + - libcap
> + - valgrind
> +
> +Upstream-Status: Inappropriate [oe deterministic build specific]
> +
> +Signed-off-by: Jackie Huang <jackie.huang at windriver.com>
> +---
> + lib/replace/system/wscript_configure |  6 ++++-
> + lib/replace/wscript                  | 43 +++++++++++++++++++++++++++++++-----
> + wscript                              |  4 ++++
> + 3 files changed, 46 insertions(+), 7 deletions(-)
> +
> +diff --git a/lib/replace/system/wscript_configure b/lib/replace/system/wscript_configure
> +index 2035474..10f9ae7 100644
> +--- a/lib/replace/system/wscript_configure
> ++++ b/lib/replace/system/wscript_configure
> +@@ -1,6 +1,10 @@
> + #!/usr/bin/env python
> + 
> +-conf.CHECK_HEADERS('sys/capability.h')
> ++import Options
> ++
> ++if Options.options.enable_libcap:
> ++    conf.CHECK_HEADERS('sys/capability.h')
> ++
> + conf.CHECK_FUNCS('getpwnam_r getpwuid_r getpwent_r')
> + 
> + # solaris varients of getXXent_r
> +diff --git a/lib/replace/wscript b/lib/replace/wscript
> +index fc43e1a..a899dd2 100644
> +--- a/lib/replace/wscript
> ++++ b/lib/replace/wscript
> +@@ -23,6 +23,22 @@ def set_options(opt):
> +     opt.PRIVATE_EXTENSION_DEFAULT('')
> +     opt.RECURSE('buildtools/wafsamba')
> + 
> ++    opt.add_option('--with-acl',
> ++                   help=("Enable use of acl"),
> ++                   action="store_true", dest='enable_acl', default=False)
> ++
> ++    opt.add_option('--with-attr',
> ++                   help=("Enable use of attr"),
> ++                   action="store_true", dest='enable_attr', default=False)
> ++
> ++    opt.add_option('--with-libaio',
> ++                   help=("Enable use of libaio"),
> ++                   action="store_true", dest='enable_libaio', default=False)
> ++
> ++    opt.add_option('--with-libcap',
> ++                   help=("Enable use of libcap"),
> ++                   action="store_true", dest='enable_libcap', default=False)
> ++
> + @Utils.run_once
> + def configure(conf):
> +     conf.RECURSE('buildtools/wafsamba')
> +@@ -32,12 +48,25 @@ def configure(conf):
> +     conf.DEFINE('HAVE_LIBREPLACE', 1)
> +     conf.DEFINE('LIBREPLACE_NETWORK_CHECKS', 1)
> + 
> +-    conf.CHECK_HEADERS('linux/types.h crypt.h locale.h acl/libacl.h compat.h')
> +-    conf.CHECK_HEADERS('acl/libacl.h attr/xattr.h compat.h ctype.h dustat.h')
> ++    conf.CHECK_HEADERS('linux/types.h crypt.h locale.h compat.h')
> ++    conf.CHECK_HEADERS('compat.h ctype.h dustat.h')
> +     conf.CHECK_HEADERS('fcntl.h fnmatch.h glob.h history.h krb5.h langinfo.h')
> +-    conf.CHECK_HEADERS('libaio.h locale.h ndir.h pwd.h')
> +-    conf.CHECK_HEADERS('shadow.h sys/acl.h')
> +-    conf.CHECK_HEADERS('sys/attributes.h attr/attributes.h sys/capability.h sys/dir.h sys/epoll.h')
> ++    conf.CHECK_HEADERS('locale.h ndir.h pwd.h')
> ++    conf.CHECK_HEADERS('shadow.h')
> ++    conf.CHECK_HEADERS('sys/attributes.h sys/dir.h sys/epoll.h')
> ++
> ++    if Options.options.enable_acl:
> ++        conf.CHECK_HEADERS('acl/libacl.h sys/acl.h')
> ++
> ++    if Options.options.enable_attr:
> ++        conf.CHECK_HEADERS('attr/attributes.h attr/xattr.h')
> ++
> ++    if Options.options.enable_libaio:
> ++        conf.CHECK_HEADERS('libaio.h')
> ++
> ++    if Options.options.enable_libcap:
> ++        conf.CHECK_HEADERS('sys/capability.h')
> ++
> +     conf.CHECK_HEADERS('port.h')
> +     conf.CHECK_HEADERS('sys/fcntl.h sys/filio.h sys/filsys.h sys/fs/s5param.h sys/fs/vx/quota.h')
> +     conf.CHECK_HEADERS('sys/id.h sys/ioctl.h sys/ipc.h sys/mman.h sys/mode.h sys/ndir.h sys/priv.h')
> +@@ -73,7 +102,9 @@ def configure(conf):
> + 
> +     conf.CHECK_CODE('', headers='rpc/rpc.h rpcsvc/yp_prot.h', define='HAVE_RPCSVC_YP_PROT_H')
> + 
> +-    conf.CHECK_HEADERS('valgrind.h valgrind/valgrind.h valgrind/memcheck.h')
> ++    if Options.options.enable_valgrind:
> ++        conf.CHECK_HEADERS('valgrind.h valgrind/valgrind.h valgrind/memcheck.h')
> ++
> +     conf.CHECK_HEADERS('nss_common.h nsswitch.h ns_api.h')
> +     conf.CHECK_HEADERS('sys/extattr.h sys/ea.h sys/proplist.h sys/cdefs.h')
> +     conf.CHECK_HEADERS('utmp.h utmpx.h lastlog.h')
> +diff --git a/wscript b/wscript
> +index 41f3be7..f900c24 100644
> +--- a/wscript
> ++++ b/wscript
> +@@ -35,6 +35,10 @@ def set_options(opt):
> +         opt.add_option('--disable-python',
> +                        help=("disable the pytalloc module"),
> +                        action="store_true", dest='disable_python', default=False)
> ++        opt.add_option('--with-valgrind',
> ++                       help=("enable use of valgrind"),
> ++                       action="store_true", dest='enable_valgrind', default=False)
> ++
> + 
> + 
> + def configure(conf):
> +-- 
> +2.8.3
> +
> diff --git a/meta-networking/recipes-support/libtalloc/libtalloc_2.1.8.bb b/meta-networking/recipes-support/libtalloc/libtalloc_2.1.8.bb
> index 7c85ab3..8b2ae33 100644
> --- a/meta-networking/recipes-support/libtalloc/libtalloc_2.1.8.bb
> +++ b/meta-networking/recipes-support/libtalloc/libtalloc_2.1.8.bb
> @@ -3,9 +3,11 @@ HOMEPAGE = "http://talloc.samba.org"
>  SECTION = "libs"
>  LICENSE = "LGPL-3.0+ & GPL-3.0+"
>  
> -DEPENDS += "libaio libbsd"
> +DEPENDS += "libbsd"
>  
> -SRC_URI = "http://samba.org/ftp/talloc/talloc-${PV}.tar.gz"
> +SRC_URI = "http://samba.org/ftp/talloc/talloc-${PV}.tar.gz \
> +           file://talloc-Add-configure-options-for-packages.patch \
> +"
>  LIC_FILES_CHKSUM = "file://${COREBASE}/meta/files/common-licenses/LGPL-3.0;md5=bfccfe952269fff2b407dd11f2f3083b \
>                      file://${COREBASE}/meta/files/common-licenses/GPL-3.0;md5=c79ff39f19dfec6d293b95dea7b07891"

I know you haven't changed this, but

This is wrong, we should use some files in talloc source, not
common-license.

>  
> @@ -15,7 +17,15 @@ SRC_URI[sha256sum] = "22d14911164d4de67ff76b5269fa5250d01f78c955bc77e28615350996
>  
>  inherit waf-samba
>  
> -PACKAGECONFIG[attr] = ",,attr"
> +PACKAGECONFIG ??= "\
> +    ${@bb.utils.contains('DISTRO_FEATURES', 'acl', 'acl', '', d)} \
> +    ${@bb.utils.contains('DISTRO_FEATURES', 'xattr', 'attr', '', d)} \
> +"
> +PACKAGECONFIG[acl] = "--with-acl,,acl"
> +PACKAGECONFIG[attr] = "--with-attr,,attr"
> +PACKAGECONFIG[libaio] = "--with-libaio,,libaio,"
> +PACKAGECONFIG[libcap] = "--with-libcap,,libcap,"
> +PACKAGECONFIG[valgrind] = "--with-valgrind,,valgrind,"

What about disable options for clarity?

>  
>  SRC_URI += "${@bb.utils.contains('PACKAGECONFIG', 'attr', '', 'file://avoid-attr-unless-wanted.patch', d)}"
>  
> -- 
> 2.8.3
> 
> -- 
> _______________________________________________
> Openembedded-devel mailing list
> Openembedded-devel at lists.openembedded.org
> http://lists.openembedded.org/mailman/listinfo/openembedded-devel

-- 
Martin 'JaMa' Jansa     jabber: Martin.Jansa at gmail.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 163 bytes
Desc: Digital signature
URL: <http://lists.openembedded.org/pipermail/openembedded-devel/attachments/20160920/6aecce45/attachment-0002.sig>


More information about the Openembedded-devel mailing list