All of lore.kernel.org
 help / color / mirror / Atom feed
From: Martin Jansa <martin.jansa@gmail.com>
To: openembedded-devel@lists.openembedded.org
Subject: Re: [meta-networking][PATCH 1/4] libtalloc: fixes for deterministic builds
Date: Tue, 20 Sep 2016 08:46:30 +0200	[thread overview]
Message-ID: <20160920064630.GA3461@jama> (raw)
In-Reply-To: <3eedb5bcccfc787f9673143098f394efa6ae6124.1474348826.git.jackie.huang@windriver.com>

[-- Attachment #1: Type: text/plain, Size: 8522 bytes --]

On Tue, Sep 20, 2016 at 01:42:23PM +0800, jackie.huang@windriver.com wrote:
> From: Jackie Huang <jackie.huang@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@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@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@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@lists.openembedded.org
> http://lists.openembedded.org/mailman/listinfo/openembedded-devel

-- 
Martin 'JaMa' Jansa     jabber: Martin.Jansa@gmail.com

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 169 bytes --]

  reply	other threads:[~2016-09-20  6:46 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-09-20  5:42 [meta-networking][PATCH 0/4] libtalloc/tevent/ldb/tdb: fixes for deterministic builds jackie.huang
2016-09-20  5:42 ` [meta-networking][PATCH 1/4] libtalloc: " jackie.huang
2016-09-20  6:46   ` Martin Jansa [this message]
2016-09-20  7:32     ` Huang, Jie (Jackie)
2016-09-20  8:13       ` Martin Jansa
2016-09-21  0:51         ` Huang, Jie (Jackie)
2016-09-20  5:42 ` [meta-networking][PATCH 2/4] libtevent: " jackie.huang
2016-09-20  5:42 ` [meta-networking][PATCH 3/4] libldb: " jackie.huang
2016-09-20  5:42 ` [meta-networking][PATCH 4/4] libtdb: " jackie.huang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20160920064630.GA3461@jama \
    --to=martin.jansa@gmail.com \
    --cc=openembedded-devel@lists.openembedded.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.