#include <palacios/vmm_emulator.h>
#include <palacios/vmm_host_events.h>
#include <palacios/vmm_msr.h>
+#include <palacios/vmm_profiler.h>
uint_t long_mode : 1;
uint_t db : 1;
uint_t granularity : 1;
-};
+} __attribute__((packed));
struct v3_segments {
struct v3_segment gdtr;
struct v3_segment idtr;
struct v3_segment tr;
-};
+} ;
struct shadow_page_state;
-struct shadow_map;
-struct vmm_io_map;
struct emulation_state;
struct v3_intr_state;
-
+struct v3_profiler;
uint_t cpl;
- struct shadow_map mem_map;
+ addr_t mem_size; // Probably in bytes for now....
+ v3_shdw_map_t mem_map;
+
struct vm_time time_state;
+
v3_paging_mode_t shdw_pg_mode;
struct shadow_page_state shdw_pg_state;
// This structure is how we get interrupts for the guest
struct v3_intr_state intr_state;
- struct vmm_io_map io_map;
+ v3_io_map_t io_map;
struct v3_msr_map msr_map;
// device_map
struct v3_dbg_regs dbg_regs;
struct v3_segments segments;
- struct emulation_state emulator;
-
v3_vm_operating_mode_t run_state;
void * vmm_data;
+ uint_t enable_profiler;
+ struct v3_profiler profiler;
+
+ void * decoder_state;
+
struct v3_msr guest_efer;
/* TEMP */
v3_vm_mem_mode_t v3_get_mem_mode(struct guest_info * info);
+const uchar_t * v3_cpu_mode_to_str(v3_vm_cpu_mode_t mode);
+const uchar_t * v3_mem_mode_to_str(v3_vm_mem_mode_t mode);
+
+
void v3_print_segments(struct guest_info * info);
void v3_print_ctrl_regs(struct guest_info * info);
void v3_print_GPRs(struct guest_info * info);