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 */