block: extract include/qemu/aiocb.h out of include/block/aio.h

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>
This commit is contained in:
Paolo Bonzini
2025-12-03 12:08:25 +01:00
parent e47deb1de5
commit ddab0ef124
21 changed files with 50 additions and 31 deletions

View 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"

View 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"

View 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

View 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"

View 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"

View File

@ -27,27 +27,6 @@
#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);

View 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"

View 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"

View File

@ -24,10 +24,10 @@
#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"

View 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"

View 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

View 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;

View 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"

38
include/qemu/aiocb.h Normal file
View File

@ -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

View 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"

View 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"

View 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"

View 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"

View 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"

View 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"
/*

View 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)