fcntl.h 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2. /*
  3. * This file is subject to the terms and conditions of the GNU General Public
  4. * License. See the file "COPYING" in the main directory of this archive
  5. * for more details.
  6. *
  7. * Copyright (C) 1995, 96, 97, 98, 99, 2003, 05 Ralf Baechle
  8. */
  9. #ifndef _UAPI_ASM_FCNTL_H
  10. #define _UAPI_ASM_FCNTL_H
  11. #include <asm/sgidefs.h>
  12. #define O_APPEND 0x0008
  13. #define O_DSYNC 0x0010 /* used to be O_SYNC, see below */
  14. #define O_NONBLOCK 0x0080
  15. #define O_CREAT 0x0100 /* not fcntl */
  16. #define O_TRUNC 0x0200 /* not fcntl */
  17. #define O_EXCL 0x0400 /* not fcntl */
  18. #define O_NOCTTY 0x0800 /* not fcntl */
  19. #define FASYNC 0x1000 /* fcntl, for BSD compatibility */
  20. #define O_LARGEFILE 0x2000 /* allow large file opens */
  21. /*
  22. * Before Linux 2.6.33 only O_DSYNC semantics were implemented, but using
  23. * the O_SYNC flag. We continue to use the existing numerical value
  24. * for O_DSYNC semantics now, but using the correct symbolic name for it.
  25. * This new value is used to request true Posix O_SYNC semantics. It is
  26. * defined in this strange way to make sure applications compiled against
  27. * new headers get at least O_DSYNC semantics on older kernels.
  28. *
  29. * This has the nice side-effect that we can simply test for O_DSYNC
  30. * wherever we do not care if O_DSYNC or O_SYNC is used.
  31. *
  32. * Note: __O_SYNC must never be used directly.
  33. */
  34. #define __O_SYNC 0x4000
  35. #define O_SYNC (__O_SYNC|O_DSYNC)
  36. #define O_DIRECT 0x8000 /* direct disk access hint */
  37. #define F_GETLK 14
  38. #define F_SETLK 6
  39. #define F_SETLKW 7
  40. #define F_SETOWN 24 /* for sockets. */
  41. #define F_GETOWN 23 /* for sockets. */
  42. #ifndef __mips64
  43. #define F_GETLK64 33 /* using 'struct flock64' */
  44. #define F_SETLK64 34
  45. #define F_SETLKW64 35
  46. #endif
  47. /*
  48. * The flavours of struct flock. "struct flock" is the ABI compliant
  49. * variant. Finally struct flock64 is the LFS variant of struct flock. As
  50. * a historic accident and inconsistence with the ABI definition it doesn't
  51. * contain all the same fields as struct flock.
  52. */
  53. #if _MIPS_SIM != _MIPS_SIM_ABI64
  54. #include <linux/types.h>
  55. struct flock {
  56. short l_type;
  57. short l_whence;
  58. __kernel_off_t l_start;
  59. __kernel_off_t l_len;
  60. long l_sysid;
  61. __kernel_pid_t l_pid;
  62. long pad[4];
  63. };
  64. #define HAVE_ARCH_STRUCT_FLOCK
  65. #endif /* _MIPS_SIM == _MIPS_SIM_ABI32 */
  66. #include <asm-generic/fcntl.h>
  67. #endif /* _UAPI_ASM_FCNTL_H */