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); 4472133dd2SAsias He int (*close)(struct disk_image *disk); 45d62e8ee0SJean-Philippe Brucker bool async; 46499f3bedSPekka Enberg }; 47499f3bedSPekka Enberg 4897f16d66SAsias He struct disk_image_params { 4997f16d66SAsias He const char *filename; 50a67da3beSAsias He /* 51a67da3beSAsias He * wwpn == World Wide Port Number 52a67da3beSAsias He * tpgt == Target Portal Group Tag 53a67da3beSAsias He */ 54a67da3beSAsias He const char *wwpn; 55a67da3beSAsias He const char *tpgt; 5697f16d66SAsias He bool readonly; 575236b505SAsias He bool direct; 5897f16d66SAsias He }; 5997f16d66SAsias He 609f532d00SPekka Enberg struct disk_image { 619f532d00SPekka Enberg int fd; 623fdf659dSSasha Levin u64 size; 63499f3bedSPekka Enberg struct disk_image_operations *ops; 64499f3bedSPekka Enberg void *priv; 655af21162SSasha Levin void *disk_req_cb_param; 668b52f877SSasha Levin void (*disk_req_cb)(void *param, long len); 675c5cae75SJean-Philippe Brucker bool readonly; 68f41a132bSSasha Levin bool async; 69f41a132bSSasha Levin #ifdef CONFIG_HAS_AIO 70f41a132bSSasha Levin io_context_t ctx; 7130a9aa69SJean-Philippe Brucker int evt; 72*a839180eSJean-Philippe Brucker pthread_t thread; 7330a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */ 74a67da3beSAsias He const char *wwpn; 75a67da3beSAsias He const char *tpgt; 763b55dcdeSSasha Levin int debug_iodelay; 779f532d00SPekka Enberg }; 789f532d00SPekka Enberg 793b55dcdeSSasha Levin int disk_img_name_parser(const struct option *opt, const char *arg, int unset); 803b55dcdeSSasha Levin int disk_image__init(struct kvm *kvm); 813b55dcdeSSasha Levin int disk_image__exit(struct kvm *kvm); 827d22135fSAsias He struct disk_image *disk_image__new(int fd, u64 size, struct disk_image_operations *ops, int mmap); 83fda63751SAsias He int disk_image__flush(struct disk_image *disk); 845af21162SSasha Levin ssize_t disk_image__read(struct disk_image *disk, u64 sector, const struct iovec *iov, 855af21162SSasha Levin int iovcount, void *param); 865af21162SSasha Levin ssize_t disk_image__write(struct disk_image *disk, u64 sector, const struct iovec *iov, 875af21162SSasha Levin int iovcount, void *param); 88ff6462e8SSasha Levin ssize_t disk_image__get_serial(struct disk_image *disk, void *buffer, ssize_t *len); 8970b53f25SSasha Levin 90c9310ac4SAsias He struct disk_image *raw_image__probe(int fd, struct stat *st, bool readonly); 915236b505SAsias He struct disk_image *blkdev__probe(const char *filename, int flags, struct stat *st); 92c9310ac4SAsias He 9330a9aa69SJean-Philippe Brucker ssize_t raw_image__read_sync(struct disk_image *disk, u64 sector, 945af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 9530a9aa69SJean-Philippe Brucker ssize_t raw_image__write_sync(struct disk_image *disk, u64 sector, 965af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 97dcd3cd8eSAsias He ssize_t raw_image__read_mmap(struct disk_image *disk, u64 sector, 985af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 99dcd3cd8eSAsias He ssize_t raw_image__write_mmap(struct disk_image *disk, u64 sector, 1005af21162SSasha Levin const struct iovec *iov, int iovcount, void *param); 10187ee33c8SAsias He int raw_image__close(struct disk_image *disk); 1028b52f877SSasha Levin void disk_image__set_callback(struct disk_image *disk, void (*disk_req_cb)(void *param, long len)); 10330a9aa69SJean-Philippe Brucker 10430a9aa69SJean-Philippe Brucker #ifdef CONFIG_HAS_AIO 10530a9aa69SJean-Philippe Brucker int disk_aio_setup(struct disk_image *disk); 10630a9aa69SJean-Philippe Brucker void disk_aio_destroy(struct disk_image *disk); 10730a9aa69SJean-Philippe Brucker ssize_t raw_image__read_async(struct disk_image *disk, u64 sector, 10830a9aa69SJean-Philippe Brucker const struct iovec *iov, int iovcount, void *param); 10930a9aa69SJean-Philippe Brucker ssize_t raw_image__write_async(struct disk_image *disk, u64 sector, 11030a9aa69SJean-Philippe Brucker const struct iovec *iov, int iovcount, void *param); 11130a9aa69SJean-Philippe Brucker 11230a9aa69SJean-Philippe Brucker #define raw_image__read raw_image__read_async 11330a9aa69SJean-Philippe Brucker #define raw_image__write raw_image__write_async 11430a9aa69SJean-Philippe Brucker 11530a9aa69SJean-Philippe Brucker #else /* !CONFIG_HAS_AIO */ 11630a9aa69SJean-Philippe Brucker static inline int disk_aio_setup(struct disk_image *disk) 11730a9aa69SJean-Philippe Brucker { 11830a9aa69SJean-Philippe Brucker /* No-op */ 11930a9aa69SJean-Philippe Brucker return 0; 12030a9aa69SJean-Philippe Brucker } 12130a9aa69SJean-Philippe Brucker static inline void disk_aio_destroy(struct disk_image *disk) 12230a9aa69SJean-Philippe Brucker { 12330a9aa69SJean-Philippe Brucker } 12430a9aa69SJean-Philippe Brucker #define raw_image__read raw_image__read_sync 12530a9aa69SJean-Philippe Brucker #define raw_image__write raw_image__write_sync 12630a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */ 12730a9aa69SJean-Philippe Brucker 1289f532d00SPekka Enberg #endif /* KVM__DISK_IMAGE_H */ 129