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 /include/uapi/linux/libc-compat.h | |
| 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>
Diffstat (limited to 'include/uapi/linux/libc-compat.h')
| -rw-r--r-- | include/uapi/linux/libc-compat.h | 9 |
1 files changed, 9 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 */ |
