xref: /kvmtool/include/kvm/disk-image.h (revision 30a9aa69300118907de7735f5695f8b142d74455)
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 
22*30a9aa69SJean-Philippe Brucker #ifdef CONFIG_HAS_AIO
23*30a9aa69SJean-Philippe Brucker #include <libaio.h>
24*30a9aa69SJean-Philippe Brucker #endif
25*30a9aa69SJean-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);
45499f3bedSPekka Enberg };
46499f3bedSPekka Enberg 
4797f16d66SAsias He struct disk_image_params {
4897f16d66SAsias He 	const char *filename;
49a67da3beSAsias He 	/*
50a67da3beSAsias He 	 * wwpn == World Wide Port Number
51a67da3beSAsias He 	 * tpgt == Target Portal Group Tag
52a67da3beSAsias He 	 */
53a67da3beSAsias He 	const char *wwpn;
54a67da3beSAsias He 	const char *tpgt;
5597f16d66SAsias He 	bool readonly;
565236b505SAsias He 	bool direct;
5797f16d66SAsias He };
5897f16d66SAsias He 
599f532d00SPekka Enberg struct disk_image {
609f532d00SPekka Enberg 	int				fd;
613fdf659dSSasha Levin 	u64				size;
62499f3bedSPekka Enberg 	struct disk_image_operations	*ops;
63499f3bedSPekka Enberg 	void				*priv;
645af21162SSasha Levin 	void				*disk_req_cb_param;
658b52f877SSasha Levin 	void				(*disk_req_cb)(void *param, long len);
665c5cae75SJean-Philippe Brucker 	bool				readonly;
67f41a132bSSasha Levin 	bool				async;
68f41a132bSSasha Levin #ifdef CONFIG_HAS_AIO
69f41a132bSSasha Levin 	io_context_t			ctx;
70*30a9aa69SJean-Philippe Brucker 	int				evt;
71*30a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */
72a67da3beSAsias He 	const char			*wwpn;
73a67da3beSAsias He 	const char			*tpgt;
743b55dcdeSSasha Levin 	int				debug_iodelay;
759f532d00SPekka Enberg };
769f532d00SPekka Enberg 
773b55dcdeSSasha Levin int disk_img_name_parser(const struct option *opt, const char *arg, int unset);
783b55dcdeSSasha Levin int disk_image__init(struct kvm *kvm);
793b55dcdeSSasha Levin int disk_image__exit(struct kvm *kvm);
807d22135fSAsias He struct disk_image *disk_image__new(int fd, u64 size, struct disk_image_operations *ops, int mmap);
81fda63751SAsias He int disk_image__flush(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);
86ff6462e8SSasha Levin ssize_t disk_image__get_serial(struct disk_image *disk, void *buffer, ssize_t *len);
8770b53f25SSasha Levin 
88c9310ac4SAsias He struct disk_image *raw_image__probe(int fd, struct stat *st, bool readonly);
895236b505SAsias He struct disk_image *blkdev__probe(const char *filename, int flags, struct stat *st);
90c9310ac4SAsias He 
91*30a9aa69SJean-Philippe Brucker ssize_t raw_image__read_sync(struct disk_image *disk, u64 sector,
925af21162SSasha Levin 			     const struct iovec *iov, int iovcount, void *param);
93*30a9aa69SJean-Philippe Brucker ssize_t raw_image__write_sync(struct disk_image *disk, u64 sector,
945af21162SSasha Levin 			      const struct iovec *iov, int iovcount, void *param);
95dcd3cd8eSAsias He ssize_t raw_image__read_mmap(struct disk_image *disk, u64 sector,
965af21162SSasha Levin 				const struct iovec *iov, int iovcount, void *param);
97dcd3cd8eSAsias He ssize_t raw_image__write_mmap(struct disk_image *disk, u64 sector,
985af21162SSasha Levin 				const struct iovec *iov, int iovcount, void *param);
9987ee33c8SAsias He int raw_image__close(struct disk_image *disk);
1008b52f877SSasha Levin void disk_image__set_callback(struct disk_image *disk, void (*disk_req_cb)(void *param, long len));
101*30a9aa69SJean-Philippe Brucker 
102*30a9aa69SJean-Philippe Brucker #ifdef CONFIG_HAS_AIO
103*30a9aa69SJean-Philippe Brucker int disk_aio_setup(struct disk_image *disk);
104*30a9aa69SJean-Philippe Brucker void disk_aio_destroy(struct disk_image *disk);
105*30a9aa69SJean-Philippe Brucker ssize_t raw_image__read_async(struct disk_image *disk, u64 sector,
106*30a9aa69SJean-Philippe Brucker 			      const struct iovec *iov, int iovcount, void *param);
107*30a9aa69SJean-Philippe Brucker ssize_t raw_image__write_async(struct disk_image *disk, u64 sector,
108*30a9aa69SJean-Philippe Brucker 			       const struct iovec *iov, int iovcount, void *param);
109*30a9aa69SJean-Philippe Brucker 
110*30a9aa69SJean-Philippe Brucker #define raw_image__read		raw_image__read_async
111*30a9aa69SJean-Philippe Brucker #define raw_image__write	raw_image__write_async
112*30a9aa69SJean-Philippe Brucker 
113*30a9aa69SJean-Philippe Brucker #else /* !CONFIG_HAS_AIO */
114*30a9aa69SJean-Philippe Brucker static inline int disk_aio_setup(struct disk_image *disk)
115*30a9aa69SJean-Philippe Brucker {
116*30a9aa69SJean-Philippe Brucker 	/* No-op */
117*30a9aa69SJean-Philippe Brucker 	return 0;
118*30a9aa69SJean-Philippe Brucker }
119*30a9aa69SJean-Philippe Brucker static inline void disk_aio_destroy(struct disk_image *disk)
120*30a9aa69SJean-Philippe Brucker {
121*30a9aa69SJean-Philippe Brucker }
122*30a9aa69SJean-Philippe Brucker #define raw_image__read		raw_image__read_sync
123*30a9aa69SJean-Philippe Brucker #define raw_image__write	raw_image__write_sync
124*30a9aa69SJean-Philippe Brucker #endif /* CONFIG_HAS_AIO */
125*30a9aa69SJean-Philippe Brucker 
1269f532d00SPekka Enberg #endif /* KVM__DISK_IMAGE_H */
127