fcntl.h 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  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 0x1000000
  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. #ifdef CONFIG_SCFS_LOWER_PAGECACHE_INVALIDATION
  90. #define O_SCFSLOWER 040000000
  91. #endif
  92. #define F_DUPFD 0 /* dup */
  93. #define F_GETFD 1 /* get close_on_exec */
  94. #define F_SETFD 2 /* set/clear close_on_exec */
  95. #define F_GETFL 3 /* get file->f_flags */
  96. #define F_SETFL 4 /* set file->f_flags */
  97. #ifndef F_GETLK
  98. #define F_GETLK 5
  99. #define F_SETLK 6
  100. #define F_SETLKW 7
  101. #endif
  102. #ifndef F_SETOWN
  103. #define F_SETOWN 8 /* for sockets. */
  104. #define F_GETOWN 9 /* for sockets. */
  105. #endif
  106. #ifndef F_SETSIG
  107. #define F_SETSIG 10 /* for sockets. */
  108. #define F_GETSIG 11 /* for sockets. */
  109. #endif
  110. #ifndef CONFIG_64BIT
  111. #ifndef F_GETLK64
  112. #define F_GETLK64 12 /* using 'struct flock64' */
  113. #define F_SETLK64 13
  114. #define F_SETLKW64 14
  115. #endif
  116. #endif
  117. #ifndef F_SETOWN_EX
  118. #define F_SETOWN_EX 15
  119. #define F_GETOWN_EX 16
  120. #endif
  121. #ifndef F_GETOWNER_UIDS
  122. #define F_GETOWNER_UIDS 17
  123. #endif
  124. /*
  125. * fd "private" POSIX locks.
  126. *
  127. * Usually POSIX locks held by a process are released on *any* close and are
  128. * not inherited across a fork().
  129. *
  130. * These cmd values will set locks that conflict with normal POSIX locks, but
  131. * are "owned" by the opened file, not the process. This means that they are
  132. * inherited across fork() like BSD (flock) locks, and they are only released
  133. * automatically when the last reference to the the open file against which
  134. * they were acquired is put.
  135. */
  136. #define F_OFD_GETLK 36
  137. #define F_OFD_SETLK 37
  138. #define F_OFD_SETLKW 38
  139. #define F_OWNER_TID 0
  140. #define F_OWNER_PID 1
  141. #define F_OWNER_PGRP 2
  142. struct f_owner_ex {
  143. int type;
  144. __kernel_pid_t pid;
  145. };
  146. /* for F_[GET|SET]FL */
  147. #define FD_CLOEXEC 1 /* actually anything with low bit set goes */
  148. /* for posix fcntl() and lockf() */
  149. #ifndef F_RDLCK
  150. #define F_RDLCK 0
  151. #define F_WRLCK 1
  152. #define F_UNLCK 2
  153. #endif
  154. /* for old implementation of bsd flock () */
  155. #ifndef F_EXLCK
  156. #define F_EXLCK 4 /* or 3 */
  157. #define F_SHLCK 8 /* or 4 */
  158. #endif
  159. /* operations for bsd flock(), also used by the kernel implementation */
  160. #define LOCK_SH 1 /* shared lock */
  161. #define LOCK_EX 2 /* exclusive lock */
  162. #define LOCK_NB 4 /* or'd with one of the above to prevent
  163. blocking */
  164. #define LOCK_UN 8 /* remove lock */
  165. #define LOCK_MAND 32 /* This is a mandatory flock ... */
  166. #define LOCK_READ 64 /* which allows concurrent read operations */
  167. #define LOCK_WRITE 128 /* which allows concurrent write operations */
  168. #define LOCK_RW 192 /* which allows concurrent read & write ops */
  169. #define F_LINUX_SPECIFIC_BASE 1024
  170. #ifndef HAVE_ARCH_STRUCT_FLOCK
  171. #ifndef __ARCH_FLOCK_PAD
  172. #define __ARCH_FLOCK_PAD
  173. #endif
  174. struct flock {
  175. short l_type;
  176. short l_whence;
  177. __kernel_off_t l_start;
  178. __kernel_off_t l_len;
  179. __kernel_pid_t l_pid;
  180. __ARCH_FLOCK_PAD
  181. };
  182. #endif
  183. #ifndef CONFIG_64BIT
  184. #ifndef HAVE_ARCH_STRUCT_FLOCK64
  185. #ifndef __ARCH_FLOCK64_PAD
  186. #define __ARCH_FLOCK64_PAD
  187. #endif
  188. struct flock64 {
  189. short l_type;
  190. short l_whence;
  191. __kernel_loff_t l_start;
  192. __kernel_loff_t l_len;
  193. __kernel_pid_t l_pid;
  194. __ARCH_FLOCK64_PAD
  195. };
  196. #endif
  197. #endif /* !CONFIG_64BIT */
  198. #endif /* _ASM_GENERIC_FCNTL_H */