xref: /aosp_15_r20/external/kernel-headers/original/uapi/asm-generic/fcntl.h (revision f80ad8b4341604f5951dab671d41019a6d7087ce)
1*f80ad8b4SAndroid Build Coastguard Worker /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2*f80ad8b4SAndroid Build Coastguard Worker #ifndef _ASM_GENERIC_FCNTL_H
3*f80ad8b4SAndroid Build Coastguard Worker #define _ASM_GENERIC_FCNTL_H
4*f80ad8b4SAndroid Build Coastguard Worker 
5*f80ad8b4SAndroid Build Coastguard Worker #include <linux/types.h>
6*f80ad8b4SAndroid Build Coastguard Worker 
7*f80ad8b4SAndroid Build Coastguard Worker /*
8*f80ad8b4SAndroid Build Coastguard Worker  * FMODE_EXEC is 0x20
9*f80ad8b4SAndroid Build Coastguard Worker  * FMODE_NONOTIFY is 0x4000000
10*f80ad8b4SAndroid Build Coastguard Worker  * These cannot be used by userspace O_* until internal and external open
11*f80ad8b4SAndroid Build Coastguard Worker  * flags are split.
12*f80ad8b4SAndroid Build Coastguard Worker  * -Eric Paris
13*f80ad8b4SAndroid Build Coastguard Worker  */
14*f80ad8b4SAndroid Build Coastguard Worker 
15*f80ad8b4SAndroid Build Coastguard Worker /*
16*f80ad8b4SAndroid Build Coastguard Worker  * When introducing new O_* bits, please check its uniqueness in fcntl_init().
17*f80ad8b4SAndroid Build Coastguard Worker  */
18*f80ad8b4SAndroid Build Coastguard Worker 
19*f80ad8b4SAndroid Build Coastguard Worker #define O_ACCMODE	00000003
20*f80ad8b4SAndroid Build Coastguard Worker #define O_RDONLY	00000000
21*f80ad8b4SAndroid Build Coastguard Worker #define O_WRONLY	00000001
22*f80ad8b4SAndroid Build Coastguard Worker #define O_RDWR		00000002
23*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_CREAT
24*f80ad8b4SAndroid Build Coastguard Worker #define O_CREAT		00000100	/* not fcntl */
25*f80ad8b4SAndroid Build Coastguard Worker #endif
26*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_EXCL
27*f80ad8b4SAndroid Build Coastguard Worker #define O_EXCL		00000200	/* not fcntl */
28*f80ad8b4SAndroid Build Coastguard Worker #endif
29*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_NOCTTY
30*f80ad8b4SAndroid Build Coastguard Worker #define O_NOCTTY	00000400	/* not fcntl */
31*f80ad8b4SAndroid Build Coastguard Worker #endif
32*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_TRUNC
33*f80ad8b4SAndroid Build Coastguard Worker #define O_TRUNC		00001000	/* not fcntl */
34*f80ad8b4SAndroid Build Coastguard Worker #endif
35*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_APPEND
36*f80ad8b4SAndroid Build Coastguard Worker #define O_APPEND	00002000
37*f80ad8b4SAndroid Build Coastguard Worker #endif
38*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_NONBLOCK
39*f80ad8b4SAndroid Build Coastguard Worker #define O_NONBLOCK	00004000
40*f80ad8b4SAndroid Build Coastguard Worker #endif
41*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_DSYNC
42*f80ad8b4SAndroid Build Coastguard Worker #define O_DSYNC		00010000	/* used to be O_SYNC, see below */
43*f80ad8b4SAndroid Build Coastguard Worker #endif
44*f80ad8b4SAndroid Build Coastguard Worker #ifndef FASYNC
45*f80ad8b4SAndroid Build Coastguard Worker #define FASYNC		00020000	/* fcntl, for BSD compatibility */
46*f80ad8b4SAndroid Build Coastguard Worker #endif
47*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_DIRECT
48*f80ad8b4SAndroid Build Coastguard Worker #define O_DIRECT	00040000	/* direct disk access hint */
49*f80ad8b4SAndroid Build Coastguard Worker #endif
50*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_LARGEFILE
51*f80ad8b4SAndroid Build Coastguard Worker #define O_LARGEFILE	00100000
52*f80ad8b4SAndroid Build Coastguard Worker #endif
53*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_DIRECTORY
54*f80ad8b4SAndroid Build Coastguard Worker #define O_DIRECTORY	00200000	/* must be a directory */
55*f80ad8b4SAndroid Build Coastguard Worker #endif
56*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_NOFOLLOW
57*f80ad8b4SAndroid Build Coastguard Worker #define O_NOFOLLOW	00400000	/* don't follow links */
58*f80ad8b4SAndroid Build Coastguard Worker #endif
59*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_NOATIME
60*f80ad8b4SAndroid Build Coastguard Worker #define O_NOATIME	01000000
61*f80ad8b4SAndroid Build Coastguard Worker #endif
62*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_CLOEXEC
63*f80ad8b4SAndroid Build Coastguard Worker #define O_CLOEXEC	02000000	/* set close_on_exec */
64*f80ad8b4SAndroid Build Coastguard Worker #endif
65*f80ad8b4SAndroid Build Coastguard Worker 
66*f80ad8b4SAndroid Build Coastguard Worker /*
67*f80ad8b4SAndroid Build Coastguard Worker  * Before Linux 2.6.33 only O_DSYNC semantics were implemented, but using
68*f80ad8b4SAndroid Build Coastguard Worker  * the O_SYNC flag.  We continue to use the existing numerical value
69*f80ad8b4SAndroid Build Coastguard Worker  * for O_DSYNC semantics now, but using the correct symbolic name for it.
70*f80ad8b4SAndroid Build Coastguard Worker  * This new value is used to request true Posix O_SYNC semantics.  It is
71*f80ad8b4SAndroid Build Coastguard Worker  * defined in this strange way to make sure applications compiled against
72*f80ad8b4SAndroid Build Coastguard Worker  * new headers get at least O_DSYNC semantics on older kernels.
73*f80ad8b4SAndroid Build Coastguard Worker  *
74*f80ad8b4SAndroid Build Coastguard Worker  * This has the nice side-effect that we can simply test for O_DSYNC
75*f80ad8b4SAndroid Build Coastguard Worker  * wherever we do not care if O_DSYNC or O_SYNC is used.
76*f80ad8b4SAndroid Build Coastguard Worker  *
77*f80ad8b4SAndroid Build Coastguard Worker  * Note: __O_SYNC must never be used directly.
78*f80ad8b4SAndroid Build Coastguard Worker  */
79*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_SYNC
80*f80ad8b4SAndroid Build Coastguard Worker #define __O_SYNC	04000000
81*f80ad8b4SAndroid Build Coastguard Worker #define O_SYNC		(__O_SYNC|O_DSYNC)
82*f80ad8b4SAndroid Build Coastguard Worker #endif
83*f80ad8b4SAndroid Build Coastguard Worker 
84*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_PATH
85*f80ad8b4SAndroid Build Coastguard Worker #define O_PATH		010000000
86*f80ad8b4SAndroid Build Coastguard Worker #endif
87*f80ad8b4SAndroid Build Coastguard Worker 
88*f80ad8b4SAndroid Build Coastguard Worker #ifndef __O_TMPFILE
89*f80ad8b4SAndroid Build Coastguard Worker #define __O_TMPFILE	020000000
90*f80ad8b4SAndroid Build Coastguard Worker #endif
91*f80ad8b4SAndroid Build Coastguard Worker 
92*f80ad8b4SAndroid Build Coastguard Worker /* a horrid kludge trying to make sure that this will fail on old kernels */
93*f80ad8b4SAndroid Build Coastguard Worker #define O_TMPFILE (__O_TMPFILE | O_DIRECTORY)
94*f80ad8b4SAndroid Build Coastguard Worker 
95*f80ad8b4SAndroid Build Coastguard Worker #ifndef O_NDELAY
96*f80ad8b4SAndroid Build Coastguard Worker #define O_NDELAY	O_NONBLOCK
97*f80ad8b4SAndroid Build Coastguard Worker #endif
98*f80ad8b4SAndroid Build Coastguard Worker 
99*f80ad8b4SAndroid Build Coastguard Worker #define F_DUPFD		0	/* dup */
100*f80ad8b4SAndroid Build Coastguard Worker #define F_GETFD		1	/* get close_on_exec */
101*f80ad8b4SAndroid Build Coastguard Worker #define F_SETFD		2	/* set/clear close_on_exec */
102*f80ad8b4SAndroid Build Coastguard Worker #define F_GETFL		3	/* get file->f_flags */
103*f80ad8b4SAndroid Build Coastguard Worker #define F_SETFL		4	/* set file->f_flags */
104*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_GETLK
105*f80ad8b4SAndroid Build Coastguard Worker #define F_GETLK		5
106*f80ad8b4SAndroid Build Coastguard Worker #define F_SETLK		6
107*f80ad8b4SAndroid Build Coastguard Worker #define F_SETLKW	7
108*f80ad8b4SAndroid Build Coastguard Worker #endif
109*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_SETOWN
110*f80ad8b4SAndroid Build Coastguard Worker #define F_SETOWN	8	/* for sockets. */
111*f80ad8b4SAndroid Build Coastguard Worker #define F_GETOWN	9	/* for sockets. */
112*f80ad8b4SAndroid Build Coastguard Worker #endif
113*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_SETSIG
114*f80ad8b4SAndroid Build Coastguard Worker #define F_SETSIG	10	/* for sockets. */
115*f80ad8b4SAndroid Build Coastguard Worker #define F_GETSIG	11	/* for sockets. */
116*f80ad8b4SAndroid Build Coastguard Worker #endif
117*f80ad8b4SAndroid Build Coastguard Worker 
118*f80ad8b4SAndroid Build Coastguard Worker #if __BITS_PER_LONG == 32 || defined(__KERNEL__)
119*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_GETLK64
120*f80ad8b4SAndroid Build Coastguard Worker #define F_GETLK64	12	/*  using 'struct flock64' */
121*f80ad8b4SAndroid Build Coastguard Worker #define F_SETLK64	13
122*f80ad8b4SAndroid Build Coastguard Worker #define F_SETLKW64	14
123*f80ad8b4SAndroid Build Coastguard Worker #endif
124*f80ad8b4SAndroid Build Coastguard Worker #endif /* __BITS_PER_LONG == 32 || defined(__KERNEL__) */
125*f80ad8b4SAndroid Build Coastguard Worker 
126*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_SETOWN_EX
127*f80ad8b4SAndroid Build Coastguard Worker #define F_SETOWN_EX	15
128*f80ad8b4SAndroid Build Coastguard Worker #define F_GETOWN_EX	16
129*f80ad8b4SAndroid Build Coastguard Worker #endif
130*f80ad8b4SAndroid Build Coastguard Worker 
131*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_GETOWNER_UIDS
132*f80ad8b4SAndroid Build Coastguard Worker #define F_GETOWNER_UIDS	17
133*f80ad8b4SAndroid Build Coastguard Worker #endif
134*f80ad8b4SAndroid Build Coastguard Worker 
135*f80ad8b4SAndroid Build Coastguard Worker /*
136*f80ad8b4SAndroid Build Coastguard Worker  * Open File Description Locks
137*f80ad8b4SAndroid Build Coastguard Worker  *
138*f80ad8b4SAndroid Build Coastguard Worker  * Usually record locks held by a process are released on *any* close and are
139*f80ad8b4SAndroid Build Coastguard Worker  * not inherited across a fork().
140*f80ad8b4SAndroid Build Coastguard Worker  *
141*f80ad8b4SAndroid Build Coastguard Worker  * These cmd values will set locks that conflict with process-associated
142*f80ad8b4SAndroid Build Coastguard Worker  * record  locks, but are "owned" by the open file description, not the
143*f80ad8b4SAndroid Build Coastguard Worker  * process. This means that they are inherited across fork() like BSD (flock)
144*f80ad8b4SAndroid Build Coastguard Worker  * locks, and they are only released automatically when the last reference to
145*f80ad8b4SAndroid Build Coastguard Worker  * the the open file against which they were acquired is put.
146*f80ad8b4SAndroid Build Coastguard Worker  */
147*f80ad8b4SAndroid Build Coastguard Worker #define F_OFD_GETLK	36
148*f80ad8b4SAndroid Build Coastguard Worker #define F_OFD_SETLK	37
149*f80ad8b4SAndroid Build Coastguard Worker #define F_OFD_SETLKW	38
150*f80ad8b4SAndroid Build Coastguard Worker 
151*f80ad8b4SAndroid Build Coastguard Worker #define F_OWNER_TID	0
152*f80ad8b4SAndroid Build Coastguard Worker #define F_OWNER_PID	1
153*f80ad8b4SAndroid Build Coastguard Worker #define F_OWNER_PGRP	2
154*f80ad8b4SAndroid Build Coastguard Worker 
155*f80ad8b4SAndroid Build Coastguard Worker struct f_owner_ex {
156*f80ad8b4SAndroid Build Coastguard Worker 	int	type;
157*f80ad8b4SAndroid Build Coastguard Worker 	__kernel_pid_t	pid;
158*f80ad8b4SAndroid Build Coastguard Worker };
159*f80ad8b4SAndroid Build Coastguard Worker 
160*f80ad8b4SAndroid Build Coastguard Worker /* for F_[GET|SET]FL */
161*f80ad8b4SAndroid Build Coastguard Worker #define FD_CLOEXEC	1	/* actually anything with low bit set goes */
162*f80ad8b4SAndroid Build Coastguard Worker 
163*f80ad8b4SAndroid Build Coastguard Worker /* for posix fcntl() and lockf() */
164*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_RDLCK
165*f80ad8b4SAndroid Build Coastguard Worker #define F_RDLCK		0
166*f80ad8b4SAndroid Build Coastguard Worker #define F_WRLCK		1
167*f80ad8b4SAndroid Build Coastguard Worker #define F_UNLCK		2
168*f80ad8b4SAndroid Build Coastguard Worker #endif
169*f80ad8b4SAndroid Build Coastguard Worker 
170*f80ad8b4SAndroid Build Coastguard Worker /* for old implementation of bsd flock () */
171*f80ad8b4SAndroid Build Coastguard Worker #ifndef F_EXLCK
172*f80ad8b4SAndroid Build Coastguard Worker #define F_EXLCK		4	/* or 3 */
173*f80ad8b4SAndroid Build Coastguard Worker #define F_SHLCK		8	/* or 4 */
174*f80ad8b4SAndroid Build Coastguard Worker #endif
175*f80ad8b4SAndroid Build Coastguard Worker 
176*f80ad8b4SAndroid Build Coastguard Worker /* operations for bsd flock(), also used by the kernel implementation */
177*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_SH		1	/* shared lock */
178*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_EX		2	/* exclusive lock */
179*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_NB		4	/* or'd with one of the above to prevent
180*f80ad8b4SAndroid Build Coastguard Worker 				   blocking */
181*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_UN		8	/* remove lock */
182*f80ad8b4SAndroid Build Coastguard Worker 
183*f80ad8b4SAndroid Build Coastguard Worker /*
184*f80ad8b4SAndroid Build Coastguard Worker  * LOCK_MAND support has been removed from the kernel. We leave the symbols
185*f80ad8b4SAndroid Build Coastguard Worker  * here to not break legacy builds, but these should not be used in new code.
186*f80ad8b4SAndroid Build Coastguard Worker  */
187*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_MAND	32	/* This is a mandatory flock ... */
188*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_READ	64	/* which allows concurrent read operations */
189*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_WRITE	128	/* which allows concurrent write operations */
190*f80ad8b4SAndroid Build Coastguard Worker #define LOCK_RW		192	/* which allows concurrent read & write ops */
191*f80ad8b4SAndroid Build Coastguard Worker 
192*f80ad8b4SAndroid Build Coastguard Worker #define F_LINUX_SPECIFIC_BASE	1024
193*f80ad8b4SAndroid Build Coastguard Worker 
194*f80ad8b4SAndroid Build Coastguard Worker #ifndef HAVE_ARCH_STRUCT_FLOCK
195*f80ad8b4SAndroid Build Coastguard Worker struct flock {
196*f80ad8b4SAndroid Build Coastguard Worker 	short	l_type;
197*f80ad8b4SAndroid Build Coastguard Worker 	short	l_whence;
198*f80ad8b4SAndroid Build Coastguard Worker 	__kernel_off_t	l_start;
199*f80ad8b4SAndroid Build Coastguard Worker 	__kernel_off_t	l_len;
200*f80ad8b4SAndroid Build Coastguard Worker 	__kernel_pid_t	l_pid;
201*f80ad8b4SAndroid Build Coastguard Worker #ifdef	__ARCH_FLOCK_EXTRA_SYSID
202*f80ad8b4SAndroid Build Coastguard Worker 	__ARCH_FLOCK_EXTRA_SYSID
203*f80ad8b4SAndroid Build Coastguard Worker #endif
204*f80ad8b4SAndroid Build Coastguard Worker #ifdef	__ARCH_FLOCK_PAD
205*f80ad8b4SAndroid Build Coastguard Worker 	__ARCH_FLOCK_PAD
206*f80ad8b4SAndroid Build Coastguard Worker #endif
207*f80ad8b4SAndroid Build Coastguard Worker };
208*f80ad8b4SAndroid Build Coastguard Worker 
209*f80ad8b4SAndroid Build Coastguard Worker struct flock64 {
210*f80ad8b4SAndroid Build Coastguard Worker 	short  l_type;
211*f80ad8b4SAndroid Build Coastguard Worker 	short  l_whence;
212*f80ad8b4SAndroid Build Coastguard Worker 	__kernel_loff_t l_start;
213*f80ad8b4SAndroid Build Coastguard Worker 	__kernel_loff_t l_len;
214*f80ad8b4SAndroid Build Coastguard Worker 	__kernel_pid_t  l_pid;
215*f80ad8b4SAndroid Build Coastguard Worker #ifdef	__ARCH_FLOCK64_PAD
216*f80ad8b4SAndroid Build Coastguard Worker 	__ARCH_FLOCK64_PAD
217*f80ad8b4SAndroid Build Coastguard Worker #endif
218*f80ad8b4SAndroid Build Coastguard Worker };
219*f80ad8b4SAndroid Build Coastguard Worker #endif /* HAVE_ARCH_STRUCT_FLOCK */
220*f80ad8b4SAndroid Build Coastguard Worker 
221*f80ad8b4SAndroid Build Coastguard Worker #endif /* _ASM_GENERIC_FCNTL_H */
222