Untangling the glibc header rat's nest (P.1) (XCC)
[akaros.git] / tools / compilers / gcc-glibc / glibc-2.19-akaros / sysdeps / akaros / bits / fcntl.h
1 /* O_*, F_*, FD_* bit values for stub configuration.
2    Copyright (C) 1991, 1992, 1997, 2000, 2004 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
9
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
14
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
19
20 /* These values should be changed as appropriate for your system.  */
21
22 #ifndef _FCNTL_H
23 # error "Never use <bits/fcntl.h> directly; include <fcntl.h> instead."
24 #endif
25
26 /* parts of fcntl are exported by the kernel */
27 #include <ros/fs.h>
28
29 #define O_LARGEFILE     0
30
31 #ifdef __USE_BSD
32 # define O_NDELAY       O_NONBLOCK
33 #endif
34
35 #if defined __USE_BSD || defined __USE_UNIX98
36 # define F_GETOWN       5       /* Get owner (receiver of SIGIO).  */
37 # define F_SETOWN       6       /* Set owner (receiver of SIGIO).  */
38 #endif
39 #define F_GETLK         7       /* Get record locking info.  */
40 #define F_SETLK         8       /* Set record locking info.  */
41 #define F_SETLKW        9       /* Set record locking info, wait.  */
42
43 #include <sys/types.h>
44
45 /* The structure describing an advisory lock.  This is the type of the third
46    argument to `fcntl' for the F_GETLK, F_SETLK, and F_SETLKW requests.  */
47 struct flock
48   {
49     short int l_type;   /* Type of lock: F_RDLCK, F_WRLCK, or F_UNLCK.  */
50     short int l_whence; /* Where `l_start' is relative to (like `lseek').  */
51     __off_t l_start;    /* Offset where the lock begins.  */
52     __off_t l_len;      /* Size of the locked area; zero means until EOF.  */
53     __pid_t l_pid;      /* Process holding the lock.  */
54   };
55
56 /* Values for the `l_type' field of a `struct flock'.  */
57 #define F_RDLCK 1       /* Read lock.  */
58 #define F_WRLCK 2       /* Write lock.  */
59 #define F_UNLCK 3       /* Remove lock.  */
60
61 /* Advise to `posix_fadvise'.  */
62 #ifdef __USE_XOPEN2K
63 # define POSIX_FADV_NORMAL      0 /* No further special treatment.  */
64 # define POSIX_FADV_RANDOM      1 /* Expect random page references.  */
65 # define POSIX_FADV_SEQUENTIAL  2 /* Expect sequential page references.  */
66 # define POSIX_FADV_WILLNEED    3 /* Will need these pages.  */
67 # define POSIX_FADV_DONTNEED    4 /* Don't need these pages.  */
68 # define POSIX_FADV_NOREUSE     5 /* Data will be accessed once.  */
69 #endif