xref: /kvmtool/include/kvm/kvm.h (revision df4239fb27a9670b554d71fb4a79bacfb804d477)
1ae1fae34SPekka Enberg #ifndef KVM__KVM_H
2ae1fae34SPekka Enberg #define KVM__KVM_H
3ae1fae34SPekka Enberg 
4af7b0868SMatt Evans #include "kvm/kvm-arch.h"
547621338SSasha Levin #include "kvm/kvm-config.h"
6da8883c1SPekka Enberg 
7ae1fae34SPekka Enberg #include <stdbool.h>
83fdf659dSSasha Levin #include <linux/types.h>
9ce79f1caSPekka Enberg #include <time.h>
1082d2f21eSSasha Levin #include <signal.h>
11ae1fae34SPekka Enberg 
12b1c2516bSSasha Levin #define SIGKVMEXIT		(SIGRTMIN + 0)
134298ddadSSasha Levin #define SIGKVMPAUSE		(SIGRTMIN + 1)
1449e5227dSSasha Levin 
15354b198bSAsias He #define KVM_PID_FILE_PATH	"/.lkvm/"
1682d65b5eSSasha Levin #define HOME_DIR		getenv("HOME")
17ee8b1456SWanlong Gao #define KVM_BINARY_NAME		"lkvm"
1882d65b5eSSasha Levin 
19af7b0868SMatt Evans #define PAGE_SIZE (sysconf(_SC_PAGE_SIZE))
20ae1fae34SPekka Enberg 
21af7b0868SMatt Evans #define DEFINE_KVM_EXT(ext)		\
22af7b0868SMatt Evans 	.name = #ext,			\
23af7b0868SMatt Evans 	.code = ext
240c7c14a7SCyrill Gorcunov 
257021c50bSAsias He enum {
267021c50bSAsias He 	KVM_VMSTATE_RUNNING,
277021c50bSAsias He 	KVM_VMSTATE_PAUSED,
287021c50bSAsias He };
297021c50bSAsias He 
30af7b0868SMatt Evans struct kvm_ext {
315358b0e6SSasha Levin 	const char *name;
32af7b0868SMatt Evans 	int code;
33ae1fae34SPekka Enberg };
34ae1fae34SPekka Enberg 
3542ac24f9SSasha Levin struct kvm {
3642ac24f9SSasha Levin 	struct kvm_arch		arch;
3747621338SSasha Levin 	struct kvm_config	cfg;
3842ac24f9SSasha Levin 	int			sys_fd;		/* For system ioctls(), i.e. /dev/kvm */
3942ac24f9SSasha Levin 	int			vm_fd;		/* For VM ioctls() */
4042ac24f9SSasha Levin 	timer_t			timerid;	/* Posix timer for interrupts */
4142ac24f9SSasha Levin 
4242ac24f9SSasha Levin 	int			nrcpus;		/* Number of cpus to run */
43*df4239fbSSasha Levin 	struct kvm_cpu		**cpus;
4442ac24f9SSasha Levin 
4542ac24f9SSasha Levin 	u32			mem_slots;	/* for KVM_SET_USER_MEMORY_REGION */
4642ac24f9SSasha Levin 	u64			ram_size;
4742ac24f9SSasha Levin 	void			*ram_start;
4842ac24f9SSasha Levin 	u64			ram_pagesize;
4942ac24f9SSasha Levin 
5042ac24f9SSasha Levin 	bool			nmi_disabled;
5142ac24f9SSasha Levin 
5242ac24f9SSasha Levin 	const char		*vmlinux;
5342ac24f9SSasha Levin 	struct disk_image       **disks;
5442ac24f9SSasha Levin 	int                     nr_disks;
5542ac24f9SSasha Levin 
5642ac24f9SSasha Levin 	int			vm_state;
5742ac24f9SSasha Levin };
5842ac24f9SSasha Levin 
599667701cSPekka Enberg void kvm__set_dir(const char *fmt, ...);
609667701cSPekka Enberg const char *kvm__get_dir(void);
619667701cSPekka Enberg 
6247621338SSasha Levin int kvm__init(struct kvm *kvm);
6347621338SSasha Levin struct kvm *kvm__new(void);
648259b8ccSSasha Levin int kvm__recommended_cpus(struct kvm *kvm);
6543835ac9SSasha Levin int kvm__max_cpus(struct kvm *kvm);
6643835ac9SSasha Levin void kvm__init_ram(struct kvm *kvm);
67495fbd4eSSasha Levin int kvm__exit(struct kvm *kvm);
685ad8db5eSPekka Enberg bool kvm__load_firmware(struct kvm *kvm, const char *firmware_filename);
692065a6f7SCyrill Gorcunov bool kvm__load_kernel(struct kvm *kvm, const char *kernel_filename,
7053861c74SJohn Floren 			const char *initrd_filename, const char *kernel_cmdline, u16 vidmode);
7143835ac9SSasha Levin void kvm__start_timer(struct kvm *kvm);
7243835ac9SSasha Levin void kvm__stop_timer(struct kvm *kvm);
7343835ac9SSasha Levin void kvm__irq_line(struct kvm *kvm, int irq, int level);
74bfaed61cSSasha Levin void kvm__irq_trigger(struct kvm *kvm, int irq);
7543835ac9SSasha Levin bool kvm__emulate_io(struct kvm *kvm, u16 port, void *data, int direction, int size, u32 count);
7643835ac9SSasha Levin bool kvm__emulate_mmio(struct kvm *kvm, u64 phys_addr, u8 *data, u32 len, u8 is_write);
77495fbd4eSSasha Levin int kvm__register_mem(struct kvm *kvm, u64 guest_phys, u64 size, void *userspace_addr);
78495fbd4eSSasha Levin int kvm__register_mmio(struct kvm *kvm, u64 phys_addr, u64 phys_addr_len, bool coalesce,
799aa9d62aSSasha Levin 			void (*mmio_fn)(u64 addr, u8 *data, u32 len, u8 is_write, void *ptr),
809aa9d62aSSasha Levin 			void *ptr);
8173f7e5b3SSasha Levin bool kvm__deregister_mmio(struct kvm *kvm, u64 phys_addr);
824298ddadSSasha Levin void kvm__pause(void);
834298ddadSSasha Levin void kvm__continue(void);
844298ddadSSasha Levin void kvm__notify_paused(void);
854b1addaeSSasha Levin int kvm__get_sock_by_instance(const char *name);
86886af5f2SLiming Wang int kvm__enumerate_instances(int (*callback)(const char *name, int pid));
874b1addaeSSasha Levin void kvm__remove_socket(const char *name);
88ae1fae34SPekka Enberg 
898e704a7aSMatt Evans void kvm__arch_set_cmdline(char *cmdline, bool video);
907eff9f49SWanlong Gao void kvm__arch_init(struct kvm *kvm, const char *hugetlbfs_path, u64 ram_size);
91e56e2de7SLai Jiangshan void kvm__arch_delete_ram(struct kvm *kvm);
92f7f9d02bSCyrill Gorcunov int kvm__arch_setup_firmware(struct kvm *kvm);
931add9f73SSasha Levin int kvm__arch_free_firmware(struct kvm *kvm);
94af7b0868SMatt Evans bool kvm__arch_cpu_supports_vm(void);
950b69bdefSMatt Evans void kvm__arch_periodic_poll(struct kvm *kvm);
96af7b0868SMatt Evans 
97604dbd63SMatt Evans int load_flat_binary(struct kvm *kvm, int fd_kernel, int fd_initrd, const char *kernel_cmdline);
98af7b0868SMatt Evans bool load_bzimage(struct kvm *kvm, int fd_kernel, int fd_initrd, const char *kernel_cmdline, u16 vidmode);
99af7b0868SMatt Evans 
100ae1fae34SPekka Enberg /*
101ae1fae34SPekka Enberg  * Debugging
102ae1fae34SPekka Enberg  */
10343835ac9SSasha Levin void kvm__dump_mem(struct kvm *kvm, unsigned long addr, unsigned long size);
104ae1fae34SPekka Enberg 
105ae1fae34SPekka Enberg extern const char *kvm_exit_reasons[];
106ae1fae34SPekka Enberg 
10743835ac9SSasha Levin static inline bool host_ptr_in_ram(struct kvm *kvm, void *p)
1089292f776SCyrill Gorcunov {
10943835ac9SSasha Levin 	return kvm->ram_start <= p && p < (kvm->ram_start + kvm->ram_size);
1109292f776SCyrill Gorcunov }
1119292f776SCyrill Gorcunov 
11243835ac9SSasha Levin static inline void *guest_flat_to_host(struct kvm *kvm, unsigned long offset)
1139292f776SCyrill Gorcunov {
11443835ac9SSasha Levin 	return kvm->ram_start + offset;
1159292f776SCyrill Gorcunov }
1169292f776SCyrill Gorcunov 
1171d6fb3f2SSasha Levin bool kvm__supports_extension(struct kvm *kvm, unsigned int extension);
1186930e42fSSasha Levin 
119ae1fae34SPekka Enberg #endif /* KVM__KVM_H */
120