1 #ifndef KVM__KVM_ARCH_H 2 #define KVM__KVM_ARCH_H 3 4 #include "kvm/interrupt.h" 5 #include "kvm/segment.h" 6 7 #include <stdbool.h> 8 #include <linux/types.h> 9 #include <time.h> 10 11 /* 12 * The hole includes VESA framebuffer and PCI memory. 13 */ 14 #define KVM_32BIT_MAX_MEM_SIZE (1ULL << 32) 15 #define KVM_32BIT_GAP_SIZE (768 << 20) 16 #define KVM_32BIT_GAP_START (KVM_32BIT_MAX_MEM_SIZE - KVM_32BIT_GAP_SIZE) 17 18 #define KVM_MMIO_START KVM_32BIT_GAP_START 19 20 /* This is the address that pci_get_io_space_block() starts allocating 21 * from. Note that this is a PCI bus address (though same on x86). 22 */ 23 #define KVM_PCI_MMIO_AREA (KVM_MMIO_START + 0x1000000) 24 #define KVM_VIRTIO_MMIO_AREA (KVM_MMIO_START + 0x2000000) 25 26 struct kvm { 27 int sys_fd; /* For system ioctls(), i.e. /dev/kvm */ 28 int vm_fd; /* For VM ioctls() */ 29 timer_t timerid; /* Posix timer for interrupts */ 30 31 int nrcpus; /* Number of cpus to run */ 32 33 u32 mem_slots; /* for KVM_SET_USER_MEMORY_REGION */ 34 35 u64 ram_size; 36 void *ram_start; 37 38 bool nmi_disabled; 39 40 bool single_step; 41 42 u16 boot_selector; 43 u16 boot_ip; 44 u16 boot_sp; 45 46 struct interrupt_table interrupt_table; 47 48 const char *vmlinux; 49 struct disk_image **disks; 50 int nr_disks; 51 52 char *name; 53 54 int vm_state; 55 }; 56 57 static inline void *guest_flat_to_host(struct kvm *kvm, unsigned long offset); /* In kvm.h */ 58 59 static inline void *guest_real_to_host(struct kvm *kvm, u16 selector, u16 offset) 60 { 61 unsigned long flat = segment_to_flat(selector, offset); 62 63 return guest_flat_to_host(kvm, flat); 64 } 65 66 #endif /* KVM__KVM_ARCH_H */ 67