#ifndef KVM__DISK_IMAGE_H #define KVM__DISK_IMAGE_H #include "kvm/read-write.h" #include "kvm/util.h" #include "kvm/parse-options.h" #include #include /* for BLKGETSIZE64 */ #include #include #include #include #include #include #include #include #include #include #include #ifdef CONFIG_HAS_AIO #include #endif #define SECTOR_SHIFT 9 #define SECTOR_SIZE (1UL << SECTOR_SHIFT) enum { DISK_IMAGE_REGULAR, DISK_IMAGE_MMAP, }; #define MAX_DISK_IMAGES 4 struct disk_image; struct disk_image_operations { ssize_t (*read)(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); ssize_t (*write)(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); int (*flush)(struct disk_image *disk); int (*wait)(struct disk_image *disk); int (*close)(struct disk_image *disk); bool async; }; struct disk_image_params { const char *filename; /* wwpn == World Wide Port Number */ const char *wwpn; bool readonly; bool direct; }; struct disk_image { int fd; u64 size; struct disk_image_operations *ops; void *priv; void *disk_req_cb_param; void (*disk_req_cb)(void *param, long len); bool readonly; bool async; #ifdef CONFIG_HAS_AIO io_context_t ctx; int evt; pthread_t thread; u64 aio_inflight; #endif /* CONFIG_HAS_AIO */ const char *wwpn; int debug_iodelay; }; int disk_img_name_parser(const struct option *opt, const char *arg, int unset); int disk_image__init(struct kvm *kvm); int disk_image__exit(struct kvm *kvm); struct disk_image *disk_image__new(int fd, u64 size, struct disk_image_operations *ops, int mmap); int disk_image__flush(struct disk_image *disk); int disk_image__wait(struct disk_image *disk); ssize_t disk_image__read(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); ssize_t disk_image__write(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); ssize_t disk_image__get_serial(struct disk_image *disk, struct iovec *iov, int iovcount, ssize_t len); struct disk_image *raw_image__probe(int fd, struct stat *st, bool readonly); struct disk_image *blkdev__probe(const char *filename, int flags, struct stat *st); ssize_t raw_image__read_sync(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); ssize_t raw_image__write_sync(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); ssize_t raw_image__read_mmap(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); ssize_t raw_image__write_mmap(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); int raw_image__close(struct disk_image *disk); void disk_image__set_callback(struct disk_image *disk, void (*disk_req_cb)(void *param, long len)); #ifdef CONFIG_HAS_AIO int disk_aio_setup(struct disk_image *disk); void disk_aio_destroy(struct disk_image *disk); ssize_t raw_image__read_async(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); ssize_t raw_image__write_async(struct disk_image *disk, u64 sector, const struct iovec *iov, int iovcount, void *param); int raw_image__wait(struct disk_image *disk); #define raw_image__read raw_image__read_async #define raw_image__write raw_image__write_async #else /* !CONFIG_HAS_AIO */ static inline int disk_aio_setup(struct disk_image *disk) { /* No-op */ return 0; } static inline void disk_aio_destroy(struct disk_image *disk) { } static inline int raw_image__wait(struct disk_image *disk) { return 0; } #define raw_image__read raw_image__read_sync #define raw_image__write raw_image__write_sync #endif /* CONFIG_HAS_AIO */ #endif /* KVM__DISK_IMAGE_H */