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 void laio_detach_aio_context(LinuxAioState *s, AioContext *old_context); 64 void laio_attach_aio_context(LinuxAioState *s, AioContext *new_context); 65 66 /* 67 * laio_io_plug/unplug work in the thread's current AioContext, therefore the 68 * caller must ensure that they are paired in the same IOThread. 69 */ 70 void laio_io_plug(void); 71 void laio_io_unplug(uint64_t dev_max_batch); 72 #endif 73 /* io_uring.c - Linux io_uring implementation */ 74 #ifdef CONFIG_LINUX_IO_URING 75 typedef struct LuringState LuringState; 76 LuringState *luring_init(Error **errp); 77 void luring_cleanup(LuringState *s); 78 79 /* luring_co_submit: submit I/O requests in the thread's current AioContext. */ 80 int coroutine_fn luring_co_submit(BlockDriverState *bs, int fd, uint64_t offset, 81 QEMUIOVector *qiov, int type); 82 void luring_detach_aio_context(LuringState *s, AioContext *old_context); 83 void luring_attach_aio_context(LuringState *s, AioContext *new_context); 84 85 /* 86 * luring_io_plug/unplug work in the thread's current AioContext, therefore the 87 * caller must ensure that they are paired in the same IOThread. 88 */ 89 void luring_io_plug(void); 90 void luring_io_unplug(void); 91 #endif 92 93 #ifdef _WIN32 94 typedef struct QEMUWin32AIOState QEMUWin32AIOState; 95 QEMUWin32AIOState *win32_aio_init(void); 96 void win32_aio_cleanup(QEMUWin32AIOState *aio); 97 int win32_aio_attach(QEMUWin32AIOState *aio, HANDLE hfile); 98 BlockAIOCB *win32_aio_submit(BlockDriverState *bs, 99 QEMUWin32AIOState *aio, HANDLE hfile, 100 uint64_t offset, uint64_t bytes, QEMUIOVector *qiov, 101 BlockCompletionFunc *cb, void *opaque, int type); 102 void win32_aio_detach_aio_context(QEMUWin32AIOState *aio, 103 AioContext *old_context); 104 void win32_aio_attach_aio_context(QEMUWin32AIOState *aio, 105 AioContext *new_context); 106 #endif 107 108 #endif /* QEMU_RAW_AIO_H */ 109