xref: /titanic_52/usr/src/lib/libbc/inc/include/sys/fcntlcom.h (revision f89940742f5d14dde79b69b98a414dd7b7f585c7)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 
22 /*
23  * Copyright 2010 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 /*
28  * Copyright (c) 1983 Regents of the University of California.
29  * All rights reserved.  The Berkeley software License Agreement
30  * specifies the terms and conditions for redistribution.
31  */
32 
33 #ifndef	__SYS_FCNTLCOM_H
34 #define	__SYS_FCNTLCOM_H
35 
36 #ifdef	__cplusplus
37 extern "C" {
38 #endif
39 
40 /*
41  * Rewack the FXXXXX values as _FXXXX so that _POSIX_SOURCE works.
42  */
43 #define	_FOPEN		(-1)	/* from sys/file.h, kernel use only */
44 #define	_FREAD		0x0001	/* read enabled */
45 #define	_FWRITE		0x0002	/* write enabled */
46 #define	_FNDELAY	0x0004	/* non blocking I/O (4.2 style) */
47 #define	_FAPPEND	0x0008	/* append (writes guaranteed at the end) */
48 #define	_FMARK		0x0010	/* internal; mark during gc() */
49 #define	_FDEFER		0x0020	/* internal; defer for next gc pass */
50 #define	_FASYNC		0x0040	/* signal pgrp when data ready */
51 #define	_FSHLOCK	0x0080	/* BSD flock() shared lock present */
52 #define	_FEXLOCK	0x0100	/* BSD flock() exclusive lock present */
53 #define	_FCREAT		0x0200	/* open with file create */
54 #define	_FTRUNC		0x0400	/* open with truncation */
55 #define	_FEXCL		0x0800	/* error on open if file exists */
56 #define	_FNBIO		0x1000	/* non blocking I/O (sys5 style) */
57 #define	_FSYNC		0x2000	/* do all writes synchronously */
58 #define	_FNONBLOCK	0x4000	/* non blocking I/O (POSIX style) */
59 #define	_FNOCTTY	0x8000	/* don't assign a ctty on this open */
60 
61 #define	O_ACCMODE	(O_RDONLY|O_WRONLY|O_RDWR)
62 
63 /*
64  * Flag values for open(2) and fcntl(2)
65  * The kernel adds 1 to the open modes to turn it into some
66  * combination of FREAD and FWRITE.
67  */
68 #define	O_RDONLY	0		/* +1 == FREAD */
69 #define	O_WRONLY	1		/* +1 == FWRITE */
70 #define	O_RDWR		2		/* +1 == FREAD|FWRITE */
71 #define	O_APPEND	_FAPPEND
72 #define	O_CREAT		_FCREAT
73 #define	O_TRUNC		_FTRUNC
74 #define	O_EXCL		_FEXCL
75 /*	O_SYNC		_FSYNC		not posix, defined below */
76 /*	O_NDELAY	_FNDELAY 	set in include/fcntl.h */
77 /*	O_NDELAY	_FNBIO 		set in 5include/fcntl.h */
78 #define	O_NONBLOCK	_FNONBLOCK
79 #define	O_NOCTTY	_FNOCTTY
80 
81 #ifndef	_POSIX_SOURCE
82 
83 #define	O_SYNC		_FSYNC
84 
85 /*
86  * Flags that work for fcntl(fd, F_SETFL, FXXXX)
87  */
88 #define	FAPPEND		_FAPPEND
89 #define	FSYNC		_FSYNC
90 #define	FASYNC		_FASYNC
91 #define	FNBIO		_FNBIO
92 #define	FNONBIO		_FNONBLOCK	/* XXX fix to be NONBLOCK everywhere */
93 #define	FNDELAY		_FNDELAY
94 
95 /*
96  * Flags that are disallowed for fcntl's (FCNTLCANT);
97  * used for opens, internal state, or locking.
98  */
99 #define	FREAD		_FREAD
100 #define	FWRITE		_FWRITE
101 #define	FMARK		_FMARK
102 #define	FDEFER		_FDEFER
103 #define	FSHLOCK		_FSHLOCK
104 #define	FEXLOCK		_FEXLOCK
105 
106 /*
107  * The rest of the flags, used only for opens
108  */
109 #define	FOPEN		_FOPEN
110 #define	FCREAT		_FCREAT
111 #define	FTRUNC		_FTRUNC
112 #define	FEXCL		_FEXCL
113 #define	FNOCTTY		_FNOCTTY
114 
115 #endif	/* !_POSIX_SOURCE */
116 
117 /* XXX close on exec request; must match UF_EXCLOSE in user.h */
118 #define	FD_CLOEXEC	1	/* posix */
119 
120 /* fcntl(2) requests */
121 #define	F_DUPFD		0	/* Duplicate fildes */
122 #define	F_GETFD		1	/* Get fildes flags (close on exec) */
123 #define	F_SETFD		2	/* Set fildes flags (close on exec) */
124 #define	F_GETFL		3	/* Get file flags */
125 #define	F_SETFL		4	/* Set file flags */
126 #ifndef	_POSIX_SOURCE
127 #define	F_GETOWN 	5	/* Get owner - for ASYNC */
128 #define	F_SETOWN 	6	/* Set owner - for ASYNC */
129 #endif	/* !_POSIX_SOURCE */
130 #define	F_GETLK  	7	/* Get record-locking information */
131 #define	F_SETLK  	8	/* Set or Clear a record-lock (Non-Blocking) */
132 #define	F_SETLKW 	9	/* Set or Clear a record-lock (Blocking) */
133 #ifndef	_POSIX_SOURCE
134 #define	F_CNVT 		12	/* Convert a fhandle to an open fd */
135 #endif	/* !_POSIX_SOURCE */
136 
137 /* fcntl(2) flags (l_type field of flock structure) */
138 #define	F_RDLCK		1	/* read lock */
139 #define	F_WRLCK		2	/* write lock */
140 #define	F_UNLCK		3	/* remove lock(s) */
141 #ifndef	_POSIX_SOURCE
142 #define	F_UNLKSYS	4	/* remove remote locks for a given system */
143 #endif	/* !_POSIX_SOURCE */
144 
145 /* needed for _syscall(SYS_openat, AT_FDCWD, ...) */
146 #define	AT_FDCWD		0xffd19553
147 #define	AT_SYMLINK_NOFOLLOW	0x1000
148 #define	AT_REMOVEDIR		0x1
149 
150 #include <sys/stdtypes.h>
151 
152 /* file segment locking set data type - information passed to system by user */
153 struct flock {
154 	short	l_type;		/* F_RDLCK, F_WRLCK, or F_UNLCK */
155 	short	l_whence;	/* flag to choose starting offset */
156 	long	l_start;	/* relative offset, in bytes */
157 	long	l_len;		/* length, in bytes; 0 means lock to EOF */
158 	short	l_pid;		/* returned with F_GETLK */
159 	short	l_xxx;		/* reserved for future use */
160 };
161 
162 #ifndef	_POSIX_SOURCE
163 /* extended file segment locking set data type */
164 struct eflock {
165 	short	l_type;		/* F_RDLCK, F_WRLCK, or F_UNLCK */
166 	short	l_whence;	/* flag to choose starting offset */
167 	long	l_start;	/* relative offset, in bytes */
168 	long	l_len;		/* length, in bytes; 0 means lock to EOF */
169 	short	l_pid;		/* returned with F_GETLK */
170 	short	l_xxx;		/* reserved for future use */
171 	long	l_rpid;		/* Remote process id wanting this lock */
172 	long	l_rsys;		/* Remote system id wanting this lock */
173 };
174 #endif	/* !_POSIX_SOURCE */
175 
176 #ifndef	KERNEL
177 #include <sys/stat.h>		/* sigh. for the mode bits for open/creat */
178 
179 int	open(/* char *path, int flags, mode_t modes */);
180 int	creat(/* char *path, mode_t modes */);
181 int	fcntl(/* int fd, cmd, ... */);
182 #endif	/* !KERNEL */
183 
184 #ifdef	__cplusplus
185 }
186 #endif
187 
188 #endif	/* __SYS_FCNTLCOM_H */
189