diff options
author | Serge Hallyn <serge.hallyn@ubuntu.com> | 2014-04-03 17:48:33 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-04-03 19:21:06 -0400 |
commit | ea1a8217b06b41b31a2b60b0b83f75c77ef9c873 (patch) | |
tree | bfff18284431af103bb746ea570cd09874b2b87c | |
parent | e9107f88c985bcda5a8ec692cd692005738136f1 (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.h | 9 | ||||
-rw-r--r-- | include/uapi/linux/xattr.h | 7 |
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." |