From bd99318c820c47af63c30dcf12fb3f929c257180 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Tue, 12 Jan 2016 16:42:12 +0000 Subject: [PATCH] perf: fix strerror_r override detection, apparently part of tools/ relies on non-GNU behavior Signed-off-by: Felix Fietkau SVN-Revision: 48221 --- package/devel/perf/Makefile | 2 +- package/devel/perf/musl-compat.h | 11 ----------- package/devel/perf/musl-include/string.h | 18 ++++++++++++++++++ 3 files changed, 19 insertions(+), 12 deletions(-) create mode 100644 package/devel/perf/musl-include/string.h diff --git a/package/devel/perf/Makefile b/package/devel/perf/Makefile index 97eecd715d1..e6ee62f5a21 100644 --- a/package/devel/perf/Makefile +++ b/package/devel/perf/Makefile @@ -59,7 +59,7 @@ MAKE_FLAGS = \ prefix=/usr ifdef CONFIG_USE_MUSL - MAKE_FLAGS += EXTRA_CFLAGS="-include $(CURDIR)/musl-compat.h -D__UCLIBC__" + MAKE_FLAGS += EXTRA_CFLAGS="-I$(CURDIR)/musl-include -include $(CURDIR)/musl-compat.h -D__UCLIBC__" endif define Build/Compile diff --git a/package/devel/perf/musl-compat.h b/package/devel/perf/musl-compat.h index d0fa7810fa8..458915d5eb8 100644 --- a/package/devel/perf/musl-compat.h +++ b/package/devel/perf/musl-compat.h @@ -4,7 +4,6 @@ #ifndef __ASSEMBLER__ #include -#include #include #include #include @@ -16,16 +15,6 @@ #undef _IOC #undef _IO -/* Change XSI compliant version into GNU extension hackery */ -static inline char * -gnu_strerror_r(int err, char *buf, size_t buflen) -{ - if (strerror_r(err, buf, buflen)) - return NULL; - return buf; -} -#define strerror_r gnu_strerror_r - #define _SC_LEVEL1_DCACHE_LINESIZE -1 static inline long sysconf_wrap(int name) diff --git a/package/devel/perf/musl-include/string.h b/package/devel/perf/musl-include/string.h new file mode 100644 index 00000000000..65dc2f1e8f3 --- /dev/null +++ b/package/devel/perf/musl-include/string.h @@ -0,0 +1,18 @@ +#ifndef __MUSL_COMPAT_STRING_H +#define __MUSL_COMPAT_STRING_H + +#include_next + +/* Change XSI compliant version into GNU extension hackery */ +static inline char * +gnu_strerror_r(int err, char *buf, size_t buflen) +{ + if (strerror_r(err, buf, buflen)) + return NULL; + return buf; +} +#ifdef _GNU_SOURCE +#define strerror_r gnu_strerror_r +#endif + +#endif