summaryrefslogtreecommitdiffstats
path: root/upstream/archlinux/man3p/writev.3p
blob: 45fc3e574e9dbfad9e9b851bada4599472ddb4b7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
'\" et
.TH WRITEV "3P" 2017 "IEEE/The Open Group" "POSIX Programmer's Manual"
.\"
.SH PROLOG
This manual page is part of the POSIX Programmer's Manual.
The Linux implementation of this interface may differ (consult
the corresponding Linux manual page for details of Linux behavior),
or the interface may not be implemented on Linux.
.\"
.SH NAME
writev
\(em write a vector
.SH SYNOPSIS
.LP
.nf
#include <sys/uio.h>
.P
ssize_t writev(int \fIfildes\fP, const struct iovec *\fIiov\fP, int \fIiovcnt\fP);
.fi
.SH DESCRIPTION
The
\fIwritev\fR()
function shall be equivalent to
\fIwrite\fR(),
except as described below. The
\fIwritev\fR()
function shall gather output data from the
.IR iovcnt
buffers specified by the members of the
.IR iov
array:
.IR iov [0],
.IR iov [1],
\&.\|.\|., \fIiov\fR[\fIiovcnt\fR\-1].
The
.IR iovcnt
argument is valid if greater than 0 and less than or equal to
{IOV_MAX},
as defined in
.IR <limits.h> .
.P
Each
.IR iovec
entry specifies the base address and length of an area in memory from
which data should be written. The
\fIwritev\fR()
function shall always write a complete area before proceeding to the
next.
.P
If
.IR fildes
refers to a regular file and all of the
.IR iov_len
members in the array pointed to by
.IR iov
are 0,
\fIwritev\fR()
shall return 0 and have no other effect. For other file types, the
behavior is unspecified.
.P
If the sum of the
.IR iov_len
values is greater than
{SSIZE_MAX},
the operation shall fail and no data shall be transferred.
.SH "RETURN VALUE"
Upon successful completion,
\fIwritev\fR()
shall return the number of bytes actually written. Otherwise, it shall
return a value of \-1, the file-pointer shall remain unchanged, and
.IR errno
shall be set to indicate an error.
.SH ERRORS
Refer to
.IR "\fIwrite\fR\^(\|)".
.P
In addition, the
\fIwritev\fR()
function shall fail if:
.TP
.BR EINVAL
The sum of the
.IR iov_len
values in the
.IR iov
array would overflow an
.BR ssize_t .
.P
The
\fIwritev\fR()
function may fail and set
.IR errno
to:
.TP
.BR EINVAL
The
.IR iovcnt
argument was less than or equal to 0, or greater than
{IOV_MAX}.
.LP
.IR "The following sections are informative."
.SH EXAMPLES
.SS "Writing Data from an Array"
.P
The following example writes data from the buffers specified by members
of the
.IR iov
array to the file associated with the file descriptor
.IR fd .
.sp
.RS 4
.nf

#include <sys/types.h>
#include <sys/uio.h>
#include <unistd.h>
\&...
ssize_t bytes_written;
int fd;
char *buf0 = "short string\en";
char *buf1 = "This is a longer string\en";
char *buf2 = "This is the longest string in this example\en";
int iovcnt;
struct iovec iov[3];
.P
iov[0].iov_base = buf0;
iov[0].iov_len = strlen(buf0);
iov[1].iov_base = buf1;
iov[1].iov_len = strlen(buf1);
iov[2].iov_base = buf2;
iov[2].iov_len = strlen(buf2);
\&...
iovcnt = sizeof(iov) / sizeof(struct iovec);
.P
bytes_written = writev(fd, iov, iovcnt);
\&...
.fi
.P
.RE
.SH "APPLICATION USAGE"
None.
.SH RATIONALE
Refer to
.IR "\fIwrite\fR\^(\|)".
.SH "FUTURE DIRECTIONS"
None.
.SH "SEE ALSO"
.IR "\fIreadv\fR\^(\|)",
.IR "\fIwrite\fR\^(\|)"
.P
The Base Definitions volume of POSIX.1\(hy2017,
.IR "\fB<limits.h>\fP",
.IR "\fB<sys_uio.h>\fP"
.\"
.SH COPYRIGHT
Portions of this text are reprinted and reproduced in electronic form
from IEEE Std 1003.1-2017, Standard for Information Technology
-- Portable Operating System Interface (POSIX), The Open Group Base
Specifications Issue 7, 2018 Edition,
Copyright (C) 2018 by the Institute of
Electrical and Electronics Engineers, Inc and The Open Group.
In the event of any discrepancy between this version and the original IEEE and
The Open Group Standard, the original IEEE and The Open Group Standard
is the referee document. The original Standard can be obtained online at
http://www.opengroup.org/unix/online.html .
.PP
Any typographical or formatting errors that appear
in this page are most likely
to have been introduced during the conversion of the source files to
man page format. To report such errors, see
https://www.kernel.org/doc/man-pages/reporting_bugs.html .