From 5f5cc45cf0e027f6ca503dc229a4890fc7164b66 Mon Sep 17 00:00:00 2001 From: Elliott Hughes Date: Mon, 18 Aug 2014 16:04:03 -0700 Subject: [PATCH] Fix (_BSD_SOURCE and _GNU_SOURCE). is supposed to take user-settable stuff like _GNU_SOURCE and _BSD_SOURCE and turn them into __USE_GNU and __USE_BSD for use in the C library headers. Instead, bionic used to unconditionally define _BSD_SOURCE and _GNU_SOURCE, and then test _GNU_SOURCE in the header files (which makes no sense whatsoever). Bug: 14659579 Change-Id: Ice4cf21a364ea2e559071dc8329e995277d5b987 --- libc/bionic/clone.cpp | 2 +- libc/include/features.h | 15 +++++++-------- libc/include/sched.h | 5 +++-- libc/include/unistd.h | 5 +++-- libm/include/math.h | 5 +++-- libm/sincos.c | 2 +- tests/math_sincos_test.cpp | 2 ++ 7 files changed, 20 insertions(+), 16 deletions(-) diff --git a/libc/bionic/clone.cpp b/libc/bionic/clone.cpp index 0a0fdd526..9b5c9e7ae 100644 --- a/libc/bionic/clone.cpp +++ b/libc/bionic/clone.cpp @@ -26,7 +26,7 @@ * SUCH DAMAGE. */ -#define __GNU_SOURCE 1 +#define _GNU_SOURCE 1 #include #include #include diff --git a/libc/include/features.h b/libc/include/features.h index 343c84d2b..057d1de45 100644 --- a/libc/include/features.h +++ b/libc/include/features.h @@ -25,18 +25,17 @@ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ + #ifndef _FEATURES_H_ #define _FEATURES_H_ -/* certain Linux-specific programs expect a header file - * that defines various features macros - */ +#if defined(_BSD_SOURCE) +# define __USE_BSD 1 +#endif -/* we do include a number of BSD extensions */ -#define _BSD_SOURCE 1 - -/* we do include a number of GNU extensions */ -#define _GNU_SOURCE 1 +#if defined(_GNU_SOURCE) +# define __USE_GNU 1 +#endif /* C95 support */ #undef __USE_ISOC95 diff --git a/libc/include/sched.h b/libc/include/sched.h index e43b6ccaa..76249506e 100644 --- a/libc/include/sched.h +++ b/libc/include/sched.h @@ -28,6 +28,7 @@ #ifndef _SCHED_H_ #define _SCHED_H_ +#include #include #include @@ -52,7 +53,7 @@ extern int sched_setparam(pid_t, const struct sched_param*); extern int sched_getparam(pid_t, struct sched_param*); extern int sched_rr_get_interval(pid_t, struct timespec*); -#ifdef _GNU_SOURCE +#if defined(__USE_GNU) extern int clone(int (*)(void*), void*, int, void*, ...); extern int unshare(int); @@ -146,7 +147,7 @@ extern void __sched_cpufree(cpu_set_t* set); extern int __sched_cpucount(size_t setsize, cpu_set_t* set); -#endif /* _GNU_SOURCE */ +#endif /* __USE_GNU */ __END_DECLS diff --git a/libc/include/unistd.h b/libc/include/unistd.h index 781fc4435..c3e655e09 100644 --- a/libc/include/unistd.h +++ b/libc/include/unistd.h @@ -28,6 +28,7 @@ #ifndef _UNISTD_H_ #define _UNISTD_H_ +#include #include #include #include @@ -112,7 +113,7 @@ extern int chdir(const char *); extern int fchdir(int); extern int rmdir(const char *); extern int pipe(int *); -#ifdef _GNU_SOURCE +#if defined(__USE_GNU) extern int pipe2(int *, int); #endif extern int chroot(const char *); @@ -143,7 +144,7 @@ extern ssize_t pwrite64(int, const void *, size_t, off64_t); extern int dup(int); extern int dup2(int, int); -#ifdef _GNU_SOURCE +#if defined(__USE_GNU) extern int dup3(int, int, int); #endif extern int fcntl(int, int, ...); diff --git a/libm/include/math.h b/libm/include/math.h index 4faec333f..a808d8d41 100644 --- a/libm/include/math.h +++ b/libm/include/math.h @@ -17,6 +17,7 @@ #ifndef _MATH_H_ #define _MATH_H_ +#include #include #include @@ -462,11 +463,11 @@ long double truncl(long double); #endif /* __ISO_C_VISIBLE >= 1999 */ -#if defined(_GNU_SOURCE) +#if defined(__USE_GNU) void sincos(double, double*, double*); void sincosf(float, float*, float*); void sincosl(long double, long double*, long double*); -#endif /* _GNU_SOURCE */ +#endif /* __USE_GNU */ #pragma GCC visibility pop __END_DECLS diff --git a/libm/sincos.c b/libm/sincos.c index ad755490f..a5608cfed 100644 --- a/libm/sincos.c +++ b/libm/sincos.c @@ -22,8 +22,8 @@ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. - * */ + #define _GNU_SOURCE 1 #include diff --git a/tests/math_sincos_test.cpp b/tests/math_sincos_test.cpp index 0fab2c20f..f2e30dea9 100644 --- a/tests/math_sincos_test.cpp +++ b/tests/math_sincos_test.cpp @@ -14,6 +14,8 @@ * limitations under the License. */ +#define _GNU_SOURCE 1 + #include #include