mirror of
https://github.com/qemu/qemu.git
synced 2026-01-14 03:01:08 +00:00
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:
@ -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"
|
||||
|
||||
@ -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"
|
||||
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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"
|
||||
|
||||
|
||||
@ -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"
|
||||
|
||||
|
||||
@ -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);
|
||||
|
||||
@ -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"
|
||||
|
||||
@ -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"
|
||||
|
||||
@ -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"
|
||||
|
||||
@ -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"
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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;
|
||||
|
||||
@ -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
38
include/qemu/aiocb.h
Normal 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
|
||||
@ -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"
|
||||
|
||||
@ -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"
|
||||
|
||||
|
||||
@ -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"
|
||||
|
||||
@ -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"
|
||||
|
||||
@ -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"
|
||||
|
||||
@ -31,7 +31,6 @@
|
||||
#include "vnc-jobs.h"
|
||||
#include "qemu/sockets.h"
|
||||
#include "qemu/main-loop.h"
|
||||
#include "block/aio.h"
|
||||
#include "trace.h"
|
||||
|
||||
/*
|
||||
|
||||
@ -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)
|
||||
|
||||
Reference in New Issue
Block a user