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;
51*145a86feSJean-Philippe Brucker /* wwpn == World Wide Port Number */
52a67da3beSAsias He const char *wwpn;
5397f16d66SAsias He bool readonly;
545236b505SAsias He bool direct;
5597f16d66SAsias He };
5697f16d66SAsias He
579f532d00SPekka Enberg struct disk_image {
589f532d00SPekka Enberg int fd;
593fdf659dSSasha Levin u64 size;
60499f3bedSPekka Enberg struct disk_image_operations *ops;
61499f3bedSPekka Enberg void *priv;
625af21162SSasha Levin void *disk_req_cb_param;
638b52f877SSasha Levin void (*disk_req_cb)(void *param, long len);
645c5cae75SJean-Philippe Brucker bool readonly;
65f41a132bSSasha Levin bool async;
66f41a132bSSasha Levin #ifdef CONFIG_HAS_AIO
67f41a132bSSasha Levin io_context_t ctx;
6830a9aa69SJean-Philippe Brucker int evt;
69a839180eSJean-Philippe Brucker pthread_t thread;
702790307cSJean-Philippe Brucker u64 aio_inflight;
7130a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */
72a67da3beSAsias He const char *wwpn;
733b55dcdeSSasha Levin int debug_iodelay;
749f532d00SPekka Enberg };
759f532d00SPekka Enberg
763b55dcdeSSasha Levin int disk_img_name_parser(const struct option *opt, const char *arg, int unset);
773b55dcdeSSasha Levin int disk_image__init(struct kvm *kvm);
783b55dcdeSSasha Levin int disk_image__exit(struct kvm *kvm);
797d22135fSAsias He struct disk_image *disk_image__new(int fd, u64 size, struct disk_image_operations *ops, int mmap);
80fda63751SAsias He int disk_image__flush(struct disk_image *disk);
812790307cSJean-Philippe Brucker int disk_image__wait(struct disk_image *disk);
825af21162SSasha Levin ssize_t disk_image__read(struct disk_image *disk, u64 sector, const struct iovec *iov,
835af21162SSasha Levin int iovcount, void *param);
845af21162SSasha Levin ssize_t disk_image__write(struct disk_image *disk, u64 sector, const struct iovec *iov,
855af21162SSasha Levin int iovcount, void *param);
8648427891SJean-Philippe Brucker ssize_t disk_image__get_serial(struct disk_image *disk, struct iovec *iov,
8748427891SJean-Philippe Brucker int iovcount, ssize_t len);
8870b53f25SSasha Levin
89c9310ac4SAsias He struct disk_image *raw_image__probe(int fd, struct stat *st, bool readonly);
905236b505SAsias He struct disk_image *blkdev__probe(const char *filename, int flags, struct stat *st);
91c9310ac4SAsias He
9230a9aa69SJean-Philippe Brucker ssize_t raw_image__read_sync(struct disk_image *disk, u64 sector,
935af21162SSasha Levin const struct iovec *iov, int iovcount, void *param);
9430a9aa69SJean-Philippe Brucker ssize_t raw_image__write_sync(struct disk_image *disk, u64 sector,
955af21162SSasha Levin const struct iovec *iov, int iovcount, void *param);
96dcd3cd8eSAsias He ssize_t raw_image__read_mmap(struct disk_image *disk, u64 sector,
975af21162SSasha Levin const struct iovec *iov, int iovcount, void *param);
98dcd3cd8eSAsias He ssize_t raw_image__write_mmap(struct disk_image *disk, u64 sector,
995af21162SSasha Levin const struct iovec *iov, int iovcount, void *param);
10087ee33c8SAsias He int raw_image__close(struct disk_image *disk);
1018b52f877SSasha Levin void disk_image__set_callback(struct disk_image *disk, void (*disk_req_cb)(void *param, long len));
10230a9aa69SJean-Philippe Brucker
10330a9aa69SJean-Philippe Brucker #ifdef CONFIG_HAS_AIO
10430a9aa69SJean-Philippe Brucker int disk_aio_setup(struct disk_image *disk);
10530a9aa69SJean-Philippe Brucker void disk_aio_destroy(struct disk_image *disk);
10630a9aa69SJean-Philippe Brucker ssize_t raw_image__read_async(struct disk_image *disk, u64 sector,
10730a9aa69SJean-Philippe Brucker const struct iovec *iov, int iovcount, void *param);
10830a9aa69SJean-Philippe Brucker ssize_t raw_image__write_async(struct disk_image *disk, u64 sector,
10930a9aa69SJean-Philippe Brucker const struct iovec *iov, int iovcount, void *param);
1102790307cSJean-Philippe Brucker int raw_image__wait(struct disk_image *disk);
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 */
disk_aio_setup(struct disk_image * disk)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 }
disk_aio_destroy(struct disk_image * disk)12130a9aa69SJean-Philippe Brucker static inline void disk_aio_destroy(struct disk_image *disk)
12230a9aa69SJean-Philippe Brucker {
12330a9aa69SJean-Philippe Brucker }
1242790307cSJean-Philippe Brucker
raw_image__wait(struct disk_image * disk)1252790307cSJean-Philippe Brucker static inline int raw_image__wait(struct disk_image *disk)
1262790307cSJean-Philippe Brucker {
1272790307cSJean-Philippe Brucker return 0;
1282790307cSJean-Philippe Brucker }
12930a9aa69SJean-Philippe Brucker #define raw_image__read raw_image__read_sync
13030a9aa69SJean-Philippe Brucker #define raw_image__write raw_image__write_sync
13130a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */
13230a9aa69SJean-Philippe Brucker
1339f532d00SPekka Enberg #endif /* KVM__DISK_IMAGE_H */
134