xref: /openbmc/qemu/include/block/raw-aio.h (revision 36c1febe3f34ae38db375865b7841165d76cdae4)
1 /*
2  * Declarations for AIO in the raw protocol
3  *
4  * Copyright IBM, Corp. 2008
5  *
6  * Authors:
7  *  Anthony Liguori   <aliguori@us.ibm.com>
8  *
9  * This work is licensed under the terms of the GNU GPL, version 2.  See
10  * the COPYING file in the top-level directory.
11  *
12  * Contributions after 2012-01-13 are licensed under the terms of the
13  * GNU GPL, version 2 or (at your option) any later version.
14  */
15 
16 #ifndef QEMU_RAW_AIO_H
17 #define QEMU_RAW_AIO_H
18 
19 #include "block/aio.h"
20 #include "qemu/iov.h"
21 
22 /* AIO request types */
23 #define QEMU_AIO_READ         0x0001
24 #define QEMU_AIO_WRITE        0x0002
25 #define QEMU_AIO_IOCTL        0x0004
26 #define QEMU_AIO_FLUSH        0x0008
27 #define QEMU_AIO_DISCARD      0x0010
28 #define QEMU_AIO_WRITE_ZEROES 0x0020
29 #define QEMU_AIO_COPY_RANGE   0x0040
30 #define QEMU_AIO_TRUNCATE     0x0080
31 #define QEMU_AIO_ZONE_REPORT  0x0100
32 #define QEMU_AIO_ZONE_MGMT    0x0200
33 #define QEMU_AIO_ZONE_APPEND  0x0400
34 #define QEMU_AIO_TYPE_MASK \
35         (QEMU_AIO_READ | \
36          QEMU_AIO_WRITE | \
37          QEMU_AIO_IOCTL | \
38          QEMU_AIO_FLUSH | \
39          QEMU_AIO_DISCARD | \
40          QEMU_AIO_WRITE_ZEROES | \
41          QEMU_AIO_COPY_RANGE | \
42          QEMU_AIO_TRUNCATE | \
43          QEMU_AIO_ZONE_REPORT | \
44          QEMU_AIO_ZONE_MGMT | \
45          QEMU_AIO_ZONE_APPEND)
46 
47 /* AIO flags */
48 #define QEMU_AIO_MISALIGNED   0x1000
49 #define QEMU_AIO_BLKDEV       0x2000
50 #define QEMU_AIO_NO_FALLBACK  0x4000
51 
52 
53 /* linux-aio.c - Linux native implementation */
54 #ifdef CONFIG_LINUX_AIO
55 typedef struct LinuxAioState LinuxAioState;
56 LinuxAioState *laio_init(Error **errp);
57 void laio_cleanup(LinuxAioState *s);
58 
59 /* laio_co_submit: submit I/O requests in the thread's current AioContext. */
60 int coroutine_fn laio_co_submit(int fd, uint64_t offset, QEMUIOVector *qiov,
61                                 int type, uint64_t dev_max_batch);
62 
63 bool laio_has_fdsync(int);
64 void laio_detach_aio_context(LinuxAioState *s, AioContext *old_context);
65 void laio_attach_aio_context(LinuxAioState *s, AioContext *new_context);
66 #endif
67 /* io_uring.c - Linux io_uring implementation */
68 #ifdef CONFIG_LINUX_IO_URING
69 LuringState *luring_init(Error **errp);
70 void luring_cleanup(LuringState *s);
71 
72 /* luring_co_submit: submit I/O requests in the thread's current AioContext. */
73 int coroutine_fn luring_co_submit(BlockDriverState *bs, int fd, uint64_t offset,
74                                   QEMUIOVector *qiov, int type);
75 void luring_detach_aio_context(LuringState *s, AioContext *old_context);
76 void luring_attach_aio_context(LuringState *s, AioContext *new_context);
77 #endif
78 
79 #ifdef _WIN32
80 typedef struct QEMUWin32AIOState QEMUWin32AIOState;
81 QEMUWin32AIOState *win32_aio_init(void);
82 void win32_aio_cleanup(QEMUWin32AIOState *aio);
83 int win32_aio_attach(QEMUWin32AIOState *aio, HANDLE hfile);
84 BlockAIOCB *win32_aio_submit(BlockDriverState *bs,
85         QEMUWin32AIOState *aio, HANDLE hfile,
86         uint64_t offset, uint64_t bytes, QEMUIOVector *qiov,
87         BlockCompletionFunc *cb, void *opaque, int type);
88 void win32_aio_detach_aio_context(QEMUWin32AIOState *aio,
89                                   AioContext *old_context);
90 void win32_aio_attach_aio_context(QEMUWin32AIOState *aio,
91                                   AioContext *new_context);
92 #endif
93 
94 #endif /* QEMU_RAW_AIO_H */
95