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 #define KVM_NR_CPUS (255) 12 13 /* 14 * The hole includes VESA framebuffer and PCI memory. 15 */ 16 #define KVM_32BIT_GAP_SIZE (768 << 20) 17 #define KVM_32BIT_GAP_START ((1ULL << 32) - KVM_32BIT_GAP_SIZE) 18 19 #define KVM_MMIO_START KVM_32BIT_GAP_START 20 21 /* This is the address that pci_get_io_space_block() starts allocating 22 * from. Note that this is a PCI bus address (though same on x86). 23 */ 24 #define KVM_PCI_MMIO_AREA (KVM_MMIO_START + 0x1000000) 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 const char *name; 53 }; 54 55 static inline void *guest_flat_to_host(struct kvm *kvm, unsigned long offset); /* In kvm.h */ 56 57 static inline void *guest_real_to_host(struct kvm *kvm, u16 selector, u16 offset) 58 { 59 unsigned long flat = segment_to_flat(selector, offset); 60 61 return guest_flat_to_host(kvm, flat); 62 } 63 64 #endif /* KVM__KVM_ARCH_H */ 65