package/dhcpdump: fix build at -O2
Since commitaa556e2035
("utils/genrandconfig: test with BR2_OPTIMIZE_2=y"), we are doing builds at -O2 instead of -Os. This has unveiled an issue in the strsep.c file: strsep.c:65:23: error: register name not specified for 'delim' register const char *delim; This strsep.c compatibility code is compiled in if HAVE_STRSEP is not defined, but dhcpdump does not use any kind of configure script to detect the availability of strsep(). Therefore by default, it gets compiled in, and the "register" specifier used for some variable declarations in strsep.c cause build issues at -O2. A previous commit in Buildroot fromc2a7f0d605
("dhcpdump: Fix strsep() feature test"), attempted to fix this problem by changing the test on HAVE_STRSEP by a test on _BSD_SOURCE. Unfortunately, _BSD_SOURCE is not meant to be tested: it's a feature macro that is meant to be *defined* by some code to tell the C library headers to expose (or not) some given functionality. So instead, we basically revert commitc2a7f0d605
by dropping the patch, and pass -DHAVE_STRSEP in the CFLAGS when building dhcpdump. Fixes: http://autobuild.buildroot.net/results/7231170d3d3e3637f02382c1a0a96009b0527618/ Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
This commit is contained in:
parent
401b7b94a3
commit
136c8862cf
@ -1,27 +0,0 @@
|
||||
Use the official _BSD_SOURCE feature test macro instead of the meaningless
|
||||
HAVE_STRSEP macro in order to detect the availability of strsep().
|
||||
|
||||
This allows toolchains supporting strsep() to use it instead of the custom
|
||||
implementation from dhcpdump, which also avoids the following error with some
|
||||
toolchains:
|
||||
|
||||
In file included from dhcpdump.c:30:0:
|
||||
dhcpdump.c: At top level:
|
||||
strsep.c:65:23: error: register name not specified for ‘delim’
|
||||
register const char *delim;
|
||||
^
|
||||
|
||||
Signed-off-by: Benoît Thébaudeau <benoit.thebaudeau@advansee.com>
|
||||
|
||||
diff -Nrdup dhcpdump-1.8.orig/dhcpdump.c dhcpdump-1.8/dhcpdump.c
|
||||
--- dhcpdump-1.8.orig/dhcpdump.c 2008-06-24 05:26:52.000000000 +0200
|
||||
+++ dhcpdump-1.8/dhcpdump.c 2011-05-31 19:22:15.987388498 +0200
|
||||
@@ -26,7 +26,7 @@
|
||||
#include <regex.h>
|
||||
#include "dhcp_options.h"
|
||||
|
||||
-#ifndef HAVE_STRSEP
|
||||
+#ifndef _BSD_SOURCE
|
||||
#include "strsep.c"
|
||||
#endif
|
||||
|
@ -15,8 +15,11 @@ ifeq ($(BR2_STATIC_LIBS),y)
|
||||
DHCPDUMP_LIBS += `$(STAGING_DIR)/usr/bin/pcap-config --static --additional-libs`
|
||||
endif
|
||||
|
||||
# glibc, uclibc and musl have strsep()
|
||||
DHCPDUMP_CFLAGS = $(TARGET_CFLAGS) -DHAVE_STRSEP
|
||||
|
||||
define DHCPDUMP_BUILD_CMDS
|
||||
$(TARGET_MAKE_ENV) $(MAKE) -C $(@D) CC="$(TARGET_CC) $(TARGET_CFLAGS) \
|
||||
$(TARGET_MAKE_ENV) $(MAKE) -C $(@D) CC="$(TARGET_CC) $(DHCPDUMP_CFLAGS) \
|
||||
-D_GNU_SOURCE" LIBS="$(DHCPDUMP_LIBS)"
|
||||
endef
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user