1997-03-03 18:01:01 +00:00
|
|
|
.\" -*- nroff -*-
|
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1996 Doug Rabson
|
|
|
|
.\"
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" This program is free software.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
.\" IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
1999-08-28 00:22:10 +00:00
|
|
|
.\" $FreeBSD$
|
1997-03-03 18:01:01 +00:00
|
|
|
.\"
|
|
|
|
.Dd July 24, 1996
|
|
|
|
.Dt VOP_RDWR 9
|
2010-04-14 19:08:06 +00:00
|
|
|
.Os
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh NAME
|
|
|
|
.Nm VOP_READ ,
|
|
|
|
.Nm VOP_WRITE
|
|
|
|
.Nd read or write a file
|
|
|
|
.Sh SYNOPSIS
|
2001-10-01 16:09:29 +00:00
|
|
|
.In sys/param.h
|
|
|
|
.In sys/vnode.h
|
|
|
|
.In sys/uio.h
|
1997-03-03 18:01:01 +00:00
|
|
|
.Ft int
|
|
|
|
.Fn VOP_READ "struct vnode *vp" "struct uio *uio" "int ioflag" "struct ucred *cred"
|
|
|
|
.Ft int
|
|
|
|
.Fn VOP_WRITE "struct vnode *vp" "struct uio *uio" "int ioflag" "struct ucred *cred"
|
|
|
|
.Sh DESCRIPTION
|
2020-11-12 16:44:56 +00:00
|
|
|
These entry points read or write the contents of a file.
|
1997-03-03 18:01:01 +00:00
|
|
|
.Pp
|
|
|
|
The arguments are:
|
|
|
|
.Bl -tag -width ioflag
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa vp
|
2005-01-28 10:43:05 +00:00
|
|
|
The vnode of the file.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa uio
|
2005-01-28 10:43:05 +00:00
|
|
|
The location of the data to be read or written.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa ioflag
|
2005-01-28 10:43:05 +00:00
|
|
|
Various flags.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa cnp
|
2005-01-28 10:43:05 +00:00
|
|
|
The credentials of the caller.
|
1997-03-03 18:01:01 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fa ioflag
|
2002-12-12 17:26:04 +00:00
|
|
|
argument is used to give directives and hints to the file system.
|
1999-12-13 02:28:53 +00:00
|
|
|
When attempting a read, the high 16 bits are used to provide a
|
2002-12-12 17:26:04 +00:00
|
|
|
read-ahead hint (in units of file system blocks) that the file system
|
2003-10-23 02:11:14 +00:00
|
|
|
should attempt.
|
|
|
|
The low 16 bits are a bit mask which can contain
|
1999-12-13 02:28:53 +00:00
|
|
|
the following flags:
|
2020-11-12 16:44:56 +00:00
|
|
|
.Bl -tag -width "IO_NODELOCKED"
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Dv IO_UNIT
|
2005-01-28 10:43:05 +00:00
|
|
|
Do I/O as atomic unit.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Dv IO_APPEND
|
2005-01-28 10:43:05 +00:00
|
|
|
Append write to end.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Dv IO_SYNC
|
2005-01-28 10:43:05 +00:00
|
|
|
Do I/O synchronously.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Dv IO_NODELOCKED
|
2005-01-28 10:43:05 +00:00
|
|
|
Underlying node already locked.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Dv IO_NDELAY
|
|
|
|
.Dv FNDELAY
|
2005-01-28 10:43:05 +00:00
|
|
|
flag set in file table.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Dv IO_VMIO
|
2005-01-28 10:43:05 +00:00
|
|
|
Data already in VMIO space.
|
1997-03-03 18:01:01 +00:00
|
|
|
.El
|
|
|
|
.Sh LOCKS
|
|
|
|
The file should be locked on entry and will still be locked on exit.
|
2021-02-28 03:08:37 +02:00
|
|
|
Rangelock covering the whole i/o range should be owned around the call.
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh RETURN VALUES
|
|
|
|
Zero is returned on success, otherwise an error code is returned.
|
|
|
|
.Sh ERRORS
|
1997-03-07 03:32:31 +00:00
|
|
|
.Bl -tag -width Er
|
2001-06-15 16:12:41 +00:00
|
|
|
.It Bq Er EFBIG
|
|
|
|
An attempt was made to write a file that exceeds the process's file size
|
|
|
|
limit or the maximum file size.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Bq Er ENOSPC
|
2002-12-12 17:26:04 +00:00
|
|
|
The file system is full.
|
2001-06-15 16:12:41 +00:00
|
|
|
.It Bq Er EPERM
|
|
|
|
An append-only flag is set on the file, but the caller is attempting to
|
|
|
|
write before the current end of file.
|
1997-03-03 18:01:01 +00:00
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
1997-09-29 10:11:02 +00:00
|
|
|
.Xr uiomove 9 ,
|
|
|
|
.Xr vnode 9
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh AUTHORS
|
2005-06-28 20:15:19 +00:00
|
|
|
This manual page was written by
|
1998-03-12 07:31:21 +00:00
|
|
|
.An Doug Rabson .
|