blob: e3cbc38bdcc215bf95b890c340c23da5ecf88d47 [file] [log] [blame]
Stephen Rothwell93172592005-09-06 15:17:57 -07001#ifndef _ASM_GENERIC_FCNTL_H
2#define _ASM_GENERIC_FCNTL_H
3
Stephen Rothwell5ac353f2005-09-06 15:18:00 -07004#include <linux/types.h>
5
Eric Parisecf081d2009-12-17 21:24:25 -05006/*
7 * FMODE_EXEC is 0x20
Signed-off-by: Wu Fengguang12ed2e32010-02-08 12:31:29 -05008 * FMODE_NONOTIFY is 0x1000000
Eric Parisecf081d2009-12-17 21:24:25 -05009 * These cannot be used by userspace O_* until internal and external open
10 * flags are split.
11 * -Eric Paris
12 */
13
Stephen Rothwelle64ca972005-09-06 15:17:58 -070014#define O_ACCMODE 00000003
15#define O_RDONLY 00000000
16#define O_WRONLY 00000001
17#define O_RDWR 00000002
18#ifndef O_CREAT
19#define O_CREAT 00000100 /* not fcntl */
20#endif
21#ifndef O_EXCL
22#define O_EXCL 00000200 /* not fcntl */
23#endif
24#ifndef O_NOCTTY
25#define O_NOCTTY 00000400 /* not fcntl */
26#endif
27#ifndef O_TRUNC
28#define O_TRUNC 00001000 /* not fcntl */
29#endif
30#ifndef O_APPEND
31#define O_APPEND 00002000
32#endif
33#ifndef O_NONBLOCK
34#define O_NONBLOCK 00004000
35#endif
Christoph Hellwig6b2f3d12009-10-27 11:05:28 +010036#ifndef O_DSYNC
37#define O_DSYNC 00010000 /* used to be O_SYNC, see below */
Stephen Rothwelle64ca972005-09-06 15:17:58 -070038#endif
39#ifndef FASYNC
40#define FASYNC 00020000 /* fcntl, for BSD compatibility */
41#endif
42#ifndef O_DIRECT
43#define O_DIRECT 00040000 /* direct disk access hint */
44#endif
45#ifndef O_LARGEFILE
46#define O_LARGEFILE 00100000
47#endif
48#ifndef O_DIRECTORY
49#define O_DIRECTORY 00200000 /* must be a directory */
50#endif
51#ifndef O_NOFOLLOW
52#define O_NOFOLLOW 00400000 /* don't follow links */
53#endif
54#ifndef O_NOATIME
55#define O_NOATIME 01000000
56#endif
Ulrich Drepperf23513e2007-07-15 23:40:32 -070057#ifndef O_CLOEXEC
58#define O_CLOEXEC 02000000 /* set close_on_exec */
59#endif
Christoph Hellwig6b2f3d12009-10-27 11:05:28 +010060
61/*
Christoph Hellwig76b7e002009-12-17 14:24:20 +010062 * Before Linux 2.6.33 only O_DSYNC semantics were implemented, but using
Christoph Hellwig6b2f3d12009-10-27 11:05:28 +010063 * the O_SYNC flag. We continue to use the existing numerical value
64 * for O_DSYNC semantics now, but using the correct symbolic name for it.
65 * This new value is used to request true Posix O_SYNC semantics. It is
66 * defined in this strange way to make sure applications compiled against
67 * new headers get at least O_DSYNC semantics on older kernels.
68 *
69 * This has the nice side-effect that we can simply test for O_DSYNC
70 * wherever we do not care if O_DSYNC or O_SYNC is used.
71 *
72 * Note: __O_SYNC must never be used directly.
73 */
74#ifndef O_SYNC
75#define __O_SYNC 04000000
76#define O_SYNC (__O_SYNC|O_DSYNC)
77#endif
78
Stephen Rothwelle64ca972005-09-06 15:17:58 -070079#ifndef O_NDELAY
80#define O_NDELAY O_NONBLOCK
81#endif
Stephen Rothwell93172592005-09-06 15:17:57 -070082
83#define F_DUPFD 0 /* dup */
84#define F_GETFD 1 /* get close_on_exec */
85#define F_SETFD 2 /* set/clear close_on_exec */
86#define F_GETFL 3 /* get file->f_flags */
87#define F_SETFL 4 /* set file->f_flags */
Stephen Rothwell1abf62a2005-09-06 15:17:59 -070088#ifndef F_GETLK
89#define F_GETLK 5
90#define F_SETLK 6
91#define F_SETLKW 7
92#endif
93#ifndef F_SETOWN
94#define F_SETOWN 8 /* for sockets. */
95#define F_GETOWN 9 /* for sockets. */
96#endif
97#ifndef F_SETSIG
98#define F_SETSIG 10 /* for sockets. */
99#define F_GETSIG 11 /* for sockets. */
100#endif
Peter Zijlstra71ccb832009-11-11 14:26:27 -0800101
102#ifndef CONFIG_64BIT
103#ifndef F_GETLK64
104#define F_GETLK64 12 /* using 'struct flock64' */
105#define F_SETLK64 13
106#define F_SETLKW64 14
107#endif
108#endif
109
Peter Zijlstraba0a6c92009-09-23 15:57:03 -0700110#ifndef F_SETOWN_EX
Peter Zijlstra71ccb832009-11-11 14:26:27 -0800111#define F_SETOWN_EX 15
112#define F_GETOWN_EX 16
Peter Zijlstraba0a6c92009-09-23 15:57:03 -0700113#endif
114
115#define F_OWNER_TID 0
116#define F_OWNER_PID 1
Peter Zijlstra978b4052009-11-17 14:06:24 -0800117#define F_OWNER_PGRP 2
Peter Zijlstraba0a6c92009-09-23 15:57:03 -0700118
119struct f_owner_ex {
120 int type;
121 pid_t pid;
122};
Stephen Rothwell93172592005-09-06 15:17:57 -0700123
124/* for F_[GET|SET]FL */
125#define FD_CLOEXEC 1 /* actually anything with low bit set goes */
126
Stephen Rothwell1abf62a2005-09-06 15:17:59 -0700127/* for posix fcntl() and lockf() */
128#ifndef F_RDLCK
129#define F_RDLCK 0
130#define F_WRLCK 1
131#define F_UNLCK 2
132#endif
133
134/* for old implementation of bsd flock () */
135#ifndef F_EXLCK
136#define F_EXLCK 4 /* or 3 */
137#define F_SHLCK 8 /* or 4 */
138#endif
139
140/* for leases */
141#ifndef F_INPROGRESS
142#define F_INPROGRESS 16
143#endif
144
Stephen Rothwell93172592005-09-06 15:17:57 -0700145/* operations for bsd flock(), also used by the kernel implementation */
146#define LOCK_SH 1 /* shared lock */
147#define LOCK_EX 2 /* exclusive lock */
148#define LOCK_NB 4 /* or'd with one of the above to prevent
149 blocking */
150#define LOCK_UN 8 /* remove lock */
151
152#define LOCK_MAND 32 /* This is a mandatory flock ... */
153#define LOCK_READ 64 /* which allows concurrent read operations */
154#define LOCK_WRITE 128 /* which allows concurrent write operations */
155#define LOCK_RW 192 /* which allows concurrent read & write ops */
156
157#define F_LINUX_SPECIFIC_BASE 1024
158
Stephen Rothwell5ac353f2005-09-06 15:18:00 -0700159#ifndef HAVE_ARCH_STRUCT_FLOCK
160#ifndef __ARCH_FLOCK_PAD
161#define __ARCH_FLOCK_PAD
162#endif
163
164struct flock {
165 short l_type;
166 short l_whence;
Arnd Bergmann85efde62009-02-26 00:51:39 +0100167 __kernel_off_t l_start;
168 __kernel_off_t l_len;
169 __kernel_pid_t l_pid;
Stephen Rothwell5ac353f2005-09-06 15:18:00 -0700170 __ARCH_FLOCK_PAD
171};
172#endif
173
Stephen Rothwell8d286aa2005-09-06 15:18:01 -0700174#ifndef CONFIG_64BIT
175
Stephen Rothwell8d286aa2005-09-06 15:18:01 -0700176#ifndef HAVE_ARCH_STRUCT_FLOCK64
177#ifndef __ARCH_FLOCK64_PAD
178#define __ARCH_FLOCK64_PAD
179#endif
180
181struct flock64 {
182 short l_type;
183 short l_whence;
Arnd Bergmann85efde62009-02-26 00:51:39 +0100184 __kernel_loff_t l_start;
185 __kernel_loff_t l_len;
186 __kernel_pid_t l_pid;
Stephen Rothwell8d286aa2005-09-06 15:18:01 -0700187 __ARCH_FLOCK64_PAD
188};
189#endif
190#endif /* !CONFIG_64BIT */
191
Stephen Rothwell93172592005-09-06 15:17:57 -0700192#endif /* _ASM_GENERIC_FCNTL_H */