2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
6 * Copyright (C) 1995, 96, 97, 98, 99, 2003, 05 Ralf Baechle
12 #define O_APPEND 0x0008
13 #define O_DSYNC 0x0010 /* used to be O_SYNC, see below */
14 #define O_NONBLOCK 0x0080
15 #define O_CREAT 0x0100 /* not fcntl */
16 #define O_TRUNC 0x0200 /* not fcntl */
17 #define O_EXCL 0x0400 /* not fcntl */
18 #define O_NOCTTY 0x0800 /* not fcntl */
19 #define FASYNC 0x1000 /* fcntl, for BSD compatibility */
20 #define O_LARGEFILE 0x2000 /* allow large file opens */
22 * Before Linux 2.6.33 only O_DSYNC semantics were implemented, but using
23 * the O_SYNC flag. We continue to use the existing numerical value
24 * for O_DSYNC semantics now, but using the correct symbolic name for it.
25 * This new value is used to request true Posix O_SYNC semantics. It is
26 * defined in this strange way to make sure applications compiled against
27 * new headers get at least O_DSYNC semantics on older kernels.
29 * This has the nice side-effect that we can simply test for O_DSYNC
30 * wherever we do not care if O_DSYNC or O_SYNC is used.
32 * Note: __O_SYNC must never be used directly.
34 #define __O_SYNC 0x4000
35 #define O_SYNC (__O_SYNC|O_DSYNC)
36 #define O_DIRECT 0x8000 /* direct disk access hint */
42 #define F_SETOWN 24 /* for sockets. */
43 #define F_GETOWN 23 /* for sockets. */
46 #define F_GETLK64 33 /* using 'struct flock64' */
52 * The flavours of struct flock. "struct flock" is the ABI compliant
53 * variant. Finally struct flock64 is the LFS variant of struct flock. As
54 * a historic accident and inconsistence with the ABI definition it doesn't
55 * contain all the same fields as struct flock.
59 #include <linux/types.h>
71 #define HAVE_ARCH_STRUCT_FLOCK
73 #endif /* CONFIG_32BIT */
75 #include <asm-generic/fcntl.h>
77 #endif /* _ASM_FCNTL_H */