aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSerge Hallyn <serge.hallyn@ubuntu.com>2014-04-03 17:48:33 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2014-04-03 19:21:06 -0400
commitea1a8217b06b41b31a2b60b0b83f75c77ef9c873 (patch)
treebfff18284431af103bb746ea570cd09874b2b87c
parente9107f88c985bcda5a8ec692cd692005738136f1 (diff)
xattr: guard against simultaneous glibc header inclusion
If the glibc xattr.h header is included after the uapi header, compilation fails due to an enum re-using a #define from the uapi header. Protect against this by guarding the define and enum inclusions against each other. (See https://lists.debian.org/debian-glibc/2014/03/msg00029.html and https://sourceware.org/glibc/wiki/Synchronizing_Headers for more information.) Signed-off-by: Serge Hallyn <serge.hallyn@ubuntu.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Allan McRae <allan@archlinux.org> Cc: <stable@vger.kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--include/uapi/linux/libc-compat.h9
-rw-r--r--include/uapi/linux/xattr.h7
2 files changed, 16 insertions, 0 deletions
diff --git a/include/uapi/linux/libc-compat.h b/include/uapi/linux/libc-compat.h
index 335e8a7cad39..c140620dad92 100644
--- a/include/uapi/linux/libc-compat.h
+++ b/include/uapi/linux/libc-compat.h
@@ -85,6 +85,12 @@
85 85
86#endif /* _NETINET_IN_H */ 86#endif /* _NETINET_IN_H */
87 87
88/* Definitions for xattr.h */
89#if defined(_SYS_XATTR_H)
90#define __UAPI_DEF_XATTR 0
91#else
92#define __UAPI_DEF_XATTR 1
93#endif
88 94
89/* If we did not see any headers from any supported C libraries, 95/* If we did not see any headers from any supported C libraries,
90 * or we are being included in the kernel, then define everything 96 * or we are being included in the kernel, then define everything
@@ -98,6 +104,9 @@
98#define __UAPI_DEF_IPV6_MREQ 1 104#define __UAPI_DEF_IPV6_MREQ 1
99#define __UAPI_DEF_IPPROTO_V6 1 105#define __UAPI_DEF_IPPROTO_V6 1
100 106
107/* Definitions for xattr.h */
108#define __UAPI_DEF_XATTR 1
109
101#endif /* __GLIBC__ */ 110#endif /* __GLIBC__ */
102 111
103#endif /* _UAPI_LIBC_COMPAT_H */ 112#endif /* _UAPI_LIBC_COMPAT_H */
diff --git a/include/uapi/linux/xattr.h b/include/uapi/linux/xattr.h
index 40bbc04b6f81..c38355c1f3c9 100644
--- a/include/uapi/linux/xattr.h
+++ b/include/uapi/linux/xattr.h
@@ -7,11 +7,18 @@
7 Copyright (c) 2001-2002 Silicon Graphics, Inc. All Rights Reserved. 7 Copyright (c) 2001-2002 Silicon Graphics, Inc. All Rights Reserved.
8 Copyright (c) 2004 Red Hat, Inc., James Morris <jmorris@redhat.com> 8 Copyright (c) 2004 Red Hat, Inc., James Morris <jmorris@redhat.com>
9*/ 9*/
10
11#include <linux/libc-compat.h>
12
10#ifndef _UAPI_LINUX_XATTR_H 13#ifndef _UAPI_LINUX_XATTR_H
11#define _UAPI_LINUX_XATTR_H 14#define _UAPI_LINUX_XATTR_H
12 15
16#ifdef __UAPI_DEF_XATTR
17#define __USE_KERNEL_XATTR_DEFS
18
13#define XATTR_CREATE 0x1 /* set value, fail if attr already exists */ 19#define XATTR_CREATE 0x1 /* set value, fail if attr already exists */
14#define XATTR_REPLACE 0x2 /* set value, fail if attr does not exist */ 20#define XATTR_REPLACE 0x2 /* set value, fail if attr does not exist */
21#endif
15 22
16/* Namespaces */ 23/* Namespaces */
17#define XATTR_OS2_PREFIX "os2." 24#define XATTR_OS2_PREFIX "os2."