19f532d00SPekka Enberg #ifndef KVM__DISK_IMAGE_H 29f532d00SPekka Enberg #define KVM__DISK_IMAGE_H 39f532d00SPekka Enberg 4c9310ac4SAsias He #include "kvm/read-write.h" 5c9310ac4SAsias He #include "kvm/util.h" 63b55dcdeSSasha Levin #include "kvm/parse-options.h" 7c9310ac4SAsias He 83fdf659dSSasha Levin #include <linux/types.h> 9c9310ac4SAsias He #include <linux/fs.h> /* for BLKGETSIZE64 */ 10c9310ac4SAsias He #include <sys/ioctl.h> 11c9310ac4SAsias He #include <sys/types.h> 12c9310ac4SAsias He #include <sys/mman.h> 13c9310ac4SAsias He #include <sys/stat.h> 149ac38fe1SSasha Levin #include <stdbool.h> 1570b53f25SSasha Levin #include <sys/uio.h> 16c9310ac4SAsias He #include <stdbool.h> 17c9310ac4SAsias He #include <stddef.h> 18c9310ac4SAsias He #include <stdlib.h> 1929084a74SPrasad Joshi #include <unistd.h> 20c9310ac4SAsias He #include <fcntl.h> 219f532d00SPekka Enberg 2230a9aa69SJean-Philippe Brucker #ifdef CONFIG_HAS_AIO 2330a9aa69SJean-Philippe Brucker #include <libaio.h> 2430a9aa69SJean-Philippe Brucker #endif 2530a9aa69SJean-Philippe Brucker 262924f993SAsias He #define SECTOR_SHIFT 9 272924f993SAsias He #define SECTOR_SIZE (1UL << SECTOR_SHIFT) 282924f993SAsias He 2938c396e4SSasha Levin enum { 3038c396e4SSasha Levin DISK_IMAGE_REGULAR, 3138c396e4SSasha Levin DISK_IMAGE_MMAP, 3238c396e4SSasha Levin }; 3338c396e4SSasha Levin 34c1ed214eSPrasad Joshi #define MAX_DISK_IMAGES 4 357d22135fSAsias He 36499f3bedSPekka Enberg struct disk_image; 37499f3bedSPekka Enberg 38499f3bedSPekka Enberg struct disk_image_operations { 39dcd3cd8eSAsias He ssize_t (*read)(struct disk_image *disk, u64 sector, const struct iovec *iov, 405af21162SSasha Levin int iovcount, void *param); 41dcd3cd8eSAsias He ssize_t (*write)(struct disk_image *disk, u64 sector, const struct iovec *iov, 425af21162SSasha Levin int iovcount, void *param); 4329084a74SPrasad Joshi int (*flush)(struct disk_image *disk); 442790307cSJean-Philippe Brucker int (*wait)(struct disk_image *disk); 4572133dd2SAsias He int (*close)(struct disk_image *disk); 46d62e8ee0SJean-Philippe Brucker bool async; 47499f3bedSPekka Enberg }; 48499f3bedSPekka Enberg 4997f16d66SAsias He struct disk_image_params { 5097f16d66SAsias He const char *filename; 51a67da3beSAsias He /* 52a67da3beSAsias He * wwpn == World Wide Port Number 53a67da3beSAsias He * tpgt == Target Portal Group Tag 54a67da3beSAsias He */ 55a67da3beSAsias He const char *wwpn; 56a67da3beSAsias He const char *tpgt; 5797f16d66SAsias He bool readonly; 585236b505SAsias He bool direct; 5997f16d66SAsias He }; 6097f16d66SAsias He 619f532d00SPekka Enberg struct disk_image { 629f532d00SPekka Enberg int fd; 633fdf659dSSasha Levin u64 size; 64499f3bedSPekka Enberg struct disk_image_operations *ops; 65499f3bedSPekka Enberg void *priv; 665af21162SSasha Levin void *disk_req_cb_param; 678b52f877SSasha Levin void (*disk_req_cb)(void *param, long len); 685c5cae75SJean-Philippe Brucker bool readonly; 69f41a132bSSasha Levin bool async; 70f41a132bSSasha Levin #ifdef CONFIG_HAS_AIO 71f41a132bSSasha Levin io_context_t ctx; 7230a9aa69SJean-Philippe Brucker int evt; 73a839180eSJean-Philippe Brucker pthread_t thread; 742790307cSJean-Philippe Brucker u64 aio_inflight; 7530a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */ 76a67da3beSAsias He const char *wwpn; 77a67da3beSAsias He const char *tpgt; 783b55dcdeSSasha Levin int debug_iodelay; 799f532d00SPekka Enberg }; 809f532d00SPekka Enberg 813b55dcdeSSasha Levin int disk_img_name_parser(const struct option *opt, const char *arg, int unset); 823b55dcdeSSasha Levin int disk_image__init(struct kvm *kvm); 833b55dcdeSSasha Levin int disk_image__exit(struct kvm *kvm); 847d22135fSAsias He struct disk_image *disk_image__new(int fd, u64 size, struct disk_image_operations *ops, int mmap); 85fda63751SAsias He int disk_image__flush(struct disk_image *disk); 862790307cSJean-Philippe Brucker int disk_image__wait(struct disk_image *disk); 875af21162SSasha Levin ssize_t disk_image__read(struct disk_image *disk, u64 sector, const struct iovec *iov, 885af21162SSasha Levin int iovcount, void *param); 895af21162SSasha Levin ssize_t disk_image__write(struct disk_image *disk, u64 sector, const struct iovec *iov, 905af21162SSasha Levin int iovcount, void *param); 91*48427891SJean-Philippe Brucker ssize_t disk_image__get_serial(struct disk_image *disk, struct iovec *iov, 92*48427891SJean-Philippe Brucker int iovcount, ssize_t len); 9370b53f25SSasha Levin 94c9310ac4SAsias He struct disk_image *raw_image__probe(int fd, struct stat *st, bool readonly); 955236b505SAsias He struct disk_image *blkdev__probe(const char *filename, int flags, struct stat *st); 96c9310ac4SAsias He 9730a9aa69SJean-Philippe Brucker ssize_t raw_image__read_sync(struct disk_image *disk, u64 sector, 985af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 9930a9aa69SJean-Philippe Brucker ssize_t raw_image__write_sync(struct disk_image *disk, u64 sector, 1005af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 101dcd3cd8eSAsias He ssize_t raw_image__read_mmap(struct disk_image *disk, u64 sector, 1025af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 103dcd3cd8eSAsias He ssize_t raw_image__write_mmap(struct disk_image *disk, u64 sector, 1045af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 10587ee33c8SAsias He int raw_image__close(struct disk_image *disk); 1068b52f877SSasha Levin void disk_image__set_callback(struct disk_image *disk, void (*disk_req_cb)(void *param, long len)); 10730a9aa69SJean-Philippe Brucker 10830a9aa69SJean-Philippe Brucker #ifdef CONFIG_HAS_AIO 10930a9aa69SJean-Philippe Brucker int disk_aio_setup(struct disk_image *disk); 11030a9aa69SJean-Philippe Brucker void disk_aio_destroy(struct disk_image *disk); 11130a9aa69SJean-Philippe Brucker ssize_t raw_image__read_async(struct disk_image *disk, u64 sector, 11230a9aa69SJean-Philippe Brucker const struct iovec *iov, int iovcount, void *param); 11330a9aa69SJean-Philippe Brucker ssize_t raw_image__write_async(struct disk_image *disk, u64 sector, 11430a9aa69SJean-Philippe Brucker const struct iovec *iov, int iovcount, void *param); 1152790307cSJean-Philippe Brucker int raw_image__wait(struct disk_image *disk); 11630a9aa69SJean-Philippe Brucker 11730a9aa69SJean-Philippe Brucker #define raw_image__read raw_image__read_async 11830a9aa69SJean-Philippe Brucker #define raw_image__write raw_image__write_async 11930a9aa69SJean-Philippe Brucker 12030a9aa69SJean-Philippe Brucker #else /* !CONFIG_HAS_AIO */ 12130a9aa69SJean-Philippe Brucker static inline int disk_aio_setup(struct disk_image *disk) 12230a9aa69SJean-Philippe Brucker { 12330a9aa69SJean-Philippe Brucker /* No-op */ 12430a9aa69SJean-Philippe Brucker return 0; 12530a9aa69SJean-Philippe Brucker } 12630a9aa69SJean-Philippe Brucker static inline void disk_aio_destroy(struct disk_image *disk) 12730a9aa69SJean-Philippe Brucker { 12830a9aa69SJean-Philippe Brucker } 1292790307cSJean-Philippe Brucker 1302790307cSJean-Philippe Brucker static inline int raw_image__wait(struct disk_image *disk) 1312790307cSJean-Philippe Brucker { 1322790307cSJean-Philippe Brucker return 0; 1332790307cSJean-Philippe Brucker } 13430a9aa69SJean-Philippe Brucker #define raw_image__read raw_image__read_sync 13530a9aa69SJean-Philippe Brucker #define raw_image__write raw_image__write_sync 13630a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */ 13730a9aa69SJean-Philippe Brucker 1389f532d00SPekka Enberg #endif /* KVM__DISK_IMAGE_H */ 139