]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
block: extract include/qemu/aiocb.h out of include/block/aio.h
authorPaolo Bonzini <pbonzini@redhat.com>
Wed, 3 Dec 2025 11:08:25 +0000 (12:08 +0100)
committerPaolo Bonzini <pbonzini@redhat.com>
Sat, 27 Dec 2025 09:11:12 +0000 (10:11 +0100)
Create a new header corresponding to functions defined in
util/aiocb.c, and include it whenever AIOCBs are used but
AioContext is not.

Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
21 files changed:
block/win32-aio.c
fsdev/qemu-fsdev-throttle.h
hw/core/ptimer.c
hw/misc/i2c-echo.c
hw/virtio/virtio-pmem.c
include/block/aio.h
include/block/block-global-state.h
include/block/block-io.h
include/block/block_int-common.h
include/block/raw-aio.h
include/block/thread-pool.h
include/hw/ide/ide-dma.h
include/hw/scsi/scsi.h
include/qemu/aiocb.h [new file with mode: 0644]
include/qemu/job.h
include/qemu/throttle.h
scsi/qemu-pr-helper.c
tests/unit/test-thread-pool.c
ui/input-linux.c
ui/vnc-jobs.c
util/aiocb.c

index f0689f3ee95fd5028e803ba72346c9c8e1d9d3fd..539f1c81c657074e1a336074b7b62fe3931ac4cb 100644 (file)
@@ -28,6 +28,7 @@
 #include "block/block_int.h"
 #include "block/aio.h"
 #include "block/raw-aio.h"
+#include "qemu/aiocb.h"
 #include "qemu/event_notifier.h"
 #include "qemu/iov.h"
 #include "qemu/memalign.h"
index daa8ca2494d866debea345ebcae8433fb0dd1317..a1dc03079031918cd11f92ce9ba1d82a29ddf21f 100644 (file)
@@ -15,7 +15,6 @@
 #ifndef QEMU_FSDEV_THROTTLE_H
 #define QEMU_FSDEV_THROTTLE_H
 
-#include "block/aio.h"
 #include "qemu/coroutine.h"
 #include "qemu/throttle.h"
 
index e42e06fa4de6e3a9677967450c75e62a52b533f4..0cbe1ed5787cd4b1652e8d96e490be09d2c9097a 100644 (file)
@@ -13,7 +13,6 @@
 #include "exec/replay-core.h"
 #include "exec/icount.h"
 #include "system/qtest.h"
-#include "block/aio.h"
 #include "hw/core/clock.h"
 
 #define DELTA_ADJUST     1
index 2bb99ec0dbfd9677d5396161c99658136f5d7656..54d07db6fae5d47b598ed5efee58d492bf21e636 100644 (file)
@@ -11,7 +11,6 @@
 #include "qemu/osdep.h"
 #include "qemu/timer.h"
 #include "qemu/main-loop.h"
-#include "block/aio.h"
 #include "hw/i2c/i2c.h"
 #include "trace.h"
 
index 854d08abf6e0db3ba90e6adc8cb7951bbcdfa4cd..5381d592824a29fb1370f19ddc737828a4e60f8f 100644 (file)
@@ -22,7 +22,6 @@
 #include "standard-headers/linux/virtio_ids.h"
 #include "standard-headers/linux/virtio_pmem.h"
 #include "system/hostmem.h"
-#include "block/aio.h"
 #include "block/thread-pool.h"
 #include "trace.h"
 
index cc3d5f25a2416bee6e42cd4121bb2a4efa4e10db..59c56d695ee2d63f76580f4ab8b4b53f6041d3ba 100644 (file)
 #include "hw/core/qdev.h"
 
 
