Message ID | 1494488270-10121-1-git-send-email-thomas.petazzoni@free-electrons.com |
---|---|
State | Accepted |
Headers | show |
Hello, On Thu, 11 May 2017 09:37:50 +0200, Thomas Petazzoni wrote: > Since the introduction of 4.11 kernel headers in Buildroot, radvd has > failed to build with all toolchains using this kernel header version. > > The issue comes from the fact that radvd includes both <net/if_arp.h> > and <linux/if_arp.h> if they are available. Until 4.11, > <linux/if_arp.h> was in fact not included, because the > AC_CHECK_HEADERS() test concluded this header was unsuitable. This has > been fixed in the upstream kernel by commit > 2618be7dccf8739b89e1906b64bd8d551af351e6 ("uapi: fix linux/if.h > userspace compilation errors"). So now, the radvd configure script > considers both <net/if_arp.h> and <linux/if_arp.h> as suitable > headers, and includes both of them, leading to the duplicate > definition of various types. > > Since it's redundant to include both <net/if_arp.h> and > <linux/if_arp.h>, we simply force radvd to believe that > <linux/if_arp.h> is not available by passing the appropriate autoconf > cache variable. This gets us back to the previous situation, where > <linux/if_arp.h> was never used. > > This has been tested with a uClibc toolchain using 4.11 kernel > headers, and verified to work on glibc and musl with older kernel > headers as well. > > Fixes: > > http://autobuild.buildroot.net/results/949a75d96299394e4ac957746fa23a4b52f31b43/ > > Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> > --- > package/radvd/radvd.mk | 6 +++++- > 1 file changed, 5 insertions(+), 1 deletion(-) Applied to master, thanks. Thomas
diff --git a/package/radvd/radvd.mk b/package/radvd/radvd.mk index 64f755d..8822187 100644 --- a/package/radvd/radvd.mk +++ b/package/radvd/radvd.mk @@ -8,7 +8,11 @@ RADVD_VERSION = 2.12 RADVD_SOURCE = radvd-$(RADVD_VERSION).tar.xz RADVD_SITE = http://www.litech.org/radvd/dist RADVD_DEPENDENCIES = host-bison flex host-flex host-pkgconf -RADVD_CONF_ENV = ac_cv_prog_cc_c99='-std=gnu99' +# We need to ignore <linux/if_arp.h>, because radvd already includes +# <net/if_arp.h>, which conflicts with <linux/if_arp.h>. +RADVD_CONF_ENV = \ + ac_cv_prog_cc_c99='-std=gnu99' \ + ac_cv_header_linux_if_arp_h=no # For 0002-Don-t-force-fstack-protector-the-toolchain-might-lac.patch RADVD_AUTORECONF = YES RADVD_LICENSE = BSD-4-Clause-like
Since the introduction of 4.11 kernel headers in Buildroot, radvd has failed to build with all toolchains using this kernel header version. The issue comes from the fact that radvd includes both <net/if_arp.h> and <linux/if_arp.h> if they are available. Until 4.11, <linux/if_arp.h> was in fact not included, because the AC_CHECK_HEADERS() test concluded this header was unsuitable. This has been fixed in the upstream kernel by commit 2618be7dccf8739b89e1906b64bd8d551af351e6 ("uapi: fix linux/if.h userspace compilation errors"). So now, the radvd configure script considers both <net/if_arp.h> and <linux/if_arp.h> as suitable headers, and includes both of them, leading to the duplicate definition of various types. Since it's redundant to include both <net/if_arp.h> and <linux/if_arp.h>, we simply force radvd to believe that <linux/if_arp.h> is not available by passing the appropriate autoconf cache variable. This gets us back to the previous situation, where <linux/if_arp.h> was never used. This has been tested with a uClibc toolchain using 4.11 kernel headers, and verified to work on glibc and musl with older kernel headers as well. Fixes: http://autobuild.buildroot.net/results/949a75d96299394e4ac957746fa23a4b52f31b43/ Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> --- package/radvd/radvd.mk | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-)