epoc32/include/libc/sys/fcntl.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:27:01 +0100
branchSymbian2
changeset 3 e1b950c65cb4
parent 0 061f57f2323e
child 4 837f303aceeb
permissions -rw-r--r--
Attempt to represent the S^2->S^3 header reorganisation as a series of "hg rename" operations
williamr@2
     1
/*
williamr@2
     2
* Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
williamr@2
     3
* All rights reserved.
williamr@2
     4
* This component and the accompanying materials are made available
williamr@2
     5
* under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
williamr@2
     6
* which accompanies this distribution, and is available
williamr@2
     7
* at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
williamr@2
     8
*
williamr@2
     9
* Initial Contributors:
williamr@2
    10
* Nokia Corporation - initial contribution.
williamr@2
    11
*
williamr@2
    12
* Contributors:
williamr@2
    13
*
williamr@2
    14
* Description:
williamr@2
    15
*
williamr@2
    16
*/
williamr@2
    17
williamr@2
    18
williamr@2
    19
williamr@2
    20
williamr@2
    21
williamr@2
    22
williamr@2
    23
/**
williamr@2
    24
 @file
williamr@2
    25
 @publishedAll
williamr@2
    26
 @released
williamr@2
    27
*/
williamr@2
    28
williamr@2
    29
#ifndef	_FCNTL_
williamr@2
    30
#define	_FCNTL_
williamr@2
    31
williamr@2
    32
#ifdef __cplusplus
williamr@2
    33
