Initial revision
[kopensolaris-gnu/glibc.git] / sysdeps / mach / hurd / fcntlbits.h
1 /* O_*, F_*, FD_* bit values for GNU.
2 Copyright (C) 1993 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 Library General Public License as
7 published by the Free Software Foundation; either version 2 of the
8 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 Library General Public License for more details.
14
15 You should have received a copy of the GNU Library General Public
16 License along with the GNU C Library; see the file COPYING.LIB.  If
17 not, write to the Free Software Foundation, Inc., 675 Mass Ave,
18 Cambridge, MA 02139, USA.  */
19
20 #ifndef _FCNTLBITS_H
21
22 #define _FCNTLBITS_H    1
23
24
25 /* File access modes for `open' and `fcntl'.
26
27    In GNU, read and write are bits (unlike BSD).  */
28 #ifdef __USE_GNU
29 #define O_READ          O_RDONLY /* Open for reading.  */
30 #define O_WRITE         O_WRONLY /* Open for writing.  */
31 #endif
32 #define O_RDONLY        0x0001  /* POSIX.1 name: Open read-only.  */
33 #define O_WRONLY        0x0002  /* POSIX.1 name: Open write-only.  */
34 #define O_RDWR          (O_RDONLY|O_WRONLY) /* Open for reading and writing. */
35
36
37 /* Bits OR'd into the second argument to open.  */
38 #define O_CREAT         0x0200  /* Create file if it doesn't exist.  */
39 #define O_EXCL          0x0800  /* Fail if file already exists.  */
40 #define O_TRUNC         0x0400  /* Truncate file to zero length.  */
41 /* Apparently not assigning a controlling terminal is the default
42    behavior in BSD, so no bit is required to request that behavior.  */
43 #define O_NOCTTY        0       /* Don't assign a controlling terminal.  */
44 #ifdef  __USE_MISC
45 #define O_ASYNC         0x0040  /* Send SIGIO to owner when data is ready.  */
46 #define O_FSYNC         0x0080  /* Synchronous writes.  */
47 #define O_SYNC          O_FSYNC
48 #define O_SHLOCK        0x0010  /* Open with shared file lock.  */
49 #define O_EXLOCK        0x0020  /* Open with shared exclusive lock.  */
50 #endif
51
52 /* File status flags for `open' and `fcntl'.  */
53 #define O_APPEND        0x0008  /* Writes append to the file.  */
54 #define O_NONBLOCK      0x0004  /* Non-blocking I/O.  */
55
56 #ifdef __USE_BSD
57 #define O_NDELAY        O_NONBLOCK
58 #endif
59
60 #ifdef __USE_GNU
61 #define O_NOATIME       0x1000  /* Don't set access time on read by owner. */
62 #define O_NOLINK        0x2000  /* No name mappings on final component.  */
63 #define O_NOTRANS       0x4000  /* No translator on final component. */
64 #endif
65
66 #ifdef __USE_BSD
67 /* Bits in the file status flags returned by F_GETFL.  */
68 #define FREAD           O_RDONLY
69 #define FWRITE          O_WRONLY
70
71 /* Traditional BSD names the O_* bits.  */
72 #define FASYNC          O_ASYNC
73 #define FCREAT          O_CREAT
74 #define FEXCL           O_EXCL
75 #define FTRUNC          O_TRUNC
76 #define FNOCTTY         O_NOCTTY
77 #define FFSYNC          O_FSYNC
78 #define FSYNC           O_SYNC
79 #define FAPPEND         O_APPEND
80 #define FNONBLOCK       O_NONBLOCK
81 #define FNDELAY         O_NDELAY
82 #endif
83
84 /* Mask for file access modes.  This is system-dependent in case
85    some system ever wants to define some other flavor of access.  */
86 #define O_ACCMODE       (O_RDONLY|O_WRONLY|O_RDWR)
87
88 /* Values for the second argument to `fcntl'.  */
89 #define F_DUPFD         0       /* Duplicate file descriptor.  */
90 #define F_GETFD         1       /* Get file descriptor flags.  */
91 #define F_SETFD         2       /* Set file descriptor flags.  */
92 #define F_GETFL         3       /* Get file status flags.  */
93 #define F_SETFL         4       /* Set file status flags.  */
94 #ifdef __USE_BSD
95 #define F_GETOWN        5       /* Get owner (receiver of SIGIO).  */
96 #define F_SETOWN        6       /* Set owner (receiver of SIGIO).  */
97 #endif
98 #define F_GETLK         7       /* Get record locking info.  */
99 #define F_SETLK         8       /* Set record locking info (non-blocking).  */
100 #define F_SETLKW        9       /* Set record locking info (blocking).  */
101
102 /* File descriptor flags used with F_GETFD and F_SETFD.  */
103 #define FD_CLOEXEC      1       /* Close on exec.  */
104
105
106 #include <gnu/types.h>
107
108 /* The structure describing an advisory lock.  This is the type of the third
109    argument to `fcntl' for the F_GETLK, F_SETLK, and F_SETLKW requests.  */
110 struct flock
111   {
112     short int l_type;   /* Type of lock: F_RDLCK, F_WRLCK, or F_UNLCK.  */
113     short int l_whence; /* Where `l_start' is relative to (like `lseek').  */
114     __off_t l_start;    /* Offset where the lock begins.  */
115     __off_t l_len;      /* Size of the locked area; zero means until EOF.  */
116     short int l_pid;    /* Process holding the lock.  */
117   };
118
119 /* Values for the `l_type' field of a `struct flock'.  */
120 #define F_RDLCK 1       /* Read lock.  */
121 #define F_WRLCK 2       /* Write lock.  */
122 #define F_UNLCK 3       /* Remove lock.  */
123
124
125 #endif  /* fcntlbits.h */