diff options
author | Khem Raj <raj.khem@gmail.com> | 2013-03-17 22:56:24 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-03-18 21:42:24 +0000 |
commit | 04cd51c8ac2b33476ca1b0c6467bceea76ceb636 (patch) | |
tree | 8bdeb4663bd5c35dce610b76831cd886b5fcc4ad /meta/recipes-extended/iptables | |
parent | 3c0deeb41eb19a7936acedd596e9158fd2e1d60a (diff) | |
download | poky-04cd51c8ac2b33476ca1b0c6467bceea76ceb636.tar.gz |
iptables: Turn ipv6 and libnfnetlink support into PACKAGECONFIG
Detection of libnfnetlink is automatic in configure which means
that when you have meta-networking in your cosmos, it would create
a race condition where if libnfnetlink is already staged then it
will be enabled otherwise disabled. The issue happens quite often
with sstate and high parallelism. Since the dependency libnfnetlink
is not part of OE-Core, this patch turns it into a PACKAGECONFIG
which is diabled by default and iptables is patched to provide
the knob.
If you want to enable libnfnetlink support then it can be done
in a bbappend where you are sure that you are also including
meta-networking in your distro.
While at it also turned ipv6 support into packageconfig
(From OE-Core rev: 0332551d90c866c5874529e81819b81b534e14be)
Signed-off-by: Khem Raj <raj.khem@gmail.com>
Signed-off-by: Saul Wold <sgw@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-extended/iptables')
-rw-r--r-- | meta/recipes-extended/iptables/iptables/0001-configure-Add-option-to-enable-disable-libnfnetlink.patch | 47 | ||||
-rw-r--r-- | meta/recipes-extended/iptables/iptables_1.4.17.bb | 15 |
2 files changed, 59 insertions, 3 deletions
diff --git a/meta/recipes-extended/iptables/iptables/0001-configure-Add-option-to-enable-disable-libnfnetlink.patch b/meta/recipes-extended/iptables/iptables/0001-configure-Add-option-to-enable-disable-libnfnetlink.patch new file mode 100644 index 0000000000..ab609e27e3 --- /dev/null +++ b/meta/recipes-extended/iptables/iptables/0001-configure-Add-option-to-enable-disable-libnfnetlink.patch | |||
@@ -0,0 +1,47 @@ | |||
1 | From 5c47cf5061b852c02178f01e23690bfe38a99d93 Mon Sep 17 00:00:00 2001 | ||
2 | From: Khem Raj <raj.khem@gmail.com> | ||
3 | Date: Sun, 17 Mar 2013 11:21:35 -0700 | ||
4 | Subject: [PATCH] configure: Add option to enable/disable libnfnetlink | ||
5 | |||
6 | This changes the configure behaviour from autodetecting | ||
7 | for libnfnetlink to having an option to disable it explicitly | ||
8 | |||
9 | Signed-off-by: Khem Raj <raj.khem@gmail.com> | ||
10 | |||
11 | Upstream-Status: Pending | ||
12 | --- | ||
13 | configure.ac | 11 ++++++++--- | ||
14 | 1 file changed, 8 insertions(+), 3 deletions(-) | ||
15 | |||
16 | diff --git a/configure.ac b/configure.ac | ||
17 | index ba616ab..ce2d315 100644 | ||
18 | --- a/configure.ac | ||
19 | +++ b/configure.ac | ||
20 | @@ -53,6 +53,9 @@ AC_ARG_ENABLE([libipq], | ||
21 | AC_ARG_WITH([pkgconfigdir], AS_HELP_STRING([--with-pkgconfigdir=PATH], | ||
22 | [Path to the pkgconfig directory [[LIBDIR/pkgconfig]]]), | ||
23 | [pkgconfigdir="$withval"], [pkgconfigdir='${libdir}/pkgconfig']) | ||
24 | +AC_ARG_ENABLE([libnfnetlink], | ||
25 | + AS_HELP_STRING([--disable-libnfnetlink], [Do not use netfilter netlink library]), | ||
26 | + [enable_libnfnetlink="$enableval"], [enable_libnfnetlink="yes"]) | ||
27 | |||
28 | libiptc_LDFLAGS2=""; | ||
29 | AX_CHECK_LINKER_FLAGS([-Wl,--no-as-needed], | ||
30 | @@ -89,9 +92,11 @@ AM_CONDITIONAL([ENABLE_LARGEFILE], [test "$enable_largefile" = "yes"]) | ||
31 | AM_CONDITIONAL([ENABLE_DEVEL], [test "$enable_devel" = "yes"]) | ||
32 | AM_CONDITIONAL([ENABLE_LIBIPQ], [test "$enable_libipq" = "yes"]) | ||
33 | |||
34 | -PKG_CHECK_MODULES([libnfnetlink], [libnfnetlink >= 1.0], | ||
35 | - [nfnetlink=1], [nfnetlink=0]) | ||
36 | -AM_CONDITIONAL([HAVE_LIBNFNETLINK], [test "$nfnetlink" = 1]) | ||
37 | +AS_IF([test "x$enable_libnfnetlink" = "xyes"], [ | ||
38 | + PKG_CHECK_MODULES([libnfnetlink], [libnfnetlink >= 1.0]) | ||
39 | + ]) | ||
40 | + | ||
41 | +AM_CONDITIONAL([HAVE_LIBNFNETLINK], [test "x$enable_libnfnetlink" = "xyes"]) | ||
42 | |||
43 | regular_CFLAGS="-Wall -Waggregate-return -Wmissing-declarations \ | ||
44 | -Wmissing-prototypes -Wredundant-decls -Wshadow -Wstrict-prototypes \ | ||
45 | -- | ||
46 | 1.7.9.5 | ||
47 | |||
diff --git a/meta/recipes-extended/iptables/iptables_1.4.17.bb b/meta/recipes-extended/iptables/iptables_1.4.17.bb index f8ef7b6552..aa932ce67a 100644 --- a/meta/recipes-extended/iptables/iptables_1.4.17.bb +++ b/meta/recipes-extended/iptables/iptables_1.4.17.bb | |||
@@ -7,7 +7,7 @@ LICENSE = "GPLv2+" | |||
7 | LIC_FILES_CHKSUM = "file://COPYING;md5=b234ee4d69f5fce4486a80fdaf4a4263\ | 7 | LIC_FILES_CHKSUM = "file://COPYING;md5=b234ee4d69f5fce4486a80fdaf4a4263\ |
8 | file://iptables/iptables.c;beginline=13;endline=25;md5=c5cffd09974558cf27d0f763df2a12dc" | 8 | file://iptables/iptables.c;beginline=13;endline=25;md5=c5cffd09974558cf27d0f763df2a12dc" |
9 | 9 | ||
10 | PR = "r0" | 10 | PR = "r1" |
11 | 11 | ||
12 | RRECOMMENDS_${PN} = "kernel-module-x-tables \ | 12 | RRECOMMENDS_${PN} = "kernel-module-x-tables \ |
13 | kernel-module-ip-tables \ | 13 | kernel-module-ip-tables \ |
@@ -24,14 +24,23 @@ FILES_${PN}-dbg =+ "${libdir}/xtables/.debug" | |||
24 | SRC_URI = "http://netfilter.org/projects/iptables/files/iptables-${PV}.tar.bz2 \ | 24 | SRC_URI = "http://netfilter.org/projects/iptables/files/iptables-${PV}.tar.bz2 \ |
25 | file://types.h-add-defines-that-are-required-for-if_packet.patch \ | 25 | file://types.h-add-defines-that-are-required-for-if_packet.patch \ |
26 | file://fix-link-failure-ip6t-NETMAP.patch \ | 26 | file://fix-link-failure-ip6t-NETMAP.patch \ |
27 | file://fix-iptables-extensions-build-error.patch" | 27 | file://fix-iptables-extensions-build-error.patch \ |
28 | file://0001-configure-Add-option-to-enable-disable-libnfnetlink.patch \ | ||
29 | " | ||
28 | SRC_URI[md5sum] = "c3fb2ffd5b39d0d54b06ccc4c8660116" | 30 | SRC_URI[md5sum] = "c3fb2ffd5b39d0d54b06ccc4c8660116" |
29 | SRC_URI[sha256sum] = "51e7a769469383b6ad308a6a19cdd2bd813cf4593e21a156a543a1cd70554925" | 31 | SRC_URI[sha256sum] = "51e7a769469383b6ad308a6a19cdd2bd813cf4593e21a156a543a1cd70554925" |
30 | 32 | ||
31 | inherit autotools | 33 | inherit autotools |
32 | 34 | ||
33 | EXTRA_OECONF = "--with-kernel=${STAGING_INCDIR} \ | 35 | EXTRA_OECONF = "--with-kernel=${STAGING_INCDIR} \ |
34 | ${@base_contains('DISTRO_FEATURES', 'ipv6', '', '--disable-ipv6', d)}" | 36 | " |
37 | PACKAGECONFIG ?= "${@base_contains('DISTRO_FEATURES', 'ipv6', 'ipv6', '', d)} \ | ||
38 | " | ||
39 | |||
40 | PACKAGECONFIG[ipv6] = "--enable-ipv6,--disable-ipv6," | ||
41 | |||
42 | # libnfnetlink recipe is in meta-networking layer | ||
43 | PACKAGECONFIG[libnfnetlink] = "--enable-libnfnetlink,--disable-libnfnetlink,libnfnetlink" | ||
35 | 44 | ||
36 | do_configure_prepend() { | 45 | do_configure_prepend() { |
37 | # Remove some libtool m4 files | 46 | # Remove some libtool m4 files |