mirror of
https://github.com/qemu/qemu.git
synced 2024-11-24 11:23:43 +08:00
c16b5a2ca0
Now that we have a separate aio pool structure we can remove those aio pool details from BlockDriver. Every driver supporting AIO now needs to declare a static AIOPool with the aiocb size and the cancellation method. This cleans up the current code considerably and will make it cleaner and more obvious to support two different aio implementations behind a single BlockDriver. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
42 lines
1.1 KiB
C
42 lines
1.1 KiB
C
/*
|
|
* DMA helper functions
|
|
*
|
|
* Copyright (c) 2009 Red Hat
|
|
*
|
|
* This work is licensed under the terms of the GNU General Public License
|
|
* (GNU GPL), version 2 or later.
|
|
*/
|
|
|
|
#ifndef DMA_H
|
|
#define DMA_H
|
|
|
|
#include <stdio.h>
|
|
//#include "cpu.h"
|
|
#include "hw/hw.h"
|
|
#include "block.h"
|
|
|
|
typedef struct {
|
|
target_phys_addr_t base;
|
|
target_phys_addr_t len;
|
|
} ScatterGatherEntry;
|
|
|
|
typedef struct {
|
|
ScatterGatherEntry *sg;
|
|
int nsg;
|
|
int nalloc;
|
|
target_phys_addr_t size;
|
|
} QEMUSGList;
|
|
|
|
void qemu_sglist_init(QEMUSGList *qsg, int alloc_hint);
|
|
void qemu_sglist_add(QEMUSGList *qsg, target_phys_addr_t base,
|
|
target_phys_addr_t len);
|
|
void qemu_sglist_destroy(QEMUSGList *qsg);
|
|
|
|
BlockDriverAIOCB *dma_bdrv_read(BlockDriverState *bs,
|
|
QEMUSGList *sg, uint64_t sector,
|
|
BlockDriverCompletionFunc *cb, void *opaque);
|
|
BlockDriverAIOCB *dma_bdrv_write(BlockDriverState *bs,
|
|
QEMUSGList *sg, uint64_t sector,
|
|
BlockDriverCompletionFunc *cb, void *opaque);
|
|
#endif
|