extern "C" {
williamr@2
    34
#endif
williamr@2
    35
williamr@2
    36
#include <_ansi.h>
williamr@2
    37
#define	_FOPEN		(-1)	/* from sys/file.h, kernel use only */
williamr@2
    38
#define	_FREAD		0x0001	/* read enabled */
williamr@2
    39
#define	_FWRITE		0x0002	/* write enabled */
williamr@2
    40
#define	_FNDELAY	0x0004	/* non blocking I/O (4.2 style) */
williamr@2
    41
#define	_FAPPEND	0x0008	/* append (writes guaranteed at the end) */
williamr@2
    42
#define	_FMARK		0x0010	/* internal; mark during gc() */
williamr@2
    43
#define	_FDEFER		0x0020	/* internal; defer for next gc pass */
williamr@2
    44
#define	_FASYNC		0x0040	/* signal pgrp when data ready */
williamr@2
    45
#define	_FSHLOCK	0x0080	/* BSD flock() shared lock present */
williamr@2
    46
#define	_FEXLOCK	0x0100	/* BSD flock() exclusive lock present */
williamr@2
    47
#define	_FCREAT		0x0200	/* open with file create */
williamr@2
    48
#define	_FTRUNC		0x0400	/* open with truncation */
williamr@2
    49
#define	_FEXCL		0x0800	/* error on open if file exists */
williamr@2
    50
#define	_FNBIO		0x1000	/* non blocking I/O (sys5 style) */
williamr@2
    51
#define	_FSYNC		0x2000	/* do all writes synchronously */
williamr@2
    52
#define	_FNONBLOCK	0x4000	/* non blocking I/O (POSIX style) */
williamr@2
    53
#define	_FNOCTTY	0x8000	/* don't assign a ctty on this open */
williamr@2
    54
williamr@2
    55
#define _FBUFFERED  0x10000 /* buffer at the interface to the file system */
williamr@2
    56
williamr@2
    57
#define	O_ACCMODE	(O_RDONLY|O_WRONLY|O_RDWR)
williamr@2
    58
williamr@2
    59
/**
williamr@2
    60
Flag values for open(2) and fcntl(2)
williamr@2
    61
The kernel adds 1 to the open modes to turn it into some
williamr@2
    62
combination of FREAD and FWRITE.
williamr@2
    63
*/
williamr@2
    64
#define	O_RDONLY	0		/* +1 == FREAD */
williamr@2
    65
#define	O_WRONLY	1		/* +1 == FWRITE */
williamr@2
    66
#define	O_RDWR		2		/* +1 == FREAD|FWRITE */
williamr@2
    67
#define	O_APPEND	_FAPPEND
williamr@2
    68
#define	O_CREAT		_FCREAT
williamr@2
    69
#define	O_TRUNC		_FTRUNC
williamr@2
    70
#define	O_EXCL		_FEXCL
williamr@2
    71
/*	O_SYNC		_FSYNC		not posix, defined below */
williamr@2
    72
/*	O_NDELAY	_FNDELAY 	set in include/fcntl.h */
williamr@2
    73
/*	O_NDELAY	_FNBIO 		set in 5include/fcntl.h */
williamr@2
    74
#define	O_NONBLOCK	_FNONBLOCK
williamr@2
    75
#define	O_NOCTTY	_FNOCTTY
williamr@2
    76
williamr@2
    77
#define _FBINARY        0x10000
williamr@2
    78
#define _FTEXT          0x20000
williamr@2
    79
#define O_BINARY	_FBINARY
williamr@2
    80
#define O_TEXT		_FTEXT
williamr@2
    81
#define O_BUFFERED  _FBUFFERED
williamr@2
    82
williamr@2
    83
#ifndef	_POSIX_SOURCE
williamr@2
    84
williamr@2
    85
#define	O_SYNC		_FSYNC
williamr@2
    86
williamr@2
    87
/**
williamr@2
    88
Flags that work for fcntl(fd, F_SETFL, FXXXX)
williamr@2
    89
*/
williamr@2
    90
#define	FAPPEND		_FAPPEND
williamr@2
    91
#define	FSYNC		_FSYNC
williamr@2
    92
#define	FASYNC		_FASYNC
williamr@2
    93
#define	FNBIO		_FNBIO
williamr@2
    94
#define	FNONBIO		_FNONBLOCK	/* XXX fix to be NONBLOCK everywhere */
williamr@2
    95
#define	FNDELAY		_FNDELAY
williamr@2
    96
williamr@2
    97
/**
williamr@2
    98
Flags that are disallowed for fcntl's (FCNTLCANT);
williamr@2
    99
used for opens, internal state, or locking.
williamr@2
   100
*/
williamr@2
   101
#define	FREAD		_FREAD
williamr@2
   102
#define	FWRITE		_FWRITE
williamr@2
   103
#define	FMARK		_FMARK
williamr@2
   104
#define	FDEFER		_FDEFER
williamr@2
   105
#define	FSHLOCK		_FSHLOCK
williamr@2
   106
#define	FEXLOCK		_FEXLOCK
williamr@2
   107
williamr@2
   108
/**
williamr@2
   109
The rest of the flags, used only for opens
williamr@2
   110
*/
williamr@2
   111
#define	FOPEN		_FOPEN
williamr@2
   112
#define	FCREAT		_FCREAT
williamr@2
   113
#define	FTRUNC		_FTRUNC
williamr@2
   114
#define	FEXCL		_FEXCL
williamr@2
   115
#define	FNOCTTY		_FNOCTTY
williamr@2
   116
#define FBUFFERED   _FBUFFERED
williamr@2
   117
williamr@2
   118
#endif	/* !_POSIX_SOURCE */
williamr@2
   119
williamr@2
   120
/**
williamr@2
   121
XXX close on exec request; must match UF_EXCLOSE in user.h 
williamr@2
   122
*/
williamr@2
   123
#define	FD_CLOEXEC	1	/* posix */
williamr@2
   124
williamr@2
   125
/** 
williamr@2
   126
fcntl(2) requests 
williamr@2
   127
*/
williamr@2
   128
#define	F_DUPFD		0	/* Duplicate fildes */
williamr@2
   129
#define	F_GETFD		1	/* Get fildes flags (close on exec) */
williamr@2
   130
#define	F_SETFD		2	/* Set fildes flags (close on exec) */
williamr@2
   131
#define	F_GETFL		3	/* Get file flags */
williamr@2
   132
#define	F_SETFL		4	/* Set file flags */
williamr@2
   133
#ifndef	_POSIX_SOURCE
williamr@2
   134
#define	F_GETOWN 	5	/* Get owner - for ASYNC */
williamr@2
   135
#define	F_SETOWN 	6	/* Set owner - for ASYNC */
williamr@2
   136
#endif	/* !_POSIX_SOURCE */
williamr@2
   137
#define	F_GETLK  	7	/* Get record-locking information */
williamr@2
   138
#define	F_SETLK  	8	/* Set or Clear a record-lock (Non-Blocking) */
williamr@2
   139
#define	F_SETLKW 	9	/* Set or Clear a record-lock (Blocking) */
williamr@2
   140
#ifndef	_POSIX_SOURCE
williamr@2
   141
#define	F_RGETLK 	10	/* Test a remote lock to see if it is blocked */
williamr@2
   142
#define	F_RSETLK 	11	/* Set or unlock a remote lock */
williamr@2
   143
#define	F_CNVT 		12	/* Convert a fhandle to an open fd */
williamr@2
   144
#define	F_RSETLKW 	13	/* Set or Clear remote record-lock(Blocking) */
williamr@2
   145
#endif	/* !_POSIX_SOURCE */
williamr@2
   146
williamr@2
   147
/** 
williamr@2
   148
fcntl(2) flags (l_type field of flock structure) 
williamr@2
   149
*/
williamr@2
   150
#define	F_RDLCK		1	/* read lock */
williamr@2
   151
#define	F_WRLCK		2	/* write lock */
williamr@2
   152
#define	F_UNLCK		3	/* remove lock(s) */
williamr@2
   153
#ifndef	_POSIX_SOURCE
williamr@2
   154
#define	F_UNLKSYS	4	/* remove remote locks for a given system */
williamr@2
   155
#endif	/* !_POSIX_SOURCE */
williamr@2
   156
williamr@2
   157
/*#include <sys/stdtypes.h>*/
williamr@2
   158
williamr@2
   159
/** 
williamr@2
   160
file segment locking set data type - information passed to system by user 
williamr@2
   161
*/
williamr@2
   162
struct flock {
williamr@2
   163
	short	l_type;		/* F_RDLCK, F_WRLCK, or F_UNLCK */
williamr@2
   164
	short	l_whence;	/* flag to choose starting offset */
williamr@2
   165
	long	l_start;	/* relative offset, in bytes */
williamr@2
   166
	long	l_len;		/* length, in bytes; 0 means lock to EOF */
williamr@2
   167
	short	l_pid;		/* returned with F_GETLK */
williamr@2
   168
	short	l_xxx;		/* reserved for future use */
williamr@2
   169
};
williamr@2
   170
williamr@2
   171
#ifndef	_POSIX_SOURCE
williamr@2
   172
/** 
williamr@2
   173
extended file segment locking set data type 
williamr@2
   174
*/
williamr@2
   175
struct eflock {
williamr@2
   176
	short	l_type;		/* F_RDLCK, F_WRLCK, or F_UNLCK */
williamr@2
   177
	short	l_whence;	/* flag to choose starting offset */
williamr@2
   178
	long	l_start;	/* relative offset, in bytes */
williamr@2
   179
	long	l_len;		/* length, in bytes; 0 means lock to EOF */
williamr@2
   180
	short	l_pid;		/* returned with F_GETLK */
williamr@2
   181
	short	l_xxx;		/* reserved for future use */
williamr@2
   182
	long	l_rpid;		/* Remote process id wanting this lock */
williamr@2
   183
	long	l_rsys;		/* Remote system id wanting this lock */
williamr@2
   184
};
williamr@2
   185
#endif	/* !_POSIX_SOURCE */
williamr@2
   186
williamr@2
   187
williamr@2
   188
#include <sys/types.h>
williamr@2
   189
#include <sys/stat.h>		/* sigh. for the mode bits for open/creat */
williamr@2
   190
williamr@2
   191
#define creat(n,m)	open(n,O_WRONLY|O_CREAT|O_TRUNC,m)
williamr@2
   192
IMPORT_C int open	(const char *, int, ...);
williamr@2
   193
IMPORT_C int wopen	(const wchar_t *, int, ...);
williamr@2
   194
extern int fcntl	(int, int, ...);
williamr@2
   195
williamr@2
   196
#ifdef __cplusplus
williamr@2
   197
}
williamr@2
   198
#endif
williamr@2
   199
#endif	/* !_FCNTL_ */