xref: /qemu/include/io/channel.h (revision 401e311ff72e0a62c834bfe466de68a82cfd90cb)
1666a3af9SDaniel P. Berrange /*
2666a3af9SDaniel P. Berrange  * QEMU I/O channels
3666a3af9SDaniel P. Berrange  *
4666a3af9SDaniel P. Berrange  * Copyright (c) 2015 Red Hat, Inc.
5666a3af9SDaniel P. Berrange  *
6666a3af9SDaniel P. Berrange  * This library is free software; you can redistribute it and/or
7666a3af9SDaniel P. Berrange  * modify it under the terms of the GNU Lesser General Public
8666a3af9SDaniel P. Berrange  * License as published by the Free Software Foundation; either
9c8198bd5SChetan Pant  * version 2.1 of the License, or (at your option) any later version.
10666a3af9SDaniel P. Berrange  *
11666a3af9SDaniel P. Berrange  * This library is distributed in the hope that it will be useful,
12666a3af9SDaniel P. Berrange  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13666a3af9SDaniel P. Berrange  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14666a3af9SDaniel P. Berrange  * Lesser General Public License for more details.
15666a3af9SDaniel P. Berrange  *
16666a3af9SDaniel P. Berrange  * You should have received a copy of the GNU Lesser General Public
17666a3af9SDaniel P. Berrange  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
18666a3af9SDaniel P. Berrange  *
19666a3af9SDaniel P. Berrange  */
20666a3af9SDaniel P. Berrange 
212a6a4076SMarkus Armbruster #ifndef QIO_CHANNEL_H
222a6a4076SMarkus Armbruster #define QIO_CHANNEL_H
23666a3af9SDaniel P. Berrange 
24666a3af9SDaniel P. Berrange #include "qom/object.h"
2568ba85ceSMarkus Armbruster #include "qemu/coroutine-core.h"
26bf88c124SPaolo Bonzini #include "block/aio.h"
27666a3af9SDaniel P. Berrange 
28666a3af9SDaniel P. Berrange #define TYPE_QIO_CHANNEL "qio-channel"
29c821774aSEduardo Habkost OBJECT_DECLARE_TYPE(QIOChannel, QIOChannelClass,
3030b5707cSEduardo Habkost                     QIO_CHANNEL)
31666a3af9SDaniel P. Berrange 
32666a3af9SDaniel P. Berrange 
33666a3af9SDaniel P. Berrange #define QIO_CHANNEL_ERR_BLOCK -2
34666a3af9SDaniel P. Berrange 
35b88651cbSLeonardo Bras #define QIO_CHANNEL_WRITE_FLAG_ZERO_COPY 0x1
36b88651cbSLeonardo Bras 
3784615a19Smanish.mishra #define QIO_CHANNEL_READ_FLAG_MSG_PEEK 0x1
3884615a19Smanish.mishra 
39666a3af9SDaniel P. Berrange typedef enum QIOChannelFeature QIOChannelFeature;
40666a3af9SDaniel P. Berrange 
41666a3af9SDaniel P. Berrange enum QIOChannelFeature {
428fbf6612SFelipe Franciosi     QIO_CHANNEL_FEATURE_FD_PASS,
438fbf6612SFelipe Franciosi     QIO_CHANNEL_FEATURE_SHUTDOWN,
448fbf6612SFelipe Franciosi     QIO_CHANNEL_FEATURE_LISTEN,
45b88651cbSLeonardo Bras     QIO_CHANNEL_FEATURE_WRITE_ZERO_COPY,
4684615a19Smanish.mishra     QIO_CHANNEL_FEATURE_READ_MSG_PEEK,
47*401e311fSNikolay Borisov     QIO_CHANNEL_FEATURE_SEEKABLE,
48666a3af9SDaniel P. Berrange };
49666a3af9SDaniel P. Berrange 
50666a3af9SDaniel P. Berrange 
51666a3af9SDaniel P. Berrange typedef enum QIOChannelShutdown QIOChannelShutdown;
52666a3af9SDaniel P. Berrange 
53666a3af9SDaniel P. Berrange enum QIOChannelShutdown {
54a2458b6fSDaniel P. Berrangé     QIO_CHANNEL_SHUTDOWN_READ = 1,
55a2458b6fSDaniel P. Berrangé     QIO_CHANNEL_SHUTDOWN_WRITE = 2,
56a2458b6fSDaniel P. Berrangé     QIO_CHANNEL_SHUTDOWN_BOTH = 3,
57666a3af9SDaniel P. Berrange };
58666a3af9SDaniel P. Berrange 
59666a3af9SDaniel P. Berrange typedef gboolean (*QIOChannelFunc)(QIOChannel *ioc,
60666a3af9SDaniel P. Berrange                                    GIOCondition condition,
61666a3af9SDaniel P. Berrange                                    gpointer data);
62666a3af9SDaniel P. Berrange 
63666a3af9SDaniel P. Berrange /**
64666a3af9SDaniel P. Berrange  * QIOChannel:
65666a3af9SDaniel P. Berrange  *
66666a3af9SDaniel P. Berrange  * The QIOChannel defines the core API for a generic I/O channel
67666a3af9SDaniel P. Berrange  * class hierarchy. It is inspired by GIOChannel, but has the
68666a3af9SDaniel P. Berrange  * following differences
69666a3af9SDaniel P. Berrange  *
70666a3af9SDaniel P. Berrange  *  - Use QOM to properly support arbitrary subclassing
71666a3af9SDaniel P. Berrange  *  - Support use of iovecs for efficient I/O with multiple blocks
72666a3af9SDaniel P. Berrange  *  - None of the character set translation, binary data exclusively
73666a3af9SDaniel P. Berrange  *  - Direct support for QEMU Error object reporting
74666a3af9SDaniel P. Berrange  *  - File descriptor passing
75666a3af9SDaniel P. Berrange  *
76666a3af9SDaniel P. Berrange  * This base class is abstract so cannot be instantiated. There
77666a3af9SDaniel P. Berrange  * will be subclasses for dealing with sockets, files, and higher
78666a3af9SDaniel P. Berrange  * level protocols such as TLS, WebSocket, etc.
79666a3af9SDaniel P. Berrange  */
80666a3af9SDaniel P. Berrange 
81666a3af9SDaniel P. Berrange struct QIOChannel {
82666a3af9SDaniel P. Berrange     Object parent;
83666a3af9SDaniel P. Berrange     unsigned int features; /* bitmask of QIOChannelFeatures */
8420f4aa26SDaniel P. Berrange     char *name;
8506e0f098SStefan Hajnoczi     AioContext *read_ctx;
86c4c497d2SPaolo Bonzini     Coroutine *read_coroutine;
8706e0f098SStefan Hajnoczi     AioContext *write_ctx;
88c4c497d2SPaolo Bonzini     Coroutine *write_coroutine;
8906e0f098SStefan Hajnoczi     bool follow_coroutine_ctx;
90a5897205SPaolo Bonzini #ifdef _WIN32
91a5897205SPaolo Bonzini     HANDLE event; /* For use with GSource on Win32 */
92a5897205SPaolo Bonzini #endif
93666a3af9SDaniel P. Berrange };
94666a3af9SDaniel P. Berrange 
95666a3af9SDaniel P. Berrange /**
96666a3af9SDaniel P. Berrange  * QIOChannelClass:
97666a3af9SDaniel P. Berrange  *
98666a3af9SDaniel P. Berrange  * This class defines the contract that all subclasses
99666a3af9SDaniel P. Berrange  * must follow to provide specific channel implementations.
100666a3af9SDaniel P. Berrange  * The first five callbacks are mandatory to support, others
101666a3af9SDaniel P. Berrange  * provide additional optional features.
102666a3af9SDaniel P. Berrange  *
103666a3af9SDaniel P. Berrange  * Consult the corresponding public API docs for a description
1048659f317SLukas Straub  * of the semantics of each callback. io_shutdown in particular
1058659f317SLukas Straub  * must be thread-safe, terminate quickly and must not block.
106666a3af9SDaniel P. Berrange  */
107666a3af9SDaniel P. Berrange struct QIOChannelClass {
108666a3af9SDaniel P. Berrange     ObjectClass parent;
109666a3af9SDaniel P. Berrange 
110666a3af9SDaniel P. Berrange     /* Mandatory callbacks */
111666a3af9SDaniel P. Berrange     ssize_t (*io_writev)(QIOChannel *ioc,
112666a3af9SDaniel P. Berrange                          const struct iovec *iov,
113666a3af9SDaniel P. Berrange                          size_t niov,
114666a3af9SDaniel P. Berrange                          int *fds,
115666a3af9SDaniel P. Berrange                          size_t nfds,
116b88651cbSLeonardo Bras                          int flags,
117666a3af9SDaniel P. Berrange                          Error **errp);
118666a3af9SDaniel P. Berrange     ssize_t (*io_readv)(QIOChannel *ioc,
119666a3af9SDaniel P. Berrange                         const struct iovec *iov,
120666a3af9SDaniel P. Berrange                         size_t niov,
121666a3af9SDaniel P. Berrange                         int **fds,
122666a3af9SDaniel P. Berrange                         size_t *nfds,
12384615a19Smanish.mishra                         int flags,
124666a3af9SDaniel P. Berrange                         Error **errp);
125666a3af9SDaniel P. Berrange     int (*io_close)(QIOChannel *ioc,
126666a3af9SDaniel P. Berrange                     Error **errp);
127666a3af9SDaniel P. Berrange     GSource * (*io_create_watch)(QIOChannel *ioc,
128666a3af9SDaniel P. Berrange                                  GIOCondition condition);
129666a3af9SDaniel P. Berrange     int (*io_set_blocking)(QIOChannel *ioc,
130666a3af9SDaniel P. Berrange                            bool enabled,
131666a3af9SDaniel P. Berrange                            Error **errp);
132666a3af9SDaniel P. Berrange 
133666a3af9SDaniel P. Berrange     /* Optional callbacks */
134666a3af9SDaniel P. Berrange     int (*io_shutdown)(QIOChannel *ioc,
135666a3af9SDaniel P. Berrange                        QIOChannelShutdown how,
136666a3af9SDaniel P. Berrange                        Error **errp);
137666a3af9SDaniel P. Berrange     void (*io_set_cork)(QIOChannel *ioc,
138666a3af9SDaniel P. Berrange                         bool enabled);
139666a3af9SDaniel P. Berrange     void (*io_set_delay)(QIOChannel *ioc,
140666a3af9SDaniel P. Berrange                          bool enabled);
141666a3af9SDaniel P. Berrange     off_t (*io_seek)(QIOChannel *ioc,
142666a3af9SDaniel P. Berrange                      off_t offset,
143666a3af9SDaniel P. Berrange                      int whence,
144666a3af9SDaniel P. Berrange                      Error **errp);
145bf88c124SPaolo Bonzini     void (*io_set_aio_fd_handler)(QIOChannel *ioc,
14606e0f098SStefan Hajnoczi                                   AioContext *read_ctx,
147bf88c124SPaolo Bonzini                                   IOHandler *io_read,
14806e0f098SStefan Hajnoczi                                   AioContext *write_ctx,
149bf88c124SPaolo Bonzini                                   IOHandler *io_write,
150bf88c124SPaolo Bonzini                                   void *opaque);
151b88651cbSLeonardo Bras     int (*io_flush)(QIOChannel *ioc,
152b88651cbSLeonardo Bras                     Error **errp);
153666a3af9SDaniel P. Berrange };
154666a3af9SDaniel P. Berrange 
155666a3af9SDaniel P. Berrange /* General I/O handling functions */
156666a3af9SDaniel P. Berrange 
157666a3af9SDaniel P. Berrange /**
158666a3af9SDaniel P. Berrange  * qio_channel_has_feature:
159666a3af9SDaniel P. Berrange  * @ioc: the channel object
160666a3af9SDaniel P. Berrange  * @feature: the feature to check support of
161666a3af9SDaniel P. Berrange  *
162666a3af9SDaniel P. Berrange  * Determine whether the channel implementation supports
163666a3af9SDaniel P. Berrange  * the optional feature named in @feature.
164666a3af9SDaniel P. Berrange  *
165666a3af9SDaniel P. Berrange  * Returns: true if supported, false otherwise.
166666a3af9SDaniel P. Berrange  */
167666a3af9SDaniel P. Berrange bool qio_channel_has_feature(QIOChannel *ioc,
168666a3af9SDaniel P. Berrange                              QIOChannelFeature feature);
169666a3af9SDaniel P. Berrange 
170666a3af9SDaniel P. Berrange /**
171d8d3c7ccSFelipe Franciosi  * qio_channel_set_feature:
172d8d3c7ccSFelipe Franciosi  * @ioc: the channel object
173d8d3c7ccSFelipe Franciosi  * @feature: the feature to set support for
174d8d3c7ccSFelipe Franciosi  *
175d8d3c7ccSFelipe Franciosi  * Add channel support for the feature named in @feature.
176d8d3c7ccSFelipe Franciosi  */
177d8d3c7ccSFelipe Franciosi void qio_channel_set_feature(QIOChannel *ioc,
178d8d3c7ccSFelipe Franciosi                              QIOChannelFeature feature);
179d8d3c7ccSFelipe Franciosi 
180d8d3c7ccSFelipe Franciosi /**
18120f4aa26SDaniel P. Berrange  * qio_channel_set_name:
18220f4aa26SDaniel P. Berrange  * @ioc: the channel object
18320f4aa26SDaniel P. Berrange  * @name: the name of the channel
18420f4aa26SDaniel P. Berrange  *
18520f4aa26SDaniel P. Berrange  * Sets the name of the channel, which serves as an aid
18620f4aa26SDaniel P. Berrange  * to debugging. The name is used when creating GSource
18720f4aa26SDaniel P. Berrange  * watches for this channel.
18820f4aa26SDaniel P. Berrange  */
18920f4aa26SDaniel P. Berrange void qio_channel_set_name(QIOChannel *ioc,
19020f4aa26SDaniel P. Berrange                           const char *name);
19120f4aa26SDaniel P. Berrange 
19220f4aa26SDaniel P. Berrange /**
193666a3af9SDaniel P. Berrange  * qio_channel_readv_full:
194666a3af9SDaniel P. Berrange  * @ioc: the channel object
195666a3af9SDaniel P. Berrange  * @iov: the array of memory regions to read data into
196666a3af9SDaniel P. Berrange  * @niov: the length of the @iov array
197666a3af9SDaniel P. Berrange  * @fds: pointer to an array that will received file handles
198666a3af9SDaniel P. Berrange  * @nfds: pointer filled with number of elements in @fds on return
19984615a19Smanish.mishra  * @flags: read flags (QIO_CHANNEL_READ_FLAG_*)
200821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
201666a3af9SDaniel P. Berrange  *
202666a3af9SDaniel P. Berrange  * Read data from the IO channel, storing it in the
203666a3af9SDaniel P. Berrange  * memory regions referenced by @iov. Each element
204666a3af9SDaniel P. Berrange  * in the @iov will be fully populated with data
205666a3af9SDaniel P. Berrange  * before the next one is used. The @niov parameter
206666a3af9SDaniel P. Berrange  * specifies the total number of elements in @iov.
207666a3af9SDaniel P. Berrange  *
208666a3af9SDaniel P. Berrange  * It is not required for all @iov to be filled with
209666a3af9SDaniel P. Berrange  * data. If the channel is in blocking mode, at least
210666a3af9SDaniel P. Berrange  * one byte of data will be read, but no more is
211666a3af9SDaniel P. Berrange  * guaranteed. If the channel is non-blocking and no
212666a3af9SDaniel P. Berrange  * data is available, it will return QIO_CHANNEL_ERR_BLOCK
213666a3af9SDaniel P. Berrange  *
214666a3af9SDaniel P. Berrange  * If the channel has passed any file descriptors,
215666a3af9SDaniel P. Berrange  * the @fds array pointer will be allocated and
216666a3af9SDaniel P. Berrange  * the elements filled with the received file
217666a3af9SDaniel P. Berrange  * descriptors. The @nfds pointer will be updated
218666a3af9SDaniel P. Berrange  * to indicate the size of the @fds array that
219666a3af9SDaniel P. Berrange  * was allocated. It is the callers responsibility
220666a3af9SDaniel P. Berrange  * to call close() on each file descriptor and to
221666a3af9SDaniel P. Berrange  * call g_free() on the array pointer in @fds.
222666a3af9SDaniel P. Berrange  *
223666a3af9SDaniel P. Berrange  * It is an error to pass a non-NULL @fds parameter
224666a3af9SDaniel P. Berrange  * unless qio_channel_has_feature() returns a true
225666a3af9SDaniel P. Berrange  * value for the QIO_CHANNEL_FEATURE_FD_PASS constant.
226666a3af9SDaniel P. Berrange  *
227666a3af9SDaniel P. Berrange  * Returns: the number of bytes read, or -1 on error,
228666a3af9SDaniel P. Berrange  * or QIO_CHANNEL_ERR_BLOCK if no data is available
229666a3af9SDaniel P. Berrange  * and the channel is non-blocking
230666a3af9SDaniel P. Berrange  */
231666a3af9SDaniel P. Berrange ssize_t qio_channel_readv_full(QIOChannel *ioc,
232666a3af9SDaniel P. Berrange                                const struct iovec *iov,
233666a3af9SDaniel P. Berrange                                size_t niov,
234666a3af9SDaniel P. Berrange                                int **fds,
235666a3af9SDaniel P. Berrange                                size_t *nfds,
23684615a19Smanish.mishra                                int flags,
237666a3af9SDaniel P. Berrange                                Error **errp);
238666a3af9SDaniel P. Berrange 
239666a3af9SDaniel P. Berrange 
240666a3af9SDaniel P. Berrange /**
241666a3af9SDaniel P. Berrange  * qio_channel_writev_full:
242666a3af9SDaniel P. Berrange  * @ioc: the channel object
243666a3af9SDaniel P. Berrange  * @iov: the array of memory regions to write data from
244666a3af9SDaniel P. Berrange  * @niov: the length of the @iov array
245666a3af9SDaniel P. Berrange  * @fds: an array of file handles to send
246666a3af9SDaniel P. Berrange  * @nfds: number of file handles in @fds
247b88651cbSLeonardo Bras  * @flags: write flags (QIO_CHANNEL_WRITE_FLAG_*)
248821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
249666a3af9SDaniel P. Berrange  *
250666a3af9SDaniel P. Berrange  * Write data to the IO channel, reading it from the
251666a3af9SDaniel P. Berrange  * memory regions referenced by @iov. Each element
252666a3af9SDaniel P. Berrange  * in the @iov will be fully sent, before the next
253666a3af9SDaniel P. Berrange  * one is used. The @niov parameter specifies the
254666a3af9SDaniel P. Berrange  * total number of elements in @iov.
255666a3af9SDaniel P. Berrange  *
256666a3af9SDaniel P. Berrange  * It is not required for all @iov data to be fully
257666a3af9SDaniel P. Berrange  * sent. If the channel is in blocking mode, at least
258666a3af9SDaniel P. Berrange  * one byte of data will be sent, but no more is
259666a3af9SDaniel P. Berrange  * guaranteed. If the channel is non-blocking and no
260666a3af9SDaniel P. Berrange  * data can be sent, it will return QIO_CHANNEL_ERR_BLOCK
261666a3af9SDaniel P. Berrange  *
262666a3af9SDaniel P. Berrange  * If there are file descriptors to send, the @fds
263666a3af9SDaniel P. Berrange  * array should be non-NULL and provide the handles.
264666a3af9SDaniel P. Berrange  * All file descriptors will be sent if at least one
265666a3af9SDaniel P. Berrange  * byte of data was sent.
266666a3af9SDaniel P. Berrange  *
267666a3af9SDaniel P. Berrange  * It is an error to pass a non-NULL @fds parameter
268666a3af9SDaniel P. Berrange  * unless qio_channel_has_feature() returns a true
269666a3af9SDaniel P. Berrange  * value for the QIO_CHANNEL_FEATURE_FD_PASS constant.
270666a3af9SDaniel P. Berrange  *
271666a3af9SDaniel P. Berrange  * Returns: the number of bytes sent, or -1 on error,
272666a3af9SDaniel P. Berrange  * or QIO_CHANNEL_ERR_BLOCK if no data is can be sent
273666a3af9SDaniel P. Berrange  * and the channel is non-blocking
274666a3af9SDaniel P. Berrange  */
275666a3af9SDaniel P. Berrange ssize_t qio_channel_writev_full(QIOChannel *ioc,
276666a3af9SDaniel P. Berrange                                 const struct iovec *iov,
277666a3af9SDaniel P. Berrange                                 size_t niov,
278666a3af9SDaniel P. Berrange                                 int *fds,
279666a3af9SDaniel P. Berrange                                 size_t nfds,
280b88651cbSLeonardo Bras                                 int flags,
281666a3af9SDaniel P. Berrange                                 Error **errp);
282666a3af9SDaniel P. Berrange 
283666a3af9SDaniel P. Berrange /**
284e8ffaa31SEric Blake  * qio_channel_readv_all_eof:
285e8ffaa31SEric Blake  * @ioc: the channel object
286e8ffaa31SEric Blake  * @iov: the array of memory regions to read data into
287e8ffaa31SEric Blake  * @niov: the length of the @iov array
288e8ffaa31SEric Blake  * @errp: pointer to a NULL-initialized error object
289e8ffaa31SEric Blake  *
290e8ffaa31SEric Blake  * Read data from the IO channel, storing it in the
291e8ffaa31SEric Blake  * memory regions referenced by @iov. Each element
292e8ffaa31SEric Blake  * in the @iov will be fully populated with data
293e8ffaa31SEric Blake  * before the next one is used. The @niov parameter
294e8ffaa31SEric Blake  * specifies the total number of elements in @iov.
295e8ffaa31SEric Blake  *
296e8ffaa31SEric Blake  * The function will wait for all requested data
297e8ffaa31SEric Blake  * to be read, yielding from the current coroutine
298e8ffaa31SEric Blake  * if required.
299e8ffaa31SEric Blake  *
300e8ffaa31SEric Blake  * If end-of-file occurs before any data is read,
301e8ffaa31SEric Blake  * no error is reported; otherwise, if it occurs
302e8ffaa31SEric Blake  * before all requested data has been read, an error
303e8ffaa31SEric Blake  * will be reported.
304e8ffaa31SEric Blake  *
305e8ffaa31SEric Blake  * Returns: 1 if all bytes were read, 0 if end-of-file
306e8ffaa31SEric Blake  *          occurs without data, or -1 on error
307e8ffaa31SEric Blake  */
3081dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_readv_all_eof(QIOChannel *ioc,
309e8ffaa31SEric Blake                                                  const struct iovec *iov,
310e8ffaa31SEric Blake                                                  size_t niov,
311e8ffaa31SEric Blake                                                  Error **errp);
312e8ffaa31SEric Blake 
313e8ffaa31SEric Blake /**
314d4622e55SDaniel P. Berrange  * qio_channel_readv_all:
315d4622e55SDaniel P. Berrange  * @ioc: the channel object
316d4622e55SDaniel P. Berrange  * @iov: the array of memory regions to read data into
317d4622e55SDaniel P. Berrange  * @niov: the length of the @iov array
318d4622e55SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
319d4622e55SDaniel P. Berrange  *
320d4622e55SDaniel P. Berrange  * Read data from the IO channel, storing it in the
321d4622e55SDaniel P. Berrange  * memory regions referenced by @iov. Each element
322d4622e55SDaniel P. Berrange  * in the @iov will be fully populated with data
323d4622e55SDaniel P. Berrange  * before the next one is used. The @niov parameter
324d4622e55SDaniel P. Berrange  * specifies the total number of elements in @iov.
325d4622e55SDaniel P. Berrange  *
326d4622e55SDaniel P. Berrange  * The function will wait for all requested data
327d4622e55SDaniel P. Berrange  * to be read, yielding from the current coroutine
328d4622e55SDaniel P. Berrange  * if required.
329d4622e55SDaniel P. Berrange  *
330d4622e55SDaniel P. Berrange  * If end-of-file occurs before all requested data
331d4622e55SDaniel P. Berrange  * has been read, an error will be reported.
332d4622e55SDaniel P. Berrange  *
333d4622e55SDaniel P. Berrange  * Returns: 0 if all bytes were read, or -1 on error
334d4622e55SDaniel P. Berrange  */
3351dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_readv_all(QIOChannel *ioc,
336d4622e55SDaniel P. Berrange                                              const struct iovec *iov,
337d4622e55SDaniel P. Berrange                                              size_t niov,
338d4622e55SDaniel P. Berrange                                              Error **errp);
339d4622e55SDaniel P. Berrange 
340d4622e55SDaniel P. Berrange 
341d4622e55SDaniel P. Berrange /**
342d4622e55SDaniel P. Berrange  * qio_channel_writev_all:
343d4622e55SDaniel P. Berrange  * @ioc: the channel object
344d4622e55SDaniel P. Berrange  * @iov: the array of memory regions to write data from
345d4622e55SDaniel P. Berrange  * @niov: the length of the @iov array
346d4622e55SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
347d4622e55SDaniel P. Berrange  *
348d4622e55SDaniel P. Berrange  * Write data to the IO channel, reading it from the
349d4622e55SDaniel P. Berrange  * memory regions referenced by @iov. Each element
350d4622e55SDaniel P. Berrange  * in the @iov will be fully sent, before the next
351d4622e55SDaniel P. Berrange  * one is used. The @niov parameter specifies the
352d4622e55SDaniel P. Berrange  * total number of elements in @iov.
353d4622e55SDaniel P. Berrange  *
354d4622e55SDaniel P. Berrange  * The function will wait for all requested data
355d4622e55SDaniel P. Berrange  * to be written, yielding from the current coroutine
356d4622e55SDaniel P. Berrange  * if required.
357d4622e55SDaniel P. Berrange  *
358d4622e55SDaniel P. Berrange  * Returns: 0 if all bytes were written, or -1 on error
359d4622e55SDaniel P. Berrange  */
3601dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_writev_all(QIOChannel *ioc,
361d4622e55SDaniel P. Berrange                                               const struct iovec *iov,
362d4622e55SDaniel P. Berrange                                               size_t niov,
36310220d2fSMarkus Armbruster                                               Error **errp);
364d4622e55SDaniel P. Berrange 
365d4622e55SDaniel P. Berrange /**
366666a3af9SDaniel P. Berrange  * qio_channel_readv:
367666a3af9SDaniel P. Berrange  * @ioc: the channel object
368666a3af9SDaniel P. Berrange  * @iov: the array of memory regions to read data into
369666a3af9SDaniel P. Berrange  * @niov: the length of the @iov array
370821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
371666a3af9SDaniel P. Berrange  *
372666a3af9SDaniel P. Berrange  * Behaves as qio_channel_readv_full() but does not support
373666a3af9SDaniel P. Berrange  * receiving of file handles.
374666a3af9SDaniel P. Berrange  */
375666a3af9SDaniel P. Berrange ssize_t qio_channel_readv(QIOChannel *ioc,
376666a3af9SDaniel P. Berrange                           const struct iovec *iov,
377666a3af9SDaniel P. Berrange                           size_t niov,
378666a3af9SDaniel P. Berrange                           Error **errp);
379666a3af9SDaniel P. Berrange 
380666a3af9SDaniel P. Berrange /**
381666a3af9SDaniel P. Berrange  * qio_channel_writev:
382666a3af9SDaniel P. Berrange  * @ioc: the channel object
383666a3af9SDaniel P. Berrange  * @iov: the array of memory regions to write data from
384666a3af9SDaniel P. Berrange  * @niov: the length of the @iov array
385821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
386666a3af9SDaniel P. Berrange  *
387666a3af9SDaniel P. Berrange  * Behaves as qio_channel_writev_full() but does not support
388666a3af9SDaniel P. Berrange  * sending of file handles.
389666a3af9SDaniel P. Berrange  */
390666a3af9SDaniel P. Berrange ssize_t qio_channel_writev(QIOChannel *ioc,
391666a3af9SDaniel P. Berrange                            const struct iovec *iov,
392666a3af9SDaniel P. Berrange                            size_t niov,
393666a3af9SDaniel P. Berrange                            Error **errp);
394666a3af9SDaniel P. Berrange 
395666a3af9SDaniel P. Berrange /**
39650ea44f0SDaniel P. Berrange  * qio_channel_read:
397666a3af9SDaniel P. Berrange  * @ioc: the channel object
398666a3af9SDaniel P. Berrange  * @buf: the memory region to read data into
399666a3af9SDaniel P. Berrange  * @buflen: the length of @buf
400821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
401666a3af9SDaniel P. Berrange  *
402666a3af9SDaniel P. Berrange  * Behaves as qio_channel_readv_full() but does not support
403666a3af9SDaniel P. Berrange  * receiving of file handles, and only supports reading into
404666a3af9SDaniel P. Berrange  * a single memory region.
405666a3af9SDaniel P. Berrange  */
406666a3af9SDaniel P. Berrange ssize_t qio_channel_read(QIOChannel *ioc,
407666a3af9SDaniel P. Berrange                          char *buf,
408666a3af9SDaniel P. Berrange                          size_t buflen,
409666a3af9SDaniel P. Berrange                          Error **errp);
410666a3af9SDaniel P. Berrange 
411666a3af9SDaniel P. Berrange /**
41261f7c6a0SMarc-André Lureau  * qio_channel_write:
413666a3af9SDaniel P. Berrange  * @ioc: the channel object
414666a3af9SDaniel P. Berrange  * @buf: the memory regions to send data from
415666a3af9SDaniel P. Berrange  * @buflen: the length of @buf
416821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
417666a3af9SDaniel P. Berrange  *
418666a3af9SDaniel P. Berrange  * Behaves as qio_channel_writev_full() but does not support
419666a3af9SDaniel P. Berrange  * sending of file handles, and only supports writing from a
420666a3af9SDaniel P. Berrange  * single memory region.
421666a3af9SDaniel P. Berrange  */
422666a3af9SDaniel P. Berrange ssize_t qio_channel_write(QIOChannel *ioc,
423666a3af9SDaniel P. Berrange                           const char *buf,
424666a3af9SDaniel P. Berrange                           size_t buflen,
425666a3af9SDaniel P. Berrange                           Error **errp);
426666a3af9SDaniel P. Berrange 
427666a3af9SDaniel P. Berrange /**
428e8ffaa31SEric Blake  * qio_channel_read_all_eof:
429e8ffaa31SEric Blake  * @ioc: the channel object
430e8ffaa31SEric Blake  * @buf: the memory region to read data into
431e8ffaa31SEric Blake  * @buflen: the number of bytes to @buf
432e8ffaa31SEric Blake  * @errp: pointer to a NULL-initialized error object
433e8ffaa31SEric Blake  *
434e8ffaa31SEric Blake  * Reads @buflen bytes into @buf, possibly blocking or (if the
435e8ffaa31SEric Blake  * channel is non-blocking) yielding from the current coroutine
436e8ffaa31SEric Blake  * multiple times until the entire content is read. If end-of-file
437e8ffaa31SEric Blake  * occurs immediately it is not an error, but if it occurs after
438e8ffaa31SEric Blake  * data has been read it will return an error rather than a
439e8ffaa31SEric Blake  * short-read. Otherwise behaves as qio_channel_read().
440e8ffaa31SEric Blake  *
441e8ffaa31SEric Blake  * Returns: 1 if all bytes were read, 0 if end-of-file occurs
442e8ffaa31SEric Blake  *          without data, or -1 on error
443e8ffaa31SEric Blake  */
4441dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_read_all_eof(QIOChannel *ioc,
445e8ffaa31SEric Blake                                                 char *buf,
446e8ffaa31SEric Blake                                                 size_t buflen,
447e8ffaa31SEric Blake                                                 Error **errp);
448e8ffaa31SEric Blake 
449e8ffaa31SEric Blake /**
450d4622e55SDaniel P. Berrange  * qio_channel_read_all:
451d4622e55SDaniel P. Berrange  * @ioc: the channel object
452d4622e55SDaniel P. Berrange  * @buf: the memory region to read data into
453d4622e55SDaniel P. Berrange  * @buflen: the number of bytes to @buf
454d4622e55SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
455d4622e55SDaniel P. Berrange  *
456d4622e55SDaniel P. Berrange  * Reads @buflen bytes into @buf, possibly blocking or (if the
457d4622e55SDaniel P. Berrange  * channel is non-blocking) yielding from the current coroutine
458d4622e55SDaniel P. Berrange  * multiple times until the entire content is read. If end-of-file
459d4622e55SDaniel P. Berrange  * occurs it will return an error rather than a short-read. Otherwise
460d4622e55SDaniel P. Berrange  * behaves as qio_channel_read().
461d4622e55SDaniel P. Berrange  *
462d4622e55SDaniel P. Berrange  * Returns: 0 if all bytes were read, or -1 on error
463d4622e55SDaniel P. Berrange  */
4641dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_read_all(QIOChannel *ioc,
465d4622e55SDaniel P. Berrange                                             char *buf,
466d4622e55SDaniel P. Berrange                                             size_t buflen,
467d4622e55SDaniel P. Berrange                                             Error **errp);
468e8ffaa31SEric Blake 
469d4622e55SDaniel P. Berrange /**
470d4622e55SDaniel P. Berrange  * qio_channel_write_all:
471d4622e55SDaniel P. Berrange  * @ioc: the channel object
472d4622e55SDaniel P. Berrange  * @buf: the memory region to write data into
473d4622e55SDaniel P. Berrange  * @buflen: the number of bytes to @buf
474d4622e55SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
475d4622e55SDaniel P. Berrange  *
476d4622e55SDaniel P. Berrange  * Writes @buflen bytes from @buf, possibly blocking or (if the
477d4622e55SDaniel P. Berrange  * channel is non-blocking) yielding from the current coroutine
478d4622e55SDaniel P. Berrange  * multiple times until the entire content is written.  Otherwise
479d4622e55SDaniel P. Berrange  * behaves as qio_channel_write().
480d4622e55SDaniel P. Berrange  *
481d4622e55SDaniel P. Berrange  * Returns: 0 if all bytes were written, or -1 on error
482d4622e55SDaniel P. Berrange  */
4831dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_write_all(QIOChannel *ioc,
484d4622e55SDaniel P. Berrange                                              const char *buf,
485d4622e55SDaniel P. Berrange                                              size_t buflen,
486d4622e55SDaniel P. Berrange                                              Error **errp);
487d4622e55SDaniel P. Berrange 
488d4622e55SDaniel P. Berrange /**
489666a3af9SDaniel P. Berrange  * qio_channel_set_blocking:
490666a3af9SDaniel P. Berrange  * @ioc: the channel object
491666a3af9SDaniel P. Berrange  * @enabled: the blocking flag state
492821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
493666a3af9SDaniel P. Berrange  *
494666a3af9SDaniel P. Berrange  * If @enabled is true, then the channel is put into
495666a3af9SDaniel P. Berrange  * blocking mode, otherwise it will be non-blocking.
496666a3af9SDaniel P. Berrange  *
497666a3af9SDaniel P. Berrange  * In non-blocking mode, read/write operations may
498666a3af9SDaniel P. Berrange  * return QIO_CHANNEL_ERR_BLOCK if they would otherwise
499666a3af9SDaniel P. Berrange  * block on I/O
500666a3af9SDaniel P. Berrange  */
501666a3af9SDaniel P. Berrange int qio_channel_set_blocking(QIOChannel *ioc,
502666a3af9SDaniel P. Berrange                              bool enabled,
503666a3af9SDaniel P. Berrange                              Error **errp);
504666a3af9SDaniel P. Berrange 
505666a3af9SDaniel P. Berrange /**
50606e0f098SStefan Hajnoczi  * qio_channel_set_follow_coroutine_ctx:
50706e0f098SStefan Hajnoczi  * @ioc: the channel object
50806e0f098SStefan Hajnoczi  * @enabled: whether or not to follow the coroutine's AioContext
50906e0f098SStefan Hajnoczi  *
51006e0f098SStefan Hajnoczi  * If @enabled is true, calls to qio_channel_yield() use the current
51106e0f098SStefan Hajnoczi  * coroutine's AioContext. Usually this is desirable.
51206e0f098SStefan Hajnoczi  *
51306e0f098SStefan Hajnoczi  * If @enabled is false, calls to qio_channel_yield() use the global iohandler
51406e0f098SStefan Hajnoczi  * AioContext. This is may be used by coroutines that run in the main loop and
51506e0f098SStefan Hajnoczi  * do not wish to respond to I/O during nested event loops. This is the
51606e0f098SStefan Hajnoczi  * default for compatibility with code that is not aware of AioContexts.
51706e0f098SStefan Hajnoczi  */
51806e0f098SStefan Hajnoczi void qio_channel_set_follow_coroutine_ctx(QIOChannel *ioc, bool enabled);
51906e0f098SStefan Hajnoczi 
52006e0f098SStefan Hajnoczi /**
521666a3af9SDaniel P. Berrange  * qio_channel_close:
522666a3af9SDaniel P. Berrange  * @ioc: the channel object
523821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
524666a3af9SDaniel P. Berrange  *
525666a3af9SDaniel P. Berrange  * Close the channel, flushing any pending I/O
526666a3af9SDaniel P. Berrange  *
527666a3af9SDaniel P. Berrange  * Returns: 0 on success, -1 on error
528666a3af9SDaniel P. Berrange  */
529666a3af9SDaniel P. Berrange int qio_channel_close(QIOChannel *ioc,
530666a3af9SDaniel P. Berrange                       Error **errp);
531666a3af9SDaniel P. Berrange 
532666a3af9SDaniel P. Berrange /**
533666a3af9SDaniel P. Berrange  * qio_channel_shutdown:
534666a3af9SDaniel P. Berrange  * @ioc: the channel object
535666a3af9SDaniel P. Berrange  * @how: the direction to shutdown
536821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
537666a3af9SDaniel P. Berrange  *
538666a3af9SDaniel P. Berrange  * Shutdowns transmission and/or receiving of data
539666a3af9SDaniel P. Berrange  * without closing the underlying transport.
540666a3af9SDaniel P. Berrange  *
541666a3af9SDaniel P. Berrange  * Not all implementations will support this facility,
542666a3af9SDaniel P. Berrange  * so may report an error. To avoid errors, the
543666a3af9SDaniel P. Berrange  * caller may check for the feature flag
544666a3af9SDaniel P. Berrange  * QIO_CHANNEL_FEATURE_SHUTDOWN prior to calling
545666a3af9SDaniel P. Berrange  * this method.
546666a3af9SDaniel P. Berrange  *
5478659f317SLukas Straub  * This function is thread-safe, terminates quickly and does not block.
5488659f317SLukas Straub  *
549666a3af9SDaniel P. Berrange  * Returns: 0 on success, -1 on error
550666a3af9SDaniel P. Berrange  */
551666a3af9SDaniel P. Berrange int qio_channel_shutdown(QIOChannel *ioc,
552666a3af9SDaniel P. Berrange                          QIOChannelShutdown how,
553666a3af9SDaniel P. Berrange                          Error **errp);
554666a3af9SDaniel P. Berrange 
555666a3af9SDaniel P. Berrange /**
556666a3af9SDaniel P. Berrange  * qio_channel_set_delay:
557666a3af9SDaniel P. Berrange  * @ioc: the channel object
558666a3af9SDaniel P. Berrange  * @enabled: the new flag state
559666a3af9SDaniel P. Berrange  *
560666a3af9SDaniel P. Berrange  * Controls whether the underlying transport is
561666a3af9SDaniel P. Berrange  * permitted to delay writes in order to merge
562666a3af9SDaniel P. Berrange  * small packets. If @enabled is true, then the
563666a3af9SDaniel P. Berrange  * writes may be delayed in order to opportunistically
564666a3af9SDaniel P. Berrange  * merge small packets into larger ones. If @enabled
565666a3af9SDaniel P. Berrange  * is false, writes are dispatched immediately with
566666a3af9SDaniel P. Berrange  * no delay.
567666a3af9SDaniel P. Berrange  *
568666a3af9SDaniel P. Berrange  * When @enabled is false, applications may wish to
569666a3af9SDaniel P. Berrange  * use the qio_channel_set_cork() method to explicitly
570666a3af9SDaniel P. Berrange  * control write merging.
571666a3af9SDaniel P. Berrange  *
572666a3af9SDaniel P. Berrange  * On channels which are backed by a socket, this
573666a3af9SDaniel P. Berrange  * API corresponds to the inverse of TCP_NODELAY flag,
574666a3af9SDaniel P. Berrange  * controlling whether the Nagle algorithm is active.
575666a3af9SDaniel P. Berrange  *
576666a3af9SDaniel P. Berrange  * This setting is merely a hint, so implementations are
577666a3af9SDaniel P. Berrange  * free to ignore this without it being considered an
578666a3af9SDaniel P. Berrange  * error.
579666a3af9SDaniel P. Berrange  */
580666a3af9SDaniel P. Berrange void qio_channel_set_delay(QIOChannel *ioc,
581666a3af9SDaniel P. Berrange                            bool enabled);
582666a3af9SDaniel P. Berrange 
583666a3af9SDaniel P. Berrange /**
584666a3af9SDaniel P. Berrange  * qio_channel_set_cork:
585666a3af9SDaniel P. Berrange  * @ioc: the channel object
586666a3af9SDaniel P. Berrange  * @enabled: the new flag state
587666a3af9SDaniel P. Berrange  *
588666a3af9SDaniel P. Berrange  * Controls whether the underlying transport is
589666a3af9SDaniel P. Berrange  * permitted to dispatch data that is written.
590666a3af9SDaniel P. Berrange  * If @enabled is true, then any data written will
591666a3af9SDaniel P. Berrange  * be queued in local buffers until @enabled is
592666a3af9SDaniel P. Berrange  * set to false once again.
593666a3af9SDaniel P. Berrange  *
594666a3af9SDaniel P. Berrange  * This feature is typically used when the automatic
595666a3af9SDaniel P. Berrange  * write coalescing facility is disabled via the
596666a3af9SDaniel P. Berrange  * qio_channel_set_delay() method.
597666a3af9SDaniel P. Berrange  *
598666a3af9SDaniel P. Berrange  * On channels which are backed by a socket, this
599666a3af9SDaniel P. Berrange  * API corresponds to the TCP_CORK flag.
600666a3af9SDaniel P. Berrange  *
601666a3af9SDaniel P. Berrange  * This setting is merely a hint, so implementations are
602666a3af9SDaniel P. Berrange  * free to ignore this without it being considered an
603666a3af9SDaniel P. Berrange  * error.
604666a3af9SDaniel P. Berrange  */
605666a3af9SDaniel P. Berrange void qio_channel_set_cork(QIOChannel *ioc,
606666a3af9SDaniel P. Berrange                           bool enabled);
607666a3af9SDaniel P. Berrange 
608666a3af9SDaniel P. Berrange 
609666a3af9SDaniel P. Berrange /**
610666a3af9SDaniel P. Berrange  * qio_channel_seek:
611666a3af9SDaniel P. Berrange  * @ioc: the channel object
612666a3af9SDaniel P. Berrange  * @offset: the position to seek to, relative to @whence
613666a3af9SDaniel P. Berrange  * @whence: one of the (POSIX) SEEK_* constants listed below
614821791b5SDaniel P. Berrange  * @errp: pointer to a NULL-initialized error object
615666a3af9SDaniel P. Berrange  *
616666a3af9SDaniel P. Berrange  * Moves the current I/O position within the channel
617666a3af9SDaniel P. Berrange  * @ioc, to be @offset. The value of @offset is
618666a3af9SDaniel P. Berrange  * interpreted relative to @whence:
619666a3af9SDaniel P. Berrange  *
620666a3af9SDaniel P. Berrange  * SEEK_SET - the position is set to @offset bytes
621666a3af9SDaniel P. Berrange  * SEEK_CUR - the position is moved by @offset bytes
622666a3af9SDaniel P. Berrange  * SEEK_END - the position is set to end of the file plus @offset bytes
623666a3af9SDaniel P. Berrange  *
624666a3af9SDaniel P. Berrange  * Not all implementations will support this facility,
625666a3af9SDaniel P. Berrange  * so may report an error.
626666a3af9SDaniel P. Berrange  *
627666a3af9SDaniel P. Berrange  * Returns: the new position on success, (off_t)-1 on failure
628666a3af9SDaniel P. Berrange  */
629666a3af9SDaniel P. Berrange off_t qio_channel_io_seek(QIOChannel *ioc,
630666a3af9SDaniel P. Berrange                           off_t offset,
631666a3af9SDaniel P. Berrange                           int whence,
632666a3af9SDaniel P. Berrange                           Error **errp);
633666a3af9SDaniel P. Berrange 
634666a3af9SDaniel P. Berrange 
635666a3af9SDaniel P. Berrange /**
636666a3af9SDaniel P. Berrange  * qio_channel_create_watch:
637666a3af9SDaniel P. Berrange  * @ioc: the channel object
638666a3af9SDaniel P. Berrange  * @condition: the I/O condition to monitor
639666a3af9SDaniel P. Berrange  *
640666a3af9SDaniel P. Berrange  * Create a new main loop source that is used to watch
641666a3af9SDaniel P. Berrange  * for the I/O condition @condition. Typically the
642666a3af9SDaniel P. Berrange  * qio_channel_add_watch() method would be used instead
643666a3af9SDaniel P. Berrange  * of this, since it directly attaches a callback to
644666a3af9SDaniel P. Berrange  * the source
645666a3af9SDaniel P. Berrange  *
646666a3af9SDaniel P. Berrange  * Returns: the new main loop source.
647666a3af9SDaniel P. Berrange  */
648666a3af9SDaniel P. Berrange GSource *qio_channel_create_watch(QIOChannel *ioc,
649666a3af9SDaniel P. Berrange                                   GIOCondition condition);
650666a3af9SDaniel P. Berrange 
651666a3af9SDaniel P. Berrange /**
652666a3af9SDaniel P. Berrange  * qio_channel_add_watch:
653666a3af9SDaniel P. Berrange  * @ioc: the channel object
654666a3af9SDaniel P. Berrange  * @condition: the I/O condition to monitor
655666a3af9SDaniel P. Berrange  * @func: callback to invoke when the source becomes ready
656666a3af9SDaniel P. Berrange  * @user_data: opaque data to pass to @func
657666a3af9SDaniel P. Berrange  * @notify: callback to free @user_data
658666a3af9SDaniel P. Berrange  *
659666a3af9SDaniel P. Berrange  * Create a new main loop source that is used to watch
660666a3af9SDaniel P. Berrange  * for the I/O condition @condition. The callback @func
661666a3af9SDaniel P. Berrange  * will be registered against the source, to be invoked
662666a3af9SDaniel P. Berrange  * when the source becomes ready. The optional @user_data
663666a3af9SDaniel P. Berrange  * will be passed to @func when it is invoked. The @notify
664666a3af9SDaniel P. Berrange  * callback will be used to free @user_data when the
665666a3af9SDaniel P. Berrange  * watch is deleted
666666a3af9SDaniel P. Berrange  *
667666a3af9SDaniel P. Berrange  * The returned source ID can be used with g_source_remove()
668666a3af9SDaniel P. Berrange  * to remove and free the source when no longer required.
669666a3af9SDaniel P. Berrange  * Alternatively the @func callback can return a FALSE
670666a3af9SDaniel P. Berrange  * value.
671666a3af9SDaniel P. Berrange  *
672666a3af9SDaniel P. Berrange  * Returns: the source ID
673666a3af9SDaniel P. Berrange  */
674666a3af9SDaniel P. Berrange guint qio_channel_add_watch(QIOChannel *ioc,
675666a3af9SDaniel P. Berrange                             GIOCondition condition,
676666a3af9SDaniel P. Berrange                             QIOChannelFunc func,
677666a3af9SDaniel P. Berrange                             gpointer user_data,
678666a3af9SDaniel P. Berrange                             GDestroyNotify notify);
679666a3af9SDaniel P. Berrange 
680315409c7SPeter Xu /**
681315409c7SPeter Xu  * qio_channel_add_watch_full:
682315409c7SPeter Xu  * @ioc: the channel object
683315409c7SPeter Xu  * @condition: the I/O condition to monitor
684315409c7SPeter Xu  * @func: callback to invoke when the source becomes ready
685315409c7SPeter Xu  * @user_data: opaque data to pass to @func
686315409c7SPeter Xu  * @notify: callback to free @user_data
687315409c7SPeter Xu  * @context: the context to run the watch source
688315409c7SPeter Xu  *
689315409c7SPeter Xu  * Similar as qio_channel_add_watch(), but allows to specify context
690315409c7SPeter Xu  * to run the watch source.
691315409c7SPeter Xu  *
692315409c7SPeter Xu  * Returns: the source ID
693315409c7SPeter Xu  */
694315409c7SPeter Xu guint qio_channel_add_watch_full(QIOChannel *ioc,
695315409c7SPeter Xu                                  GIOCondition condition,
696315409c7SPeter Xu                                  QIOChannelFunc func,
697315409c7SPeter Xu                                  gpointer user_data,
698315409c7SPeter Xu                                  GDestroyNotify notify,
699315409c7SPeter Xu                                  GMainContext *context);
700315409c7SPeter Xu 
701315409c7SPeter Xu /**
702315409c7SPeter Xu  * qio_channel_add_watch_source:
703315409c7SPeter Xu  * @ioc: the channel object
704315409c7SPeter Xu  * @condition: the I/O condition to monitor
705315409c7SPeter Xu  * @func: callback to invoke when the source becomes ready
706315409c7SPeter Xu  * @user_data: opaque data to pass to @func
707315409c7SPeter Xu  * @notify: callback to free @user_data
708315409c7SPeter Xu  * @context: gcontext to bind the source to
709315409c7SPeter Xu  *
710315409c7SPeter Xu  * Similar as qio_channel_add_watch(), but allows to specify context
711315409c7SPeter Xu  * to run the watch source, meanwhile return the GSource object
712315409c7SPeter Xu  * instead of tag ID, with the GSource referenced already.
713315409c7SPeter Xu  *
714315409c7SPeter Xu  * Note: callers is responsible to unref the source when not needed.
715315409c7SPeter Xu  *
716315409c7SPeter Xu  * Returns: the source pointer
717315409c7SPeter Xu  */
718315409c7SPeter Xu GSource *qio_channel_add_watch_source(QIOChannel *ioc,
719315409c7SPeter Xu                                       GIOCondition condition,
720315409c7SPeter Xu                                       QIOChannelFunc func,
721315409c7SPeter Xu                                       gpointer user_data,
722315409c7SPeter Xu                                       GDestroyNotify notify,
723315409c7SPeter Xu                                       GMainContext *context);
724666a3af9SDaniel P. Berrange 
725666a3af9SDaniel P. Berrange /**
726666a3af9SDaniel P. Berrange  * qio_channel_yield:
727666a3af9SDaniel P. Berrange  * @ioc: the channel object
728666a3af9SDaniel P. Berrange  * @condition: the I/O condition to wait for
729666a3af9SDaniel P. Berrange  *
730c4c497d2SPaolo Bonzini  * Yields execution from the current coroutine until the condition
731c4c497d2SPaolo Bonzini  * indicated by @condition becomes available.  @condition must
732c4c497d2SPaolo Bonzini  * be either %G_IO_IN or %G_IO_OUT; it cannot contain both.  In
733c4c497d2SPaolo Bonzini  * addition, no two coroutine can be waiting on the same condition
734c4c497d2SPaolo Bonzini  * and channel at the same time.
735666a3af9SDaniel P. Berrange  *
7366886ceafSKevin Wolf  * This must only be called from coroutine context. It is safe to
7376886ceafSKevin Wolf  * reenter the coroutine externally while it is waiting; in this
7386886ceafSKevin Wolf  * case the function will return even if @condition is not yet
7396886ceafSKevin Wolf  * available.
740666a3af9SDaniel P. Berrange  */
7416886ceafSKevin Wolf void coroutine_fn qio_channel_yield(QIOChannel *ioc,
742666a3af9SDaniel P. Berrange                                     GIOCondition condition);
743666a3af9SDaniel P. Berrange 
744666a3af9SDaniel P. Berrange /**
7457c1f51bfSKevin Wolf  * qio_channel_wake_read:
7467c1f51bfSKevin Wolf  * @ioc: the channel object
7477c1f51bfSKevin Wolf  *
7487c1f51bfSKevin Wolf  * If qio_channel_yield() is currently waiting for the channel to become
7497c1f51bfSKevin Wolf  * readable, interrupt it and reenter immediately. This function is safe to call
7507c1f51bfSKevin Wolf  * from any thread.
7517c1f51bfSKevin Wolf  */
7527c1f51bfSKevin Wolf void qio_channel_wake_read(QIOChannel *ioc);
7537c1f51bfSKevin Wolf 
7547c1f51bfSKevin Wolf /**
755666a3af9SDaniel P. Berrange  * qio_channel_wait:
756666a3af9SDaniel P. Berrange  * @ioc: the channel object
757666a3af9SDaniel P. Berrange  * @condition: the I/O condition to wait for
758666a3af9SDaniel P. Berrange  *
759666a3af9SDaniel P. Berrange  * Block execution from the current thread until
760666a3af9SDaniel P. Berrange  * the condition indicated by @condition becomes
761666a3af9SDaniel P. Berrange  * available.
762666a3af9SDaniel P. Berrange  *
763666a3af9SDaniel P. Berrange  * This will enter a nested event loop to perform
764666a3af9SDaniel P. Berrange  * the wait.
765666a3af9SDaniel P. Berrange  */
766666a3af9SDaniel P. Berrange void qio_channel_wait(QIOChannel *ioc,
767666a3af9SDaniel P. Berrange                       GIOCondition condition);
768666a3af9SDaniel P. Berrange 
769bf88c124SPaolo Bonzini /**
770bf88c124SPaolo Bonzini  * qio_channel_set_aio_fd_handler:
771bf88c124SPaolo Bonzini  * @ioc: the channel object
77206e0f098SStefan Hajnoczi  * @read_ctx: the AioContext to set the read handler on or NULL
773bf88c124SPaolo Bonzini  * @io_read: the read handler
77406e0f098SStefan Hajnoczi  * @write_ctx: the AioContext to set the write handler on or NULL
775bf88c124SPaolo Bonzini  * @io_write: the write handler
776bf88c124SPaolo Bonzini  * @opaque: the opaque value passed to the handler
777bf88c124SPaolo Bonzini  *
778bf88c124SPaolo Bonzini  * This is used internally by qio_channel_yield().  It can
779bf88c124SPaolo Bonzini  * be used by channel implementations to forward the handlers
780bf88c124SPaolo Bonzini  * to another channel (e.g. from #QIOChannelTLS to the
781bf88c124SPaolo Bonzini  * underlying socket).
78206e0f098SStefan Hajnoczi  *
78306e0f098SStefan Hajnoczi  * When @read_ctx is NULL, don't touch the read handler. When @write_ctx is
78406e0f098SStefan Hajnoczi  * NULL, don't touch the write handler. Note that setting the read handler
78506e0f098SStefan Hajnoczi  * clears the write handler, and vice versa, if they share the same AioContext.
78606e0f098SStefan Hajnoczi  * Therefore the caller must pass both handlers together when sharing the same
78706e0f098SStefan Hajnoczi  * AioContext.
788bf88c124SPaolo Bonzini  */
789bf88c124SPaolo Bonzini void qio_channel_set_aio_fd_handler(QIOChannel *ioc,
79006e0f098SStefan Hajnoczi                                     AioContext *read_ctx,
791bf88c124SPaolo Bonzini                                     IOHandler *io_read,
79206e0f098SStefan Hajnoczi                                     AioContext *write_ctx,
793bf88c124SPaolo Bonzini                                     IOHandler *io_write,
794bf88c124SPaolo Bonzini                                     void *opaque);
795bf88c124SPaolo Bonzini 
796bfa42387SElena Ufimtseva /**
797bebab91eSElena Ufimtseva  * qio_channel_readv_full_all_eof:
798bebab91eSElena Ufimtseva  * @ioc: the channel object
799bebab91eSElena Ufimtseva  * @iov: the array of memory regions to read data to
800bebab91eSElena Ufimtseva  * @niov: the length of the @iov array
801bebab91eSElena Ufimtseva  * @fds: an array of file handles to read
802bebab91eSElena Ufimtseva  * @nfds: number of file handles in @fds
803bebab91eSElena Ufimtseva  * @errp: pointer to a NULL-initialized error object
804bebab91eSElena Ufimtseva  *
805bebab91eSElena Ufimtseva  *
806bebab91eSElena Ufimtseva  * Performs same function as qio_channel_readv_all_eof.
807bebab91eSElena Ufimtseva  * Additionally, attempts to read file descriptors shared
808bebab91eSElena Ufimtseva  * over the channel. The function will wait for all
809bebab91eSElena Ufimtseva  * requested data to be read, yielding from the current
810bebab91eSElena Ufimtseva  * coroutine if required. data refers to both file
811bebab91eSElena Ufimtseva  * descriptors and the iovs.
812bebab91eSElena Ufimtseva  *
813bebab91eSElena Ufimtseva  * Returns: 1 if all bytes were read, 0 if end-of-file
814bebab91eSElena Ufimtseva  *          occurs without data, or -1 on error
815bebab91eSElena Ufimtseva  */
816bebab91eSElena Ufimtseva 
8171dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_readv_full_all_eof(QIOChannel *ioc,
818bebab91eSElena Ufimtseva                                                       const struct iovec *iov,
819bebab91eSElena Ufimtseva                                                       size_t niov,
820bebab91eSElena Ufimtseva                                                       int **fds, size_t *nfds,
821bebab91eSElena Ufimtseva                                                       Error **errp);
822bebab91eSElena Ufimtseva 
823bebab91eSElena Ufimtseva /**
824bebab91eSElena Ufimtseva  * qio_channel_readv_full_all:
825bebab91eSElena Ufimtseva  * @ioc: the channel object
826bebab91eSElena Ufimtseva  * @iov: the array of memory regions to read data to
827bebab91eSElena Ufimtseva  * @niov: the length of the @iov array
828bebab91eSElena Ufimtseva  * @fds: an array of file handles to read
829bebab91eSElena Ufimtseva  * @nfds: number of file handles in @fds
830bebab91eSElena Ufimtseva  * @errp: pointer to a NULL-initialized error object
831bebab91eSElena Ufimtseva  *
832bebab91eSElena Ufimtseva  *
833bebab91eSElena Ufimtseva  * Performs same function as qio_channel_readv_all_eof.
834bebab91eSElena Ufimtseva  * Additionally, attempts to read file descriptors shared
835bebab91eSElena Ufimtseva  * over the channel. The function will wait for all
836bebab91eSElena Ufimtseva  * requested data to be read, yielding from the current
837bebab91eSElena Ufimtseva  * coroutine if required. data refers to both file
838bebab91eSElena Ufimtseva  * descriptors and the iovs.
839bebab91eSElena Ufimtseva  *
840bebab91eSElena Ufimtseva  * Returns: 0 if all bytes were read, or -1 on error
841bebab91eSElena Ufimtseva  */
842bebab91eSElena Ufimtseva 
8431dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_readv_full_all(QIOChannel *ioc,
844bebab91eSElena Ufimtseva                                                   const struct iovec *iov,
845bebab91eSElena Ufimtseva                                                   size_t niov,
846bebab91eSElena Ufimtseva                                                   int **fds, size_t *nfds,
847bebab91eSElena Ufimtseva                                                   Error **errp);
848bebab91eSElena Ufimtseva 
849bebab91eSElena Ufimtseva /**
850bfa42387SElena Ufimtseva  * qio_channel_writev_full_all:
851bfa42387SElena Ufimtseva  * @ioc: the channel object
852bfa42387SElena Ufimtseva  * @iov: the array of memory regions to write data from
853bfa42387SElena Ufimtseva  * @niov: the length of the @iov array
854bfa42387SElena Ufimtseva  * @fds: an array of file handles to send
855bfa42387SElena Ufimtseva  * @nfds: number of file handles in @fds
856b88651cbSLeonardo Bras  * @flags: write flags (QIO_CHANNEL_WRITE_FLAG_*)
857bfa42387SElena Ufimtseva  * @errp: pointer to a NULL-initialized error object
858bfa42387SElena Ufimtseva  *
859bfa42387SElena Ufimtseva  *
860bfa42387SElena Ufimtseva  * Behaves like qio_channel_writev_full but will attempt
861bfa42387SElena Ufimtseva  * to send all data passed (file handles and memory regions).
862bfa42387SElena Ufimtseva  * The function will wait for all requested data
863bfa42387SElena Ufimtseva  * to be written, yielding from the current coroutine
864bfa42387SElena Ufimtseva  * if required.
865bfa42387SElena Ufimtseva  *
866b88651cbSLeonardo Bras  * If QIO_CHANNEL_WRITE_FLAG_ZERO_COPY is passed in flags,
867b88651cbSLeonardo Bras  * instead of waiting for all requested data to be written,
868b88651cbSLeonardo Bras  * this function will wait until it's all queued for writing.
869b88651cbSLeonardo Bras  * In this case, if the buffer gets changed between queueing and
870b88651cbSLeonardo Bras  * sending, the updated buffer will be sent. If this is not a
871b88651cbSLeonardo Bras  * desired behavior, it's suggested to call qio_channel_flush()
872b88651cbSLeonardo Bras  * before reusing the buffer.
873b88651cbSLeonardo Bras  *
874bfa42387SElena Ufimtseva  * Returns: 0 if all bytes were written, or -1 on error
875bfa42387SElena Ufimtseva  */
876bfa42387SElena Ufimtseva 
8771dd91b22SPaolo Bonzini int coroutine_mixed_fn qio_channel_writev_full_all(QIOChannel *ioc,
878bfa42387SElena Ufimtseva                                                    const struct iovec *iov,
879bfa42387SElena Ufimtseva                                                    size_t niov,
880bfa42387SElena Ufimtseva                                                    int *fds, size_t nfds,
881b88651cbSLeonardo Bras                                                    int flags, Error **errp);
882b88651cbSLeonardo Bras 
883b88651cbSLeonardo Bras /**
884b88651cbSLeonardo Bras  * qio_channel_flush:
885b88651cbSLeonardo Bras  * @ioc: the channel object
886b88651cbSLeonardo Bras  * @errp: pointer to a NULL-initialized error object
887b88651cbSLeonardo Bras  *
888b88651cbSLeonardo Bras  * Will block until every packet queued with
889b88651cbSLeonardo Bras  * qio_channel_writev_full() + QIO_CHANNEL_WRITE_FLAG_ZERO_COPY
890b88651cbSLeonardo Bras  * is sent, or return in case of any error.
891b88651cbSLeonardo Bras  *
892b88651cbSLeonardo Bras  * If not implemented, acts as a no-op, and returns 0.
893b88651cbSLeonardo Bras  *
894b88651cbSLeonardo Bras  * Returns -1 if any error is found,
895b88651cbSLeonardo Bras  *          1 if every send failed to use zero copy.
896b88651cbSLeonardo Bras  *          0 otherwise.
897b88651cbSLeonardo Bras  */
898b88651cbSLeonardo Bras 
899b88651cbSLeonardo Bras int qio_channel_flush(QIOChannel *ioc,
900bfa42387SElena Ufimtseva                       Error **errp);
901bfa42387SElena Ufimtseva 
9022a6a4076SMarkus Armbruster #endif /* QIO_CHANNEL_H */
903