vfio/container: Move space field to base container
[qemu/ar7.git] / include / block / raw-aio.h
blob0f63c2800ce09c5a2216cd9fcd76239ee46762aa
1 /*
2 * Declarations for AIO in the raw protocol
4 * Copyright IBM, Corp. 2008
6 * Authors:
7 * Anthony Liguori <aliguori@us.ibm.com>
9 * This work is licensed under the terms of the GNU GPL, version 2. See
10 * the COPYING file in the top-level directory.
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.
16 #ifndef QEMU_RAW_AIO_H
17 #define QEMU_RAW_AIO_H
19 #include "block/aio.h"
20 #include "qemu/iov.h"
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)
47 /* AIO flags */
48 #define QEMU_AIO_MISALIGNED 0x1000
49 #define QEMU_AIO_BLKDEV 0x2000
50 #define QEMU_AIO_NO_FALLBACK 0x4000
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);
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);
63 void laio_detach_aio_context(LinuxAioState *s, AioContext *old_context);
64 void laio_attach_aio_context(LinuxAioState *s, AioContext *new_context);
65 #endif
66 /* io_uring.c - Linux io_uring implementation */
67 #ifdef CONFIG_LINUX_IO_URING
68 typedef struct LuringState LuringState;
69 LuringState *luring_init(Error **errp);
70 void luring_cleanup(LuringState *s);
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
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
94 #endif /* QEMU_RAW_AIO_H */