-typedef struct BlockAIOCB BlockAIOCB;
-typedef void BlockCompletionFunc(void *opaque, int ret);
-
-typedef struct AIOCBInfo {
-    void (*cancel_async)(BlockAIOCB *acb);
-    size_t aiocb_size;
-} AIOCBInfo;
-
-struct BlockAIOCB {
-    const AIOCBInfo *aiocb_info;
-    BlockDriverState *bs;
-    BlockCompletionFunc *cb;
-    void *opaque;
-    int refcnt;
-};
-
-void *qemu_aio_get(const AIOCBInfo *aiocb_info, BlockDriverState *bs,
-                   BlockCompletionFunc *cb, void *opaque);
-void qemu_aio_unref(void *p);
-void qemu_aio_ref(void *p);
-
 typedef struct AioHandler AioHandler;
 typedef QLIST_HEAD(, AioHandler) AioHandlerList;
 typedef void QEMUBHFunc(void *opaque);
index 479ca2858e107a5dac95f8cd07742b7a525f3d30..c2127f17249e2dc357bd4d6a421f15b727308cb5 100644 (file)
@@ -24,6 +24,7 @@
 #ifndef BLOCK_GLOBAL_STATE_H
 #define BLOCK_GLOBAL_STATE_H
 
+#include "qemu/aiocb.h"
 #include "block/block-common.h"
 #include "qemu/coroutine.h"
 #include "qemu/transactions.h"
index 4cf83fb3674bd273e12e6e078902c84b657cebc7..e5efe0efb2fcfe681d650fc028ce5b5a86af8deb 100644 (file)
@@ -24,6 +24,7 @@
 #ifndef BLOCK_IO_H
 #define BLOCK_IO_H
 
+#include "qemu/aiocb.h"
 #include "block/aio-wait.h"
 #include "block/block-common.h"
 #include "qemu/coroutine.h"
index cb0143ea77b8f6c8b1ac8bcb7a71abfa0c78c56e..6d0898e53d1f293c52035c7a911b5dbbf8d046c3 100644 (file)
 #ifndef BLOCK_INT_COMMON_H
 #define BLOCK_INT_COMMON_H
 
-#include "block/aio.h"
 #include "block/block-common.h"
 #include "block/block-global-state.h"
 #include "block/snapshot.h"
+#include "qemu/aiocb.h"
 #include "qemu/iov.h"
 #include "qemu/rcu.h"
 #include "qemu/stats64.h"
index 30e5fc9a9fdad1b39c7948bef89abb9f23e8667c..d568b887f1cb65662c042ecebe796e7a30fcc2ac 100644 (file)
@@ -16,6 +16,7 @@
 #ifndef QEMU_RAW_AIO_H
 #define QEMU_RAW_AIO_H
 
+#include "qemu/aiocb.h"
 #include "block/aio.h"
 #include "block/block-common.h"
 #include "qemu/iov.h"
index dd48cf07e85f886e9efc44916e4018141f352233..65cabfc13886868bc10b825e14bc9046dc194805 100644 (file)
@@ -18,6 +18,7 @@
 #ifndef QEMU_THREAD_POOL_H
 #define QEMU_THREAD_POOL_H
 
+#include "qemu/aiocb.h"
 #include "block/aio.h"
 
 #define THREAD_POOL_MAX_THREADS_DEFAULT         64
index d0b19ac9c57454e553047713beae36f16b6c7bf8..296010a4e0dea70d1629c3fa3e8b1d7378b7ee5d 100644 (file)
@@ -1,7 +1,7 @@
 #ifndef HW_IDE_DMA_H
 #define HW_IDE_DMA_H
 
-#include "block/aio.h"
+#include "qemu/aiocb.h"
 #include "qemu/iov.h"
 
 typedef struct IDEState IDEState;
index 83782339d4bd98121e77a173c7bc2978b26a351a..75b4d781a5cf319599a4a1cc92a55d6313cc8ae4 100644 (file)
@@ -1,6 +1,7 @@
 #ifndef QEMU_HW_SCSI_H
 #define QEMU_HW_SCSI_H
 
+#include "qemu/aiocb.h"
 #include "block/aio.h"
 #include "hw/block/block.h"
 #include "hw/core/qdev.h"
