fcntl.h
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:3k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*
  2.  * This file is subject to the terms and conditions of the GNU General Public
  3.  * License.  See the file "COPYING" in the main directory of this archive
  4.  * for more details.
  5.  *
  6.  * Copyright (C) 1995, 1996, 1997, 1998 by Ralf Baechle
  7.  */
  8. #ifndef __ASM_FCNTL_H
  9. #define __ASM_FCNTL_H
  10. /* open/fcntl - O_SYNC is only implemented on blocks devices and on files
  11.    located on an ext2 file system */
  12. #define O_ACCMODE 0x0003
  13. #define O_RDONLY 0x0000
  14. #define O_WRONLY 0x0001
  15. #define O_RDWR 0x0002
  16. #define O_APPEND 0x0008
  17. #define O_SYNC 0x0010
  18. #define O_NONBLOCK 0x0080
  19. #define O_CREAT         0x0100 /* not fcntl */
  20. #define O_TRUNC 0x0200 /* not fcntl */
  21. #define O_EXCL 0x0400 /* not fcntl */
  22. #define O_NOCTTY 0x0800 /* not fcntl */
  23. #define FASYNC 0x1000 /* fcntl, for BSD compatibility */
  24. #define O_LARGEFILE 0x2000 /* allow large file opens */
  25. #define O_DIRECT 0x8000 /* direct disk access hint */
  26. #define O_DIRECTORY 0x10000 /* must be a directory */
  27. #define O_NOFOLLOW 0x20000 /* don't follow links */
  28. #define O_NDELAY O_NONBLOCK
  29. #define F_DUPFD 0 /* dup */
  30. #define F_GETFD 1 /* get close_on_exec */
  31. #define F_SETFD 2 /* set/clear close_on_exec */
  32. #define F_GETFL 3 /* get file->f_flags */
  33. #define F_SETFL 4 /* set file->f_flags */
  34. #define F_GETLK 14
  35. #define F_SETLK 6
  36. #define F_SETLKW 7
  37. #define F_SETOWN 24 /*  for sockets. */
  38. #define F_GETOWN 23 /*  for sockets. */
  39. #define F_SETSIG 10 /*  for sockets. */
  40. #define F_GETSIG 11 /*  for sockets. */
  41. #define F_GETLK64 33 /*  using 'struct flock64' */
  42. #define F_SETLK64 34
  43. #define F_SETLKW64 35
  44. /* for F_[GET|SET]FL */
  45. #define FD_CLOEXEC 1 /* actually anything with low bit set goes */
  46. /* for posix fcntl() and lockf() */
  47. #define F_RDLCK 0
  48. #define F_WRLCK 1
  49. #define F_UNLCK 2
  50. /* for old implementation of bsd flock () */
  51. #define F_EXLCK 4 /* or 3 */
  52. #define F_SHLCK 8 /* or 4 */
  53. /* for leases */
  54. #define F_INPROGRESS 16
  55. /* operations for bsd flock(), also used by the kernel implementation */
  56. #define LOCK_SH 1 /* shared lock */
  57. #define LOCK_EX 2 /* exclusive lock */
  58. #define LOCK_NB 4 /* or'd with one of the above to prevent
  59.    blocking */
  60. #define LOCK_UN 8 /* remove lock */
  61. #define LOCK_MAND 32 /* This is a mandatory flock */
  62. #define LOCK_READ 64 /* ... Which allows concurrent read operations */
  63. #define LOCK_WRITE 128 /* ... Which allows concurrent write operations */
  64. #define LOCK_RW 192 /* ... Which allows concurrent read & write ops */
  65. /*
  66.  * The flavours of struct flock.  "struct flock" is the ABI compliant
  67.  * variant.  Finally struct flock64 is the LFS variant of struct flock.  As
  68.  * a historic accident and inconsistence with the ABI definition it doesn't
  69.  * contain all the same fields as struct flock.
  70.  */
  71. typedef struct flock {
  72. short l_type;
  73. short l_whence;
  74. __kernel_off_t l_start;
  75. __kernel_off_t l_len;
  76. long l_sysid;
  77. __kernel_pid_t l_pid;
  78. long pad[4];
  79. } flock_t;
  80. typedef struct flock64 {
  81. short l_type;
  82. short l_whence;
  83. loff_t l_start;
  84. loff_t l_len;
  85. pid_t l_pid;
  86. } flock64_t;
  87. #define F_LINUX_SPECIFIC_BASE 1024
  88. #endif /* __ASM_FCNTL_H */