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" 649a8afd1SSasha Levin #include "kvm/util-init.h" 749a8afd1SSasha Levin #include "kvm/kvm.h" 8da8883c1SPekka Enberg 9ae1fae34SPekka Enberg #include <stdbool.h> 103fdf659dSSasha Levin #include <linux/types.h> 11ce79f1caSPekka Enberg #include <time.h> 1282d2f21eSSasha Levin #include <signal.h> 13*a4d8c55eSSasha Levin #include <sys/prctl.h> 14ae1fae34SPekka Enberg 15b1c2516bSSasha Levin #define SIGKVMEXIT (SIGRTMIN + 0) 164298ddadSSasha Levin #define SIGKVMPAUSE (SIGRTMIN + 1) 1749e5227dSSasha Levin 18354b198bSAsias He #define KVM_PID_FILE_PATH "/.lkvm/" 1982d65b5eSSasha Levin #define HOME_DIR getenv("HOME") 20ee8b1456SWanlong Gao #define KVM_BINARY_NAME "lkvm" 2182d65b5eSSasha Levin 22af7b0868SMatt Evans #define PAGE_SIZE (sysconf(_SC_PAGE_SIZE)) 23ae1fae34SPekka Enberg 24af7b0868SMatt Evans #define DEFINE_KVM_EXT(ext) \ 25af7b0868SMatt Evans .name = #ext, \ 26af7b0868SMatt Evans .code = ext 270c7c14a7SCyrill Gorcunov 287021c50bSAsias He enum { 297021c50bSAsias He KVM_VMSTATE_RUNNING, 307021c50bSAsias He KVM_VMSTATE_PAUSED, 317021c50bSAsias He }; 327021c50bSAsias He 33af7b0868SMatt Evans struct kvm_ext { 345358b0e6SSasha Levin const char *name; 35af7b0868SMatt Evans int code; 36ae1fae34SPekka Enberg }; 37ae1fae34SPekka Enberg 3842ac24f9SSasha Levin struct kvm { 3942ac24f9SSasha Levin struct kvm_arch arch; 4047621338SSasha Levin struct kvm_config cfg; 4142ac24f9SSasha Levin int sys_fd; /* For system ioctls(), i.e. /dev/kvm */ 4242ac24f9SSasha Levin int vm_fd; /* For VM ioctls() */ 4342ac24f9SSasha Levin timer_t timerid; /* Posix timer for interrupts */ 4442ac24f9SSasha Levin 4542ac24f9SSasha Levin int nrcpus; /* Number of cpus to run */ 46df4239fbSSasha Levin struct kvm_cpu **cpus; 4742ac24f9SSasha Levin 4842ac24f9SSasha Levin u32 mem_slots; /* for KVM_SET_USER_MEMORY_REGION */ 4942ac24f9SSasha Levin u64 ram_size; 5042ac24f9SSasha Levin void *ram_start; 5142ac24f9SSasha Levin u64 ram_pagesize; 5242ac24f9SSasha Levin 5342ac24f9SSasha Levin bool nmi_disabled; 5442ac24f9SSasha Levin 5542ac24f9SSasha Levin const char *vmlinux; 5642ac24f9SSasha Levin struct disk_image **disks; 5742ac24f9SSasha Levin int nr_disks; 5842ac24f9SSasha Levin 5942ac24f9SSasha Levin int vm_state; 6042ac24f9SSasha Levin }; 6142ac24f9SSasha Levin 629667701cSPekka Enberg void kvm__set_dir(const char *fmt, ...); 639667701cSPekka Enberg const char *kvm__get_dir(void); 649667701cSPekka Enberg 6547621338SSasha Levin int kvm__init(struct kvm *kvm); 6647621338SSasha Levin struct kvm *kvm__new(void); 678259b8ccSSasha Levin int kvm__recommended_cpus(struct kvm *kvm); 6843835ac9SSasha Levin int kvm__max_cpus(struct kvm *kvm); 6943835ac9SSasha Levin void kvm__init_ram(struct kvm *kvm); 70495fbd4eSSasha Levin int kvm__exit(struct kvm *kvm); 715ad8db5eSPekka Enberg bool kvm__load_firmware(struct kvm *kvm, const char *firmware_filename); 722065a6f7SCyrill Gorcunov bool kvm__load_kernel(struct kvm *kvm, const char *kernel_filename, 7353861c74SJohn Floren const char *initrd_filename, const char *kernel_cmdline, u16 vidmode); 74b4532ca9SSasha Levin int kvm_timer__init(struct kvm *kvm); 75b4532ca9SSasha Levin int kvm_timer__exit(struct kvm *kvm); 7643835ac9SSasha Levin void kvm__irq_line(struct kvm *kvm, int irq, int level); 77bfaed61cSSasha Levin void kvm__irq_trigger(struct kvm *kvm, int irq); 7843835ac9SSasha Levin bool kvm__emulate_io(struct kvm *kvm, u16 port, void *data, int direction, int size, u32 count); 7943835ac9SSasha Levin bool kvm__emulate_mmio(struct kvm *kvm, u64 phys_addr, u8 *data, u32 len, u8 is_write); 80495fbd4eSSasha Levin int kvm__register_mem(struct kvm *kvm, u64 guest_phys, u64 size, void *userspace_addr); 81495fbd4eSSasha Levin int kvm__register_mmio(struct kvm *kvm, u64 phys_addr, u64 phys_addr_len, bool coalesce, 829aa9d62aSSasha Levin void (*mmio_fn)(u64 addr, u8 *data, u32 len, u8 is_write, void *ptr), 839aa9d62aSSasha Levin void *ptr); 8473f7e5b3SSasha Levin bool kvm__deregister_mmio(struct kvm *kvm, u64 phys_addr); 854346fd8fSSasha Levin void kvm__pause(struct kvm *kvm); 864346fd8fSSasha Levin void kvm__continue(struct kvm *kvm); 874298ddadSSasha Levin void kvm__notify_paused(void); 884b1addaeSSasha Levin int kvm__get_sock_by_instance(const char *name); 89886af5f2SLiming Wang int kvm__enumerate_instances(int (*callback)(const char *name, int pid)); 904b1addaeSSasha Levin void kvm__remove_socket(const char *name); 91ae1fae34SPekka Enberg 928e704a7aSMatt Evans void kvm__arch_set_cmdline(char *cmdline, bool video); 937eff9f49SWanlong Gao void kvm__arch_init(struct kvm *kvm, const char *hugetlbfs_path, u64 ram_size); 94e56e2de7SLai Jiangshan void kvm__arch_delete_ram(struct kvm *kvm); 95f7f9d02bSCyrill Gorcunov int kvm__arch_setup_firmware(struct kvm *kvm); 961add9f73SSasha Levin int kvm__arch_free_firmware(struct kvm *kvm); 97af7b0868SMatt Evans bool kvm__arch_cpu_supports_vm(void); 980b69bdefSMatt Evans void kvm__arch_periodic_poll(struct kvm *kvm); 99af7b0868SMatt Evans 100604dbd63SMatt Evans int load_flat_binary(struct kvm *kvm, int fd_kernel, int fd_initrd, const char *kernel_cmdline); 101af7b0868SMatt Evans bool load_bzimage(struct kvm *kvm, int fd_kernel, int fd_initrd, const char *kernel_cmdline, u16 vidmode); 102af7b0868SMatt Evans 103ae1fae34SPekka Enberg /* 104ae1fae34SPekka Enberg * Debugging 105ae1fae34SPekka Enberg */ 10643835ac9SSasha Levin void kvm__dump_mem(struct kvm *kvm, unsigned long addr, unsigned long size); 107ae1fae34SPekka Enberg 108ae1fae34SPekka Enberg extern const char *kvm_exit_reasons[]; 109ae1fae34SPekka Enberg 11043835ac9SSasha Levin static inline bool host_ptr_in_ram(struct kvm *kvm, void *p) 1119292f776SCyrill Gorcunov { 11243835ac9SSasha Levin return kvm->ram_start <= p && p < (kvm->ram_start + kvm->ram_size); 1139292f776SCyrill Gorcunov } 1149292f776SCyrill Gorcunov 11543835ac9SSasha Levin static inline void *guest_flat_to_host(struct kvm *kvm, unsigned long offset) 1169292f776SCyrill Gorcunov { 11743835ac9SSasha Levin return kvm->ram_start + offset; 1189292f776SCyrill Gorcunov } 1199292f776SCyrill Gorcunov 1201d6fb3f2SSasha Levin bool kvm__supports_extension(struct kvm *kvm, unsigned int extension); 1216930e42fSSasha Levin 122*a4d8c55eSSasha Levin static inline void kvm__set_thread_name(const char *name) 123*a4d8c55eSSasha Levin { 124*a4d8c55eSSasha Levin prctl(PR_SET_NAME, name); 125*a4d8c55eSSasha Levin } 126*a4d8c55eSSasha Levin 127ae1fae34SPekka Enberg #endif /* KVM__KVM_H */ 128