diff --git a/include/qemu/aiocb.h b/include/qemu/aiocb.h
new file mode 100644 (file)
index 0000000..0622646
--- /dev/null
@@ -0,0 +1,38 @@
+/*
+ * Data structures representing asynchronous I/O operations
+ *
+ * Copyright IBM, Corp. 2008
+ *
+ * Authors:
+ *  Anthony Liguori   <aliguori@us.ibm.com>
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2.  See
+ * the COPYING file in the top-level directory.
+ *
+ */
+
+#ifndef QEMU_AIOCB_H
+#define QEMU_AIOCB_H
+
+typedef struct BlockAIOCB BlockAIOCB;
+typedef void BlockCompletionFunc(void *opaque, int ret);
+
+typedef struct AIOCBInfo {
+    void (*cancel_async)(BlockAIOCB *acb);
+    size_t aiocb_size;
+} AIOCBInfo;
+
+struct BlockAIOCB {
+    const AIOCBInfo *aiocb_info;
+    BlockDriverState *bs;
+    BlockCompletionFunc *cb;
+    void *opaque;
+    int refcnt;
+};
+
+void *qemu_aio_get(const AIOCBInfo *aiocb_info, BlockDriverState *bs,
+                   BlockCompletionFunc *cb, void *opaque);
+void qemu_aio_unref(void *p);
+void qemu_aio_ref(void *p);
+
+#endif
index ead31578d3d599cdbebad0c456cfc6d600516c9b..af29b8c65310a181438edaa972678e523dfc6ab6 100644 (file)
@@ -27,6 +27,7 @@
 #define JOB_H
 
 #include "qapi/qapi-types-job.h"
+#include "qemu/aiocb.h"
 #include "qemu/queue.h"
 #include "qemu/progress_meter.h"
 #include "qemu/coroutine.h"
index 181245d29bc4193d8d87a9429e45d129efd12320..8fa2b29452a2b1cf8cafd55c0cb08f051e8e72ee 100644 (file)
@@ -25,6 +25,7 @@
 #ifndef THROTTLE_H
 #define THROTTLE_H
 
+#include "block/aio.h"
 #include "qapi/qapi-types-block-core.h"
 #include "qemu/timer.h"
 
index 074b4db472076ae11a57dee34e41d28601b0e411..9dcd3ec7111e014b7dd8ee2b4511de2f8e0b5f7d 100644 (file)
@@ -52,7 +52,6 @@
 #include "trace/control.h"
 #include "qemu-version.h"
 
-#include "block/aio.h"
 #include "block/thread-pool.h"
 
 #include "scsi/constants.h"
index 33407b595d3565614c631a58759bc55be1bcfac3..ea5234f9f48b157d3d08a5ff3bf1fce8ca113b85 100644 (file)
@@ -3,6 +3,7 @@
 #include "block/thread-pool.h"
 #include "block/block.h"
 #include "qapi/error.h"
+#include "qemu/aiocb.h"
 #include "qemu/timer.h"
 #include "qemu/error-report.h"
 #include "qemu/main-loop.h"
index 44d0c15a9b724c32b67b721db1934bd1518f33d9..c16726a3b799131adda6ff5bc49fa0741f4efcb8 100644 (file)
@@ -13,7 +13,6 @@
 #include "ui/input.h"
 #include "qom/object_interfaces.h"
 #include "system/iothread.h"
-#include "block/aio.h"
 
 #include <sys/ioctl.h>
 #include "standard-headers/linux/input.h"
index bed33950a8791e7915f3396933b0ed1d474b1575..b296d19e089619e9b5cb2868a1e833671a8789b6 100644 (file)
@@ -31,7 +31,6 @@
 #include "vnc-jobs.h"
 #include "qemu/sockets.h"
 #include "qemu/main-loop.h"
-#include "block/aio.h"
 #include "trace.h"
 
 /*
index 5aef3a069c8e79b655ddd4a29f1b0a81acc3baa3..d1a581080d37d8c9b00a2393d37f2398037ed95b 100644 (file)
@@ -23,7 +23,7 @@
  */
 
 #include "qemu/osdep.h"
-#include "block/aio.h"
+#include "qemu/aiocb.h"
 
 void *qemu_aio_get(const AIOCBInfo *aiocb_info, BlockDriverState *bs,
                    BlockCompletionFunc *cb, void *opaque)