fcntl.h 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. #ifndef _ASM_GENERIC_FCNTL_H
  2. #define _ASM_GENERIC_FCNTL_H
  3. #include <linux/types.h>
  4. /*
  5. * FMODE_EXEC is 0x20
  6. * FMODE_NONOTIFY is 0x4000000
  7. * These cannot be used by userspace O_* until internal and external open
  8. * flags are split.
  9. * -Eric Paris
  10. */
  11. /*
  12. * When introducing new O_* bits, please check its uniqueness in fcntl_init().
  13. */
  14. #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
  36. #ifndef O_DSYNC
  37. #define O_DSYNC 00010000 /* used to be O_SYNC, see below */
  38. #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
  57. #ifndef O_CLOEXEC
  58. #define O_CLOEXEC 02000000 /* set close_on_exec */
  59. #endif
  60. /*
  61. * Before Linux 2.6.33 only O_DSYNC semantics were implemented, but using
  62. * the O_SYNC flag. We continue to use the existing numerical value
  63. * for O_DSYNC semantics now, but using the correct symbolic name for it.
  64. * This new value is used to request true Posix O_SYNC semantics. It is
  65. * defined in this strange way to make sure applications compiled against
  66. * new headers get at least O_DSYNC semantics on older kernels.
  67. *
  68. * This has the nice side-effect that we can simply test for O_DSYNC
  69. * wherever we do not care if O_DSYNC or O_SYNC is used.
  70. *
  71. * Note: __O_SYNC must never be used directly.
  72. */
  73. #ifndef O_SYNC
  74. #define __O_SYNC 04000000
  75. #define O_SYNC (__O_SYNC|O_DSYNC)
  76. #endif
  77. #ifndef O_PATH
  78. #define O_PATH 010000000
  79. #endif
  80. #ifndef __O_TMPFILE
  81. #define __O_TMPFILE 020000000
  82. #endif
  83. /* a horrid kludge trying to make sure that this will fail on old kernels */
  84. #define O_TMPFILE (__O_TMPFILE | O_DIRECTORY)
  85. #define O_TMPFILE_MASK (__O_TMPFILE | O_DIRECTORY | O_CREAT)
  86. #ifndef O_NDELAY
  87. #define O_NDELAY O_NONBLOCK
  88. #endif
  89. #define F_DUPFD 0 /* dup */
  90. #define F_GETFD 1 /* get close_on_exec */
  91. #define F_SETFD 2 /* set/clear close_on_exec */
  92. #define F_GETFL 3 /* get file->f_flags */
  93. #define F_SETFL 4 /* set file->f_flags */
  94. #ifndef F_GETLK
  95. #define F_GETLK 5
  96. #define F_SETLK 6
  97. #define F_SETLKW 7
  98. #endif
  99. #ifndef F_SETOWN
  100. #define F_SETOWN 8 /* for sockets. */
  101. #define F_GETOWN 9 /* for sockets. */
  102. #endif
  103. #ifndef F_SETSIG
  104. #define F_SETSIG 10 /* for sockets. */
  105. #define F_GETSIG 11 /* for sockets. */
  106. #endif
  107. #ifndef CONFIG_64BIT
  108. #ifndef F_GETLK64
  109. #define F_GETLK64 12 /* using 'struct flock64' */
  110. #define F_SETLK64 13
  111. #define F_SETLKW64 14
  112. #endif
  113. #endif
  114. #ifndef F_SETOWN_EX
  115. #define F_SETOWN_EX 15
  116. #define F_GETOWN_EX 16
  117. #endif
  118. #ifndef F_GETOWNER_UIDS
  119. #define F_GETOWNER_UIDS 17
  120. #endif
  121. /*
  122. * Open File Description Locks
  123. *
  124. * Usually record locks held by a process are released on *any* close and are
  125. * not inherited across a fork().
  126. *
  127. * These cmd values will set locks that conflict with process-associated
  128. * record locks, but are "owned" by the open file description, not the
  129. * process. This means that they are inherited across fork() like BSD (flock)
  130. * locks, and they are only released automatically when the last reference to
  131. * the the open file against which they were acquired is put.
  132. */
  133. #define F_OFD_GETLK 36
  134. #define F_OFD_SETLK 37
  135. #define F_OFD_SETLKW 38
  136. #define F_OWNER_TID 0
  137. #define F_OWNER_PID 1
  138. #define F_OWNER_PGRP 2
  139. struct f_owner_ex {
  140. int type;
  141. __kernel_pid_t pid;
  142. };
  143. /* for F_[GET|SET]FL */
  144. #define FD_CLOEXEC 1 /* actually anything with low bit set goes */
  145. /* for posix fcntl() and lockf() */
  146. #ifndef F_RDLCK
  147. #define F_RDLCK 0
  148. #define F_WRLCK 1
  149. #define F_UNLCK 2
  150. #endif
  151. /* for old implementation of bsd flock () */
  152. #ifndef F_EXLCK
  153. #define F_EXLCK 4 /* or 3 */
  154. #define F_SHLCK 8 /* or 4 */
  155. #endif
  156. /* operations for bsd flock(), also used by the kernel implementation */
  157. #define LOCK_SH 1 /* shared lock */
  158. #define LOCK_EX 2 /* exclusive lock */
  159. #define LOCK_NB 4 /* or'd with one of the above to prevent
  160. blocking */
  161. #define LOCK_UN 8 /* remove lock */
  162. #define LOCK_MAND 32 /* This is a mandatory flock ... */
  163. #define LOCK_READ 64 /* which allows concurrent read operations */
  164. #define LOCK_WRITE 128 /* which allows concurrent write operations */
  165. #define LOCK_RW 192 /* which allows concurrent read & write ops */
  166. #define F_LINUX_SPECIFIC_BASE 1024
  167. #ifndef HAVE_ARCH_STRUCT_FLOCK
  168. #ifndef __ARCH_FLOCK_PAD
  169. #define __ARCH_FLOCK_PAD
  170. #endif
  171. struct flock {
  172. short l_type;
  173. short l_whence;
  174. __kernel_off_t l_start;
  175. __kernel_off_t l_len;
  176. __kernel_pid_t l_pid;
  177. __ARCH_FLOCK_PAD
  178. };
  179. #endif
  180. #ifndef HAVE_ARCH_STRUCT_FLOCK64
  181. #ifndef __ARCH_FLOCK64_PAD
  182. #define __ARCH_FLOCK64_PAD
  183. #endif
  184. struct flock64 {
  185. short l_type;
  186. short l_whence;
  187. __kernel_loff_t l_start;
  188. __kernel_loff_t l_len;
  189. __kernel_pid_t l_pid;
  190. __ARCH_FLOCK64_PAD
  191. };
  192. #endif
  193. #endif /* _ASM_GENERIC_FCNTL_H */