Merge remote-tracking branch 'origin/master'
[unleashed/lotheac.git] / share / man / man9s / uio.9s
blob867cdda360df95f5f7e8d1be1c5c1872fe09b56d
1 '\" te
2 .\" Copyright (c) 2009, Sun Microsystems, Inc., All Rights Reserved.
3 .\" Copyright 1989 AT&T
4 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License").  You may not use this file except in compliance with the License. You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing.
5 .\"  See the License for the specific language governing permissions and limitations under the License. When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE.  If applicable, add the following below this CDDL HEADER, with
6 .\" the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
7 .TH UIO 9S "Mar 26, 2009"
8 .SH NAME
9 uio \- scatter/gather I/O request structure
10 .SH SYNOPSIS
11 .LP
12 .nf
13 #include <sys/uio.h>
14 .fi
16 .SH INTERFACE LEVEL
17 .sp
18 .LP
19 Architecture independent level 1 (DDI/DKI)
20 .SH DESCRIPTION
21 .sp
22 .LP
23 A  \fBuio\fR structure describes an \fBI/O \fRrequest that can be broken up
24 into different data storage areas (scatter/gather I/O). A request is a list of
25 \fBiovec\fR structures (base-length pairs) indicating where in user space or
26 kernel space the \fBI/O \fRdata is to be read or written.
27 .sp
28 .LP
29 The contents of  \fBuio\fR structures passed to the driver through the entry
30 points should not be written by the driver. The  \fBuiomove\fR(9F) function
31 takes care of all overhead related to maintaining the state of the \fBuio\fR
32 structure.
33 .sp
34 .LP
35 \fBuio\fR structures allocated by the driver should be initialized to zero
36 before use, by \fBbzero\fR(9F), \fBkmem_zalloc\fR(9F), or an equivalent.
37 .SH STRUCTURE MEMBERS
38 .sp
39 .in +2
40 .nf
41 iovec_t      *uio_iov;      /* pointer to start of iovec */
42                             /* list for uio struc. */
43 int          uio_iovcnt;    /* number of iovecs in list */
44 off_t        uio_offset;    /* 32-bit offset into file where
45                             /* data is xferred. See NOTES. */
46 offset_t     uio_loffset;   /* 64-bit offset into file where */
47                             /* data is xferred. See NOTES. */
48 uio_seg_t    uio_segflg;    /* ID's type of I/O transfer: */
49                             /* UIO_SYSSPACE:  kernel <-> kernel */
50                             /* UIO_USERSPACE: kernel <-> user */
51 uint16_t     uio_fmode;     /* file mode flags (not driver setable) */
52 daddr_t      uio_limit;     /* 32-bit ulimit for file (max. block */
53                             /* offset). not driver setable. */
54                             /* See NOTES. */
55 diskaddr_t   uio_llimit;    /* 64-bit ulimit for file (max. block */
56                             /* offset). not driver setable. */
57                             /* See NOTES */
58 ssize_t      uio_resid;     /* residual count */
59 .fi
60 .in -2
62 .sp
63 .LP
64 The  \fBuio_iov\fR member is a pointer to the beginning of the \fBiovec\fR(9S)
65 list for the  \fBuio\fR. When the \fBuio\fR structure is passed to the driver
66 through an entry point, the driver should not set  \fBuio_iov\fR. When the
67 \fBuio\fR structure is created by the driver,  \fBuio_iov\fR should be
68 initialized by the driver and not written to afterward.
69 .SH SEE ALSO
70 .sp
71 .LP
72 \fBaread\fR(9E), \fBawrite\fR(9E), \fBread\fR(9E), \fBwrite\fR(9E),
73 \fBbzero\fR(9F), \fBkmem_zalloc\fR(9F), \fBuiomove\fR(9F), \fBcb_ops\fR(9S),
74 \fBiovec\fR(9S)
75 .sp
76 .LP
77 \fIWriting Device Drivers\fR
78 .SH NOTES
79 .sp
80 .LP
81 Only one structure, \fBuio_offset\fR or \fBuio_loffset\fR, should be
82 interpreted by the driver. Which field the driver interprets is dependent upon
83 the settings in the \fBcb_ops\fR(9S) structure.
84 .sp
85 .LP
86 Only one structure, \fBuio_limit\fR or \fBuio_llimit\fR, should be interpreted
87 by the driver. Which field the driver interprets is dependent upon the settings
88 in the \fBcb_ops\fR(9S) structure.
89 .sp
90 .LP
91 When performing \fBI/O \fRon a seekable device, the driver should not modify
92 either the \fBuio_offset\fR or the \fBuio_loffset\fR field of the \fBuio\fR
93 structure. \fBI/O \fRto such a device is constrained by the maximum offset
94 value. When performing \fBI/O \fRon a device on which the concept of position
95 has no relevance, the driver may preserve the \fBuio_offset\fR or
96 \fBuio_loffset\fR, perform the \fBI/O \fRoperation, then restore the
97 \fBuio_offset\fR or \fBuio_loffset\fR to the field's initial value. \fBI/O
98 \fRperformed to a device in this manner is not constrained.