1/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2#ifndef _SPARC_FCNTL_H
3#define _SPARC_FCNTL_H
4
5#define O_APPEND	0x0008
6#define FASYNC		0x0040	/* fcntl, for BSD compatibility */
7#define O_CREAT		0x0200	/* not fcntl */
8#define O_TRUNC		0x0400	/* not fcntl */
9#define O_EXCL		0x0800	/* not fcntl */
10#define O_DSYNC		0x2000	/* used to be O_SYNC, see below */
11#define O_NONBLOCK	0x4000
12#if defined(__sparc__) && defined(__arch64__)
13#define O_NDELAY	0x0004
14#else
15#define O_NDELAY	(0x0004 | O_NONBLOCK)
16#endif
17#define O_NOCTTY	0x8000	/* not fcntl */
18#define O_LARGEFILE	0x40000
19#define O_DIRECT        0x100000 /* direct disk access hint */
20#define O_NOATIME	0x200000
21#define O_CLOEXEC	0x400000
22/*
23 * Before Linux 2.6.33 only O_DSYNC semantics were implemented, but using
24 * the O_SYNC flag.  We continue to use the existing numerical value
25 * for O_DSYNC semantics now, but using the correct symbolic name for it.
26 * This new value is used to request true Posix O_SYNC semantics.  It is
27 * defined in this strange way to make sure applications compiled against
28 * new headers get at least O_DSYNC semantics on older kernels.
29 *
30 * This has the nice side-effect that we can simply test for O_DSYNC
31 * wherever we do not care if O_DSYNC or O_SYNC is used.
32 *
33 * Note: __O_SYNC must never be used directly.
34 */
35#define __O_SYNC	0x800000
36#define O_SYNC		(__O_SYNC|O_DSYNC)
37
38#define O_PATH		0x1000000
39#define __O_TMPFILE	0x2000000
40
41#define F_GETOWN	5	/*  for sockets. */
42#define F_SETOWN	6	/*  for sockets. */
43#define F_GETLK		7
44#define F_SETLK		8
45#define F_SETLKW	9
46
47/* for posix fcntl() and lockf() */
48#define F_RDLCK		1
49#define F_WRLCK		2
50#define F_UNLCK		3
51
52#define __ARCH_FLOCK_PAD	short __unused;
53#define __ARCH_FLOCK64_PAD	short __unused;
54
55#include <asm-generic/fcntl.h>
56
57#endif
58