18269e767SBrooks Davis.\" Copyright (c) 1999 Softweyr LLC. 28269e767SBrooks Davis.\" All rights reserved. 38269e767SBrooks Davis.\" 48269e767SBrooks Davis.\" Redistribution and use in source and binary forms, with or without 58269e767SBrooks Davis.\" modification, are permitted provided that the following conditions 68269e767SBrooks Davis.\" are met: 78269e767SBrooks Davis.\" 1. Redistributions of source code must retain the above copyright 88269e767SBrooks Davis.\" notice, this list of conditions and the following disclaimer. 98269e767SBrooks Davis.\" 2. Redistributions in binary form must reproduce the above copyright 108269e767SBrooks Davis.\" notice, this list of conditions and the following disclaimer in the 118269e767SBrooks Davis.\" documentation and/or other materials provided with the distribution. 128269e767SBrooks Davis.\" 138269e767SBrooks Davis.\" THIS SOFTWARE IS PROVIDED BY Softweyr LLC AND CONTRIBUTORS ``AS IS'' AND 148269e767SBrooks Davis.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 158269e767SBrooks Davis.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 168269e767SBrooks Davis.\" ARE DISCLAIMED. IN NO EVENT SHALL Softweyr LLC OR CONTRIBUTORS BE LIABLE 178269e767SBrooks Davis.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 188269e767SBrooks Davis.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 198269e767SBrooks Davis.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 208269e767SBrooks Davis.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 218269e767SBrooks Davis.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 228269e767SBrooks Davis.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 238269e767SBrooks Davis.\" SUCH DAMAGE. 248269e767SBrooks Davis.\" 25*1b37af09SEnji Cooper.Dd March 27, 2025 268269e767SBrooks Davis.Dt AIO_WRITE 2 278269e767SBrooks Davis.Os 288269e767SBrooks Davis.Sh NAME 298269e767SBrooks Davis.Nm aio_write , 30a52cb4c4SKonstantin Belousov.Nm aio_write2 , 318269e767SBrooks Davis.Nm aio_writev 328269e767SBrooks Davis.Nd asynchronous write to a file (REALTIME) 338269e767SBrooks Davis.Sh LIBRARY 348269e767SBrooks Davis.Lb libc 358269e767SBrooks Davis.Sh SYNOPSIS 368269e767SBrooks Davis.In aio.h 378269e767SBrooks Davis.Ft int 388269e767SBrooks Davis.Fn aio_write "struct aiocb *iocb" 39a52cb4c4SKonstantin Belousov.Ft int 40a52cb4c4SKonstantin Belousov.Fn aio_write2 "struct aiocb *iocb" "int flags" 418269e767SBrooks Davis.In sys/uio.h 428269e767SBrooks Davis.Ft int 438269e767SBrooks Davis.Fn aio_writev "struct aiocb *iocb" 448269e767SBrooks Davis.Sh DESCRIPTION 458269e767SBrooks DavisThe 46a52cb4c4SKonstantin Belousov.Fn aio_write , 47a52cb4c4SKonstantin Belousov.Fn aio_write2 , 488269e767SBrooks Davisand 498269e767SBrooks Davis.Fn aio_writev 508269e767SBrooks Davissystem calls allow the calling process to write 518269e767SBrooks Davisto the descriptor 528269e767SBrooks Davis.Fa iocb->aio_fildes . 53a52cb4c4SKonstantin BelousovThe syscalls return immediately after the write request has been enqueued 54a52cb4c4SKonstantin Belousovto the descriptor; the write may or may not have completed at the time 55a52cb4c4SKonstantin Belousovthe call returns. 56a52cb4c4SKonstantin Belousov.Pp 57a52cb4c4SKonstantin BelousovThe 588269e767SBrooks Davis.Fn aio_write 59a52cb4c4SKonstantin Belousovcall will write 608269e767SBrooks Davis.Fa iocb->aio_nbytes 618269e767SBrooks Davisfrom the buffer pointed to by 628269e767SBrooks Davis.Fa iocb->aio_buf , 638269e767SBrooks Daviswhereas 648269e767SBrooks Davis.Fn aio_writev 658269e767SBrooks Davisgathers the data from the 668269e767SBrooks Davis.Fa iocb->aio_iovcnt 678269e767SBrooks Davisbuffers specified by the members of the 688269e767SBrooks Davis.Fa iocb->aio_iov 698269e767SBrooks Davisarray. 70a52cb4c4SKonstantin Belousov.Pp 718269e767SBrooks DavisIf the request could not be enqueued, generally due 728269e767SBrooks Davisto invalid arguments, the call returns without having enqueued the 738269e767SBrooks Davisrequest. 748269e767SBrooks Davis.Pp 758269e767SBrooks DavisFor 768269e767SBrooks Davis.Fn aio_writev 778269e767SBrooks Davisthe 788269e767SBrooks Davis.Fa iovec 798269e767SBrooks Davisstructure is defined in 808269e767SBrooks Davis.Xr writev 2 . 818269e767SBrooks Davis.Pp 828269e767SBrooks DavisIf 838269e767SBrooks Davis.Dv O_APPEND 848269e767SBrooks Davisis set for 858269e767SBrooks Davis.Fa iocb->aio_fildes , 868269e767SBrooks Daviswrite operations append to the file in the same order as the calls were 878269e767SBrooks Davismade. 888269e767SBrooks DavisIf 898269e767SBrooks Davis.Dv O_APPEND 90a52cb4c4SKonstantin Belousovis not set for the file descriptor, the write operation for 91a52cb4c4SKonstantin Belousov.Fn aio_write 92a52cb4c4SKonstantin Belousovwill occur at 938269e767SBrooks Davisthe absolute position from the beginning of the file plus 948269e767SBrooks Davis.Fa iocb->aio_offset . 958269e767SBrooks Davis.Pp 968269e767SBrooks DavisThe 97a52cb4c4SKonstantin Belousov.Fn aio_write2 98a52cb4c4SKonstantin Belousovcall takes the 99a52cb4c4SKonstantin Belousov.Fa flags 100a52cb4c4SKonstantin Belousovargument. 101a52cb4c4SKonstantin BelousovIf 102a52cb4c4SKonstantin Belousov.Fa flags 103a52cb4c4SKonstantin Belousovis passed as zero, the call behaves identically to 104a52cb4c4SKonstantin Belousov.Fn aio_write . 105a52cb4c4SKonstantin BelousovThe following flags can be specified by logical or: 106a52cb4c4SKonstantin Belousov.Bl -tag -width AIO_OP2_VECTORED 107a52cb4c4SKonstantin Belousov.It AIO_OP2_FOFFSET 108a52cb4c4SKonstantin BelousovThe write for non 109a52cb4c4SKonstantin Belousov.Dv O_APPEND 110a52cb4c4SKonstantin Belousovfile descriptors occurs at the file descriptor offset, 111a52cb4c4SKonstantin Belousovwhich is advanced by the operation as done by the 112a52cb4c4SKonstantin Belousov.Xr write 2 113a52cb4c4SKonstantin Belousovsyscall. 114a52cb4c4SKonstantin BelousovThe 115a52cb4c4SKonstantin Belousov.Fa iocb->aio_offset 116a52cb4c4SKonstantin Belousovfield is ignored. 117a52cb4c4SKonstantin Belousov.It AIO_OP2_VECTORED 118a52cb4c4SKonstantin BelousovSimilar to 119a52cb4c4SKonstantin Belousov.Fn aio_writev , 120a52cb4c4SKonstantin Belousovthe write buffers are specified by the 121a52cb4c4SKonstantin Belousov.Fa aiocb->aio_iov 122a52cb4c4SKonstantin Belousovarray. 123a52cb4c4SKonstantin Belousov.El 124a52cb4c4SKonstantin Belousov.Pp 125a52cb4c4SKonstantin BelousovThe 1268269e767SBrooks Davis.Fa iocb 1278269e767SBrooks Davispointer may be subsequently used as an argument to 1288269e767SBrooks Davis.Fn aio_return 1298269e767SBrooks Davisand 1308269e767SBrooks Davis.Fn aio_error 1318269e767SBrooks Davisin order to determine return or error status for the enqueued operation 1328269e767SBrooks Daviswhile it is in progress. 1338269e767SBrooks Davis.Pp 1348269e767SBrooks DavisIf the request is successfully enqueued, the value of 1358269e767SBrooks Davis.Fa iocb->aio_offset 1368269e767SBrooks Daviscan be modified during the request as context, so this value must not 1378269e767SBrooks Davisbe referenced after the request is enqueued. 1388269e767SBrooks Davis.Pp 1398269e767SBrooks DavisThe 1408269e767SBrooks Davis.Fa iocb->aio_sigevent 1418269e767SBrooks Davisstructure can be used to request notification of the operation's 1428269e767SBrooks Daviscompletion as described in 1438269e767SBrooks Davis.Xr aio 4 . 1448269e767SBrooks Davis.Sh RESTRICTIONS 1458269e767SBrooks DavisThe Asynchronous I/O Control Block structure pointed to by 1468269e767SBrooks Davis.Fa iocb 1478269e767SBrooks Davisand the buffer that the 1488269e767SBrooks Davis.Fa iocb->aio_buf 1498269e767SBrooks Davismember of that structure references must remain valid until the 1508269e767SBrooks Davisoperation has completed. 1518269e767SBrooks Davis.Pp 1528269e767SBrooks DavisThe asynchronous I/O control buffer 1538269e767SBrooks Davis.Fa iocb 1548269e767SBrooks Davisshould be zeroed before the 155a52cb4c4SKonstantin Belousovsystem calls to avoid passing bogus context information to the kernel. 1568269e767SBrooks Davis.Pp 1578269e767SBrooks DavisModifications of the Asynchronous I/O Control Block structure or the 1588269e767SBrooks Davisbuffer contents are not allowed while the request is queued. 1598269e767SBrooks Davis.Pp 1608269e767SBrooks DavisIf the file offset in 1618269e767SBrooks Davis.Fa iocb->aio_offset 1628269e767SBrooks Davisis past the offset maximum for 1638269e767SBrooks Davis.Fa iocb->aio_fildes , 1648269e767SBrooks Davisno I/O will occur. 1658269e767SBrooks Davis.Sh RETURN VALUES 1668269e767SBrooks Davis.Rv -std aio_write aio_writev 1678269e767SBrooks Davis.Sh ERRORS 1688269e767SBrooks DavisThe 169a52cb4c4SKonstantin Belousov.Fn aio_write , 170a52cb4c4SKonstantin Belousov.Fn aio_write2 , 1718269e767SBrooks Davisand 1728269e767SBrooks Davis.Fn aio_writev 1738269e767SBrooks Davissystem calls will fail if: 1748269e767SBrooks Davis.Bl -tag -width Er 1758269e767SBrooks Davis.It Bq Er EAGAIN 1768269e767SBrooks DavisThe request was not queued because of system resource limitations. 1778269e767SBrooks Davis.It Bq Er EFAULT 1788269e767SBrooks DavisPart of 1798269e767SBrooks Davis.Fa aio_iov 1808269e767SBrooks Davispoints outside the process's allocated address space. 1818269e767SBrooks Davis.It Bq Er EINVAL 1828269e767SBrooks DavisThe asynchronous notification method in 1838269e767SBrooks Davis.Fa iocb->aio_sigevent.sigev_notify 1848269e767SBrooks Davisis invalid or not supported. 1858269e767SBrooks Davis.It Bq Er EOPNOTSUPP 1868269e767SBrooks DavisAsynchronous write operations on the file descriptor 1878269e767SBrooks Davis.Fa iocb->aio_fildes 1888269e767SBrooks Davisare unsafe and unsafe asynchronous I/O operations are disabled. 1898269e767SBrooks Davis.El 1908269e767SBrooks Davis.Pp 1918269e767SBrooks DavisThe following conditions may be synchronously detected when the 192a52cb4c4SKonstantin Belousov.Fn aio_write , 193a52cb4c4SKonstantin Belousov.Fn aio_write2 , 1948269e767SBrooks Davisor 1958269e767SBrooks Davis.Fn aio_writev 1968269e767SBrooks Davissystem call is made, or asynchronously, at any time thereafter. 1978269e767SBrooks DavisIf they 198a52cb4c4SKonstantin Belousovare detected at call time, the calls return -1 and set 1998269e767SBrooks Davis.Va errno 2008269e767SBrooks Davisappropriately; otherwise the 2018269e767SBrooks Davis.Fn aio_return 2028269e767SBrooks Davissystem call must be called, and will return -1, and 2038269e767SBrooks Davis.Fn aio_error 2048269e767SBrooks Davismust be called to determine the actual value that would have been 2058269e767SBrooks Davisreturned in 2068269e767SBrooks Davis.Va errno . 2078269e767SBrooks Davis.Bl -tag -width Er 2088269e767SBrooks Davis.It Bq Er EBADF 2098269e767SBrooks DavisThe 2108269e767SBrooks Davis.Fa iocb->aio_fildes 2118269e767SBrooks Davisargument 2128269e767SBrooks Davisis invalid, or is not opened for writing. 2138269e767SBrooks Davis.It Bq Er EINVAL 2148269e767SBrooks DavisThe offset 2158269e767SBrooks Davis.Fa iocb->aio_offset 2168269e767SBrooks Davisis not valid, the priority specified by 2178269e767SBrooks Davis.Fa iocb->aio_reqprio 2188269e767SBrooks Davisis not a valid priority, or the number of bytes specified by 2198269e767SBrooks Davis.Fa iocb->aio_nbytes 2208269e767SBrooks Davisis not valid. 2218269e767SBrooks Davis.El 2228269e767SBrooks Davis.Pp 2238269e767SBrooks DavisIf the request is successfully enqueued, but subsequently canceled 2248269e767SBrooks Davisor an error occurs, the value returned by the 2258269e767SBrooks Davis.Fn aio_return 2268269e767SBrooks Davissystem call is per the 2278269e767SBrooks Davis.Xr write 2 2288269e767SBrooks Davissystem call, and the value returned by the 2298269e767SBrooks Davis.Fn aio_error 2308269e767SBrooks Davissystem call is either one of the error returns from the 2318269e767SBrooks Davis.Xr write 2 2328269e767SBrooks Davissystem call, or one of: 2338269e767SBrooks Davis.Bl -tag -width Er 2348269e767SBrooks Davis.It Bq Er EBADF 2358269e767SBrooks DavisThe 2368269e767SBrooks Davis.Fa iocb->aio_fildes 2378269e767SBrooks Davisargument 2388269e767SBrooks Davisis invalid for writing. 2398269e767SBrooks Davis.It Bq Er ECANCELED 2408269e767SBrooks DavisThe request was explicitly canceled via a call to 2418269e767SBrooks Davis.Fn aio_cancel . 2428269e767SBrooks Davis.It Bq Er EINVAL 2438269e767SBrooks DavisThe offset 2448269e767SBrooks Davis.Fa iocb->aio_offset 2458269e767SBrooks Daviswould be invalid. 2468269e767SBrooks Davis.El 2478269e767SBrooks Davis.Sh SEE ALSO 2488269e767SBrooks Davis.Xr aio_cancel 2 , 2498269e767SBrooks Davis.Xr aio_error 2 , 2508269e767SBrooks Davis.Xr aio_return 2 , 2518269e767SBrooks Davis.Xr aio_suspend 2 , 2528269e767SBrooks Davis.Xr aio_waitcomplete 2 , 2538269e767SBrooks Davis.Xr sigevent 3 , 2548269e767SBrooks Davis.Xr siginfo 3 , 2558269e767SBrooks Davis.Xr aio 4 2568269e767SBrooks Davis.Sh STANDARDS 2578269e767SBrooks DavisThe 2588269e767SBrooks Davis.Fn aio_write 2598269e767SBrooks Davissystem call 2608269e767SBrooks Davisis expected to conform to the 2618269e767SBrooks Davis.St -p1003.1 2628269e767SBrooks Davisstandard. 2638269e767SBrooks Davis.Pp 2648269e767SBrooks DavisThe 265a52cb4c4SKonstantin Belousov.Fn aio_write2 266a52cb4c4SKonstantin Belousovand 2678269e767SBrooks Davis.Fn aio_writev 268d97e4478SEnji Coopersystem calls are 269d97e4478SEnji Cooper.Fx 270d97e4478SEnji Cooperextensions, 271a52cb4c4SKonstantin Belousovand should not be used in portable code. 2728269e767SBrooks Davis.Sh HISTORY 2738269e767SBrooks DavisThe 2748269e767SBrooks Davis.Fn aio_write 2758269e767SBrooks Davissystem call first appeared in 2768269e767SBrooks Davis.Fx 3.0 . 2778269e767SBrooks DavisThe 2788269e767SBrooks Davis.Fn aio_writev 2798269e767SBrooks Davissystem call first appeared in 2808269e767SBrooks Davis.Fx 13.0 . 281a52cb4c4SKonstantin BelousovThe 282a52cb4c4SKonstantin Belousov.Fn aio_write2 283a52cb4c4SKonstantin Belousovsystem call first appeared in 284a52cb4c4SKonstantin Belousov.Fx 14.1 . 2858269e767SBrooks Davis.Sh AUTHORS 2868269e767SBrooks DavisThis manual page was written by 2878269e767SBrooks Davis.An Wes Peters Aq Mt wes@softweyr.com . 2888269e767SBrooks Davis.Sh BUGS 2898269e767SBrooks DavisInvalid information in 2908269e767SBrooks Davis.Fa iocb->_aiocb_private 2918269e767SBrooks Davismay confuse the kernel. 292