blob: 317349fed536d78c29f7d8aa2a329f1e61a97800 [file] [log] [blame]
Bernhard Reutner-Fischerb1629b12006-05-19 19:29:19 +00001/* vi: set sw=4 ts=4: */
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +00002/*
Bernhard Reutner-Fischer6c4dade2008-09-25 12:13:34 +00003 Copyright 2006, Bernhard Reutner-Fischer
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +00004
5 Licensed under the GPL v2 or later, see the file LICENSE in this tarball.
6*/
Denis Vlasenkof81e8db2009-04-09 12:35:13 +00007#ifndef BB_PLATFORM_H
8#define BB_PLATFORM_H 1
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +00009
10/* Convenience macros to test the version of gcc. */
11#undef __GNUC_PREREQ
12#if defined __GNUC__ && defined __GNUC_MINOR__
13# define __GNUC_PREREQ(maj, min) \
Denis Vlasenko9213a9e2006-09-17 16:28:10 +000014 ((__GNUC__ << 16) + __GNUC_MINOR__ >= ((maj) << 16) + (min))
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +000015#else
16# define __GNUC_PREREQ(maj, min) 0
17#endif
18
19/* __restrict is known in EGCS 1.2 and above. */
Denis Vlasenko98636eb2008-05-09 17:59:34 +000020#if !__GNUC_PREREQ(2,92)
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +000021# ifndef __restrict
22# define __restrict /* Ignore */
23# endif
24#endif
25
26/* Define macros for some gcc attributes. This permits us to use the
27 macros freely, and know that they will come into play for the
28 version of gcc in which they are supported. */
29
Denis Vlasenko98636eb2008-05-09 17:59:34 +000030#if !__GNUC_PREREQ(2,7)
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +000031# ifndef __attribute__
32# define __attribute__(x)
33# endif
34#endif
35
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +000036#undef inline
Denis Vlasenkoa7189f02006-11-17 20:29:00 +000037#if defined(__STDC_VERSION__) && __STDC_VERSION__ > 199901L
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +000038/* it's a keyword */
39#else
Denis Vlasenko98636eb2008-05-09 17:59:34 +000040# if __GNUC_PREREQ(2,7)
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +000041# define inline __inline__
42# else
43# define inline
44# endif
45#endif
46
47#ifndef __const
48# define __const const
49#endif
50
Denis Vlasenkoa60f84e2008-07-05 09:18:54 +000051#define UNUSED_PARAM __attribute__ ((__unused__))
52#define NORETURN __attribute__ ((__noreturn__))
53#define PACKED __attribute__ ((__packed__))
54#define ALIGNED(m) __attribute__ ((__aligned__(m)))
Denis Vlasenko0f3a5802008-03-20 13:13:09 +000055/* __NO_INLINE__: some gcc's do not honor inlining! :( */
Denis Vlasenko98636eb2008-05-09 17:59:34 +000056#if __GNUC_PREREQ(3,0) && !defined(__NO_INLINE__)
57# define ALWAYS_INLINE __attribute__ ((always_inline)) inline
Denis Vlasenko77f1ec12007-10-13 03:36:03 +000058/* I've seen a toolchain where I needed __noinline__ instead of noinline */
Denis Vlasenko98636eb2008-05-09 17:59:34 +000059# define NOINLINE __attribute__((__noinline__))
60# if !ENABLE_WERROR
Denis Vlasenkoa60f84e2008-07-05 09:18:54 +000061# define DEPRECATED __attribute__ ((__deprecated__))
62# define UNUSED_PARAM_RESULT __attribute__ ((warn_unused_result))
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +000063# else
Denis Vlasenkoa60f84e2008-07-05 09:18:54 +000064# define DEPRECATED /* n/a */
65# define UNUSED_PARAM_RESULT /* n/a */
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +000066# endif
Denis Vlasenko98636eb2008-05-09 17:59:34 +000067#else
68# define ALWAYS_INLINE inline /* n/a */
69# define NOINLINE /* n/a */
Denis Vlasenkoa60f84e2008-07-05 09:18:54 +000070# define DEPRECATED /* n/a */
71# define UNUSED_PARAM_RESULT /* n/a */
Denis Vlasenko98636eb2008-05-09 17:59:34 +000072#endif
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +000073
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +000074/* -fwhole-program makes all symbols local. The attribute externally_visible
75 forces a symbol global. */
Denis Vlasenko98636eb2008-05-09 17:59:34 +000076#if __GNUC_PREREQ(4,1)
77# define EXTERNALLY_VISIBLE __attribute__(( visibility("default") ))
Denis Vlasenko9b49a5e2007-10-11 10:05:36 +000078//__attribute__ ((__externally_visible__))
Denis Vlasenko98636eb2008-05-09 17:59:34 +000079#else
80# define EXTERNALLY_VISIBLE
Denis Vlasenko6ebb2f52008-12-03 10:46:12 +000081#endif
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +000082
83/* We use __extension__ in some places to suppress -pedantic warnings
84 about GCC extensions. This feature didn't work properly before
85 gcc 2.8. */
Denis Vlasenko98636eb2008-05-09 17:59:34 +000086#if !__GNUC_PREREQ(2,8)
Bernhard Reutner-Fischer86f5c992006-01-22 22:55:11 +000087# ifndef __extension__
88# define __extension__
89# endif
90#endif
91
Bernhard Reutner-Fischerb5f50ea2006-09-12 13:27:55 +000092/* gcc-2.95 had no va_copy but only __va_copy. */
Denis Vlasenko98636eb2008-05-09 17:59:34 +000093#if !__GNUC_PREREQ(3,0)
Bernhard Reutner-Fischerb5f50ea2006-09-12 13:27:55 +000094# include <stdarg.h>
95# if !defined va_copy && defined __va_copy
96# define va_copy(d,s) __va_copy((d),(s))
97# endif
98#endif
99
Denis Vlasenko42b8daf2008-06-27 03:55:18 +0000100/* FAST_FUNC is a qualifier which (possibly) makes function call faster
101 * and/or smaller by using modified ABI. It is usually only needed
102 * on non-static, busybox internal functions. Recent versions of gcc
103 * optimize statics automatically. FAST_FUNC on static is required
104 * only if you need to match a function pointer's type */
Denis Vlasenkoac2b50e2008-06-27 04:30:48 +0000105#if __GNUC_PREREQ(3,0) && defined(i386) /* || defined(__x86_64__)? */
106/* stdcall makes callee to pop arguments from stack, not caller */
107# define FAST_FUNC __attribute__((regparm(3),stdcall))
Denis Vlasenko42b8daf2008-06-27 03:55:18 +0000108/* #elif ... - add your favorite arch today! */
Denis Vlasenkodefc1ea2008-06-27 02:52:20 +0000109#else
110# define FAST_FUNC
111#endif
112
Denis Vlasenkof81e8db2009-04-09 12:35:13 +0000113/* Make all declarations hidden (-fvisibility flag only affects definitions) */
114/* (don't include system headers after this until corresponding pop!) */
115#if __GNUC_PREREQ(4,1)
116# define PUSH_AND_SET_FUNCTION_VISIBILITY_TO_HIDDEN _Pragma("GCC visibility push(hidden)")
117# define POP_SAVED_FUNCTION_VISIBILITY _Pragma("GCC visibility pop")
118#else
119# define PUSH_AND_SET_FUNCTION_VISIBILITY_TO_HIDDEN
120# define POP_SAVED_FUNCTION_VISIBILITY
121#endif
122
Rob Landley5cf7c2d2006-02-21 06:44:43 +0000123/* ---- Endian Detection ------------------------------------ */
Rob Landley5cf7c2d2006-02-21 06:44:43 +0000124
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000125#if (defined __digital__ && defined __unix__)
126# include <sex.h>
127# define __BIG_ENDIAN__ (BYTE_ORDER == BIG_ENDIAN)
128# define __BYTE_ORDER BYTE_ORDER
Rob Landley15d20a02006-05-29 05:00:44 +0000129#elif !defined __APPLE__
130# include <byteswap.h>
131# include <endian.h>
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000132#endif
133
Rob Landley5cf7c2d2006-02-21 06:44:43 +0000134#ifdef __BIG_ENDIAN__
Mike Frysingerf8855132006-03-28 02:35:56 +0000135# define BB_BIG_ENDIAN 1
136# define BB_LITTLE_ENDIAN 0
Rob Landley5cf7c2d2006-02-21 06:44:43 +0000137#elif __BYTE_ORDER == __BIG_ENDIAN
Mike Frysingerf8855132006-03-28 02:35:56 +0000138# define BB_BIG_ENDIAN 1
139# define BB_LITTLE_ENDIAN 0
Bernhard Reutner-Fischered7bb622006-02-23 14:25:15 +0000140#else
Mike Frysingerf8855132006-03-28 02:35:56 +0000141# define BB_BIG_ENDIAN 0
142# define BB_LITTLE_ENDIAN 1
Rob Landley5cf7c2d2006-02-21 06:44:43 +0000143#endif
144
Denis Vlasenko9b0f6e12008-11-01 13:40:32 +0000145/* SWAP_LEnn means "convert CPU<->little_endian by swapping bytes" */
Rob Landleybba7f082006-05-29 05:51:12 +0000146#if BB_BIG_ENDIAN
Rob Landley752f0a62006-05-30 06:28:03 +0000147#define SWAP_BE16(x) (x)
148#define SWAP_BE32(x) (x)
149#define SWAP_BE64(x) (x)
Rob Landleybba7f082006-05-29 05:51:12 +0000150#define SWAP_LE16(x) bswap_16(x)
151#define SWAP_LE32(x) bswap_32(x)
152#define SWAP_LE64(x) bswap_64(x)
153#else
154#define SWAP_BE16(x) bswap_16(x)
155#define SWAP_BE32(x) bswap_32(x)
156#define SWAP_BE64(x) bswap_64(x)
Rob Landley752f0a62006-05-30 06:28:03 +0000157#define SWAP_LE16(x) (x)
158#define SWAP_LE32(x) (x)
159#define SWAP_LE64(x) (x)
Rob Landleybba7f082006-05-29 05:51:12 +0000160#endif
161
Denis Vlasenkofc9e1082008-05-26 17:32:35 +0000162/* ---- Unaligned access ------------------------------------ */
163
Denis Vlasenkoefb545b2008-12-08 22:56:18 +0000164/* NB: unaligned parameter should be a pointer, aligned one -
165 * a lvalue. This makes it more likely to not swap them by mistake
166 */
Denis Vlasenko42b8daf2008-06-27 03:55:18 +0000167#if defined(i386) || defined(__x86_64__)
Denis Vlasenkoefb545b2008-12-08 22:56:18 +0000168#define move_from_unaligned16(v, u16p) ((v) = *(uint16_t*)(u16p))
169#define move_from_unaligned32(v, u32p) ((v) = *(uint32_t*)(u32p))
170#define move_to_unaligned32(u32p, v) (*(uint32_t*)(u32p) = (v))
Denis Vlasenko42b8daf2008-06-27 03:55:18 +0000171/* #elif ... - add your favorite arch today! */
Denis Vlasenkofc9e1082008-05-26 17:32:35 +0000172#else
173/* performs reasonably well (gcc usually inlines memcpy here) */
Denis Vlasenkoefb545b2008-12-08 22:56:18 +0000174#define move_from_unaligned16(v, u16p) (memcpy(&(v), (u16p), 2))
175#define move_from_unaligned32(v, u32p) (memcpy(&(v), (u32p), 4))
Denis Vlasenko3be23082009-04-17 22:20:44 +0000176#define move_to_unaligned32(u32p, v) do { \
177 uint32_t __t = (v); \
178 memcpy((u32p), &__t, 4); \
179} while (0)
Denis Vlasenkofc9e1082008-05-26 17:32:35 +0000180#endif
181
Rob Landleydae6aa22006-03-09 22:39:08 +0000182/* ---- Networking ------------------------------------------ */
Denis Vlasenkofc9e1082008-05-26 17:32:35 +0000183
Rob Landleydae6aa22006-03-09 22:39:08 +0000184#ifndef __APPLE__
Mike Frysingerf8855132006-03-28 02:35:56 +0000185# include <arpa/inet.h>
Mike Frysinger9412ec72008-02-07 22:41:33 +0000186# ifndef __socklen_t_defined
187typedef int socklen_t;
188# endif
Rob Landleydae6aa22006-03-09 22:39:08 +0000189#else
Mike Frysingerf8855132006-03-28 02:35:56 +0000190# include <netinet/in.h>
Rob Landleydae6aa22006-03-09 22:39:08 +0000191#endif
192
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000193/* ---- Compiler dependent settings ------------------------- */
Denis Vlasenkofc9e1082008-05-26 17:32:35 +0000194
Mike Frysinger22876c72008-02-07 22:10:07 +0000195#if (defined __digital__ && defined __unix__) || defined __APPLE__
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000196# undef HAVE_MNTENT_H
Mike Frysinger9412ec72008-02-07 22:41:33 +0000197# undef HAVE_SYS_STATFS_H
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000198#else
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000199# define HAVE_MNTENT_H 1
Mike Frysinger9412ec72008-02-07 22:41:33 +0000200# define HAVE_SYS_STATFS_H 1
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000201#endif /* ___digital__ && __unix__ */
202
Bernhard Reutner-Fischerbe862092007-03-19 15:15:06 +0000203/* linux/loop.h relies on __u64. Make sure we have that as a proper type
204 * until userspace is widely fixed. */
Bernhard Reutner-Fischer8c69afd2008-01-29 10:33:34 +0000205#if (defined __INTEL_COMPILER && !defined __GNUC__) || \
206 (defined __GNUC__ && defined __STRICT_ANSI__)
Denis Vlasenko6ebb2f52008-12-03 10:46:12 +0000207__extension__ typedef long long __s64;
Bernhard Reutner-Fischerbe862092007-03-19 15:15:06 +0000208__extension__ typedef unsigned long long __u64;
Bernhard Reutner-Fischer8c69afd2008-01-29 10:33:34 +0000209#endif
Bernhard Reutner-Fischerbe862092007-03-19 15:15:06 +0000210
Bernhard Reutner-Fischere2e56c72006-05-19 11:54:02 +0000211/*----- Kernel versioning ------------------------------------*/
Denis Vlasenkofc9e1082008-05-26 17:32:35 +0000212
Bernhard Reutner-Fischere2e56c72006-05-19 11:54:02 +0000213#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))
Bernhard Reutner-Fischere2e56c72006-05-19 11:54:02 +0000214
Denis Vlasenkofc9e1082008-05-26 17:32:35 +0000215/* ---- Miscellaneous --------------------------------------- */
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000216
Mike Frysingerb16b5bb2006-06-06 06:00:20 +0000217#if defined(__GNU_LIBRARY__) && __GNU_LIBRARY__ < 5 && \
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000218 !defined(__dietlibc__) && \
219 !defined(_NEWLIB_VERSION) && \
220 !(defined __digital__ && defined __unix__)
Mike Frysingerb16b5bb2006-06-06 06:00:20 +0000221# error "Sorry, this libc version is not supported :("
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000222#endif
223
Denis Vlasenko6ca409e2007-08-12 20:58:27 +0000224/* Don't perpetuate e2fsck crap into the headers. Clean up e2fsck instead. */
Rob Landley18958e92006-06-13 18:28:33 +0000225
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000226#if defined __GLIBC__ || defined __UCLIBC__ \
227 || defined __dietlibc__ || defined _NEWLIB_VERSION
228#include <features.h>
229#define HAVE_FEATURES_H
230#include <stdint.h>
231#define HAVE_STDINT_H
Mike Frysinger9412ec72008-02-07 22:41:33 +0000232#elif !defined __APPLE__
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000233/* Largest integral types. */
234#if __BIG_ENDIAN__
Denis Vlasenko87468852007-04-13 23:22:00 +0000235typedef long intmax_t;
236typedef unsigned long uintmax_t;
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000237#else
238__extension__
Denis Vlasenko87468852007-04-13 23:22:00 +0000239typedef long long intmax_t;
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000240__extension__
Denis Vlasenko87468852007-04-13 23:22:00 +0000241typedef unsigned long long uintmax_t;
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000242#endif
243#endif
244
Bernhard Reutner-Fischerc966ba42007-01-18 10:32:09 +0000245/* Size-saving "small" ints (arch-dependent) */
246#if defined(i386) || defined(__x86_64__) || defined(__mips__) || defined(__cris__)
247/* add other arches which benefit from this... */
248typedef signed char smallint;
249typedef unsigned char smalluint;
250#else
251/* for arches where byte accesses generate larger code: */
252typedef int smallint;
253typedef unsigned smalluint;
254#endif
255
Bernhard Reutner-Fischera8e2e182007-01-20 21:27:18 +0000256/* ISO C Standard: 7.16 Boolean type and values <stdbool.h> */
257#if (defined __digital__ && defined __unix__)
258/* old system without (proper) C99 support */
259#define bool smalluint
260#else
261/* modern system, so use it */
262#include <stdbool.h>
263#endif
264
Denis Vlasenko6ca409e2007-08-12 20:58:27 +0000265/* Try to defeat gcc's alignment of "char message[]"-like data */
266#if 1 /* if needed: !defined(arch1) && !defined(arch2) */
267#define ALIGN1 __attribute__((aligned(1)))
268#define ALIGN2 __attribute__((aligned(2)))
269#else
270/* Arches which MUST have 2 or 4 byte alignment for everything are here */
271#define ALIGN1
272#define ALIGN2
273#endif
274
Bernhard Reutner-Fischera8e2e182007-01-20 21:27:18 +0000275
Mike Frysinger88407592006-07-20 19:31:07 +0000276/* uclibc does not implement daemon() for no-mmu systems.
Bernhard Reutner-Fischer507cd752006-05-31 10:04:03 +0000277 * For 0.9.29 and svn, __ARCH_USE_MMU__ indicates no-mmu reliably.
278 * For earlier versions there is no reliable way to check if we are building
Denis Vlasenko9e589212008-01-24 01:33:42 +0000279 * for a mmu-less system.
Bernhard Reutner-Fischer507cd752006-05-31 10:04:03 +0000280 */
Denis Vlasenkod2c450c2008-01-08 20:32:12 +0000281#if ENABLE_NOMMU || \
282 (defined __UCLIBC__ && __UCLIBC_MAJOR__ >= 0 && __UCLIBC_MINOR__ >= 9 && \
283 __UCLIBC_SUBLEVEL__ > 28 && !defined __ARCH_USE_MMU__)
Denis Vlasenko473dae02007-04-11 07:04:23 +0000284#define BB_MMU 0
Denis Vlasenko473dae02007-04-11 07:04:23 +0000285#define USE_FOR_NOMMU(...) __VA_ARGS__
286#define USE_FOR_MMU(...)
287#else
288#define BB_MMU 1
Denis Vlasenko473dae02007-04-11 07:04:23 +0000289#define USE_FOR_NOMMU(...)
290#define USE_FOR_MMU(...) __VA_ARGS__
Bernhard Reutner-Fischer507cd752006-05-31 10:04:03 +0000291#endif
292
Rob Landley18958e92006-06-13 18:28:33 +0000293/* Platforms that haven't got dprintf need to implement fdprintf() in
294 * libbb. This would require a platform.c. It's not going to be cleaned
295 * out of the tree, so stop saying it should be. */
Denis Vlasenko7cfecc42006-12-18 22:32:45 +0000296#if !defined(__dietlibc__)
297/* Needed for: glibc */
298/* Not needed for: dietlibc */
299/* Others: ?? (add as needed) */
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000300#define fdprintf dprintf
Denis Vlasenko7cfecc42006-12-18 22:32:45 +0000301#endif
302
303#if defined(__dietlibc__)
Denis Vlasenko3ad5d0c2007-06-12 20:54:54 +0000304static ALWAYS_INLINE char* strchrnul(const char *s, char c)
Denis Vlasenkoac678ec2007-04-16 22:32:04 +0000305{
Denis Vlasenko7cfecc42006-12-18 22:32:45 +0000306 while (*s && *s != c) ++s;
307 return (char*)s;
308}
Denis Vlasenkoc8e6e352006-12-18 22:10:24 +0000309#endif
Rob Landleyc020f5f2006-05-21 18:28:13 +0000310
Denis Vlasenko473dae02007-04-11 07:04:23 +0000311/* Don't use lchown with glibc older than 2.1.x ... uClibc lacks it */
Mike Frysinger88407592006-07-20 19:31:07 +0000312#if (defined __GLIBC__ && __GLIBC__ <= 2 && __GLIBC_MINOR__ < 1) || \
313 defined __UC_LIBC__
314# define lchown chown
315#endif
316
Bernhard Reutner-Fischere00fc162006-05-26 13:10:10 +0000317#if (defined __digital__ && defined __unix__)
Rob Landley8fba99f2006-05-27 22:08:01 +0000318
Denis Vlasenko6ebb2f52008-12-03 10:46:12 +0000319# include <standards.h>
320# define HAVE_STANDARDS_H
321# include <inttypes.h>
322# define HAVE_INTTYPES_H
323# define PRIu32 "u"
Denis Vlasenko0de3c552007-04-12 12:31:02 +0000324/* use legacy setpgrp(pid_t,pid_t) for now. move to platform.c */
Denis Vlasenko6ebb2f52008-12-03 10:46:12 +0000325# define bb_setpgrp() do { pid_t __me = getpid(); setpgrp(__me,__me); } while (0)
Rob Landley18958e92006-06-13 18:28:33 +0000326
Denis Vlasenko6ebb2f52008-12-03 10:46:12 +0000327# if !defined ADJ_OFFSET_SINGLESHOT && defined MOD_CLKA && defined MOD_OFFSET
328# define ADJ_OFFSET_SINGLESHOT (MOD_CLKA | MOD_OFFSET)
329# endif
330# if !defined ADJ_FREQUENCY && defined MOD_FREQUENCY
331# define ADJ_FREQUENCY MOD_FREQUENCY
332# endif
333# if !defined ADJ_TIMECONST && defined MOD_TIMECONST
334# define ADJ_TIMECONST MOD_TIMECONST
335# endif
336# if !defined ADJ_TICK && defined MOD_CLKB
337# define ADJ_TICK MOD_CLKB
338# endif
Rob Landley8fba99f2006-05-27 22:08:01 +0000339
Denis Vlasenko6ebb2f52008-12-03 10:46:12 +0000340#else /* !__digital__ */
341
342# define bb_setpgrp() setpgrp()
343
Rob Landley18958e92006-06-13 18:28:33 +0000344#endif
345
Rob Landley22d26fc2006-06-15 15:49:36 +0000346#if defined(__linux__)
347#include <sys/mount.h>
Denis Vlasenko6ca409e2007-08-12 20:58:27 +0000348/* Make sure we have all the new mount flags we actually try to use. */
Rob Landleye3781b72006-08-08 01:39:49 +0000349#ifndef MS_BIND
350#define MS_BIND (1<<12)
351#endif
352#ifndef MS_MOVE
353#define MS_MOVE (1<<13)
354#endif
355#ifndef MS_RECURSIVE
356#define MS_RECURSIVE (1<<14)
357#endif
358#ifndef MS_SILENT
359#define MS_SILENT (1<<15)
360#endif
361
Denis Vlasenko6ca409e2007-08-12 20:58:27 +0000362/* The shared subtree stuff, which went in around 2.6.15. */
Rob Landleye3781b72006-08-08 01:39:49 +0000363#ifndef MS_UNBINDABLE
364#define MS_UNBINDABLE (1<<17)
365#endif
366#ifndef MS_PRIVATE
367#define MS_PRIVATE (1<<18)
368#endif
369#ifndef MS_SLAVE
370#define MS_SLAVE (1<<19)
371#endif
372#ifndef MS_SHARED
373#define MS_SHARED (1<<20)
374#endif
Bernhard Reutner-Fischerfb5902c2008-08-06 18:14:38 +0000375#ifndef MS_RELATIME
376#define MS_RELATIME (1 << 21)
377#endif
Denis Vlasenko9213a9e2006-09-17 16:28:10 +0000378
Rob Landley7077ea32006-06-29 19:00:12 +0000379#if !defined(BLKSSZGET)
380#define BLKSSZGET _IO(0x12, 104)
381#endif
Rob Landley22d26fc2006-06-15 15:49:36 +0000382#if !defined(BLKGETSIZE64)
Rob Landley18958e92006-06-13 18:28:33 +0000383#define BLKGETSIZE64 _IOR(0x12,114,size_t)
384#endif
Rob Landley22d26fc2006-06-15 15:49:36 +0000385#endif
Rob Landley18958e92006-06-13 18:28:33 +0000386
Denis Vlasenkof81e8db2009-04-09 12:35:13 +0000387#endif