#include <palacios/vmm_regs.h>
#include <palacios/vmm_extensions.h>
#include <palacios/vmm_barrier.h>
+#include <palacios/vmm_subset.h>
#include <palacios/vmm_timeout.h>
#include <palacios/vmm_exits.h>
#include <palacios/vmm_events.h>
#include <palacios/vmm_fp.h>
#include <palacios/vmm_perftune.h>
+
#ifdef V3_CONFIG_TELEMETRY
#include <palacios/vmm_telemetry.h>
#endif
struct v3_sym_core_state;
#endif
+#ifdef V3_CONFIG_MEM_TRACK
+#include <palacios/vmm_mem_track.h>
+#endif
+
+#ifdef V3_CONFIG_MULTIBOOT
+#include <palacios/vmm_multiboot.h>
+#endif
+
+#ifdef V3_CONFIG_HVM
+#include <palacios/vmm_hvm.h>
+#endif
+
#include <palacios/vmm_config.h>
addr_t direct_map_pt;
// arch-independent state of the nested pager (currently none)
// struct v3_nested_pg_state nested_pg_state;
+ // per-core state of the swapper (currently none)
+ //#ifdef V3_CONFIG_SWAPPING
+ // struct v3_swap_impl_state swap_impl;
+ //#endif
union {
struct v3_core_pwrstat_telemetry pwrstat_telem;
#endif
+#ifdef V3_CONFIG_MEM_TRACK
+ struct v3_core_mem_track memtrack_state;
+#endif
+
+#ifdef V3_CONFIG_HVM
+ struct v3_core_hvm hvm_state;
+#endif
+
+
/* struct v3_core_dev_mgr core_dev_mgr; */
void * decoder_state;
v3_vm_class_t vm_class;
struct v3_fw_cfg_state fw_cfg_state;
+ // This is always the total RAM (addresses 0...mem_size)
+ // in the VM.
+ // With an HVM, this is partitioned as per hvm_state
addr_t mem_size; /* In bytes for now */
uint32_t mem_align;
struct v3_mem_map mem_map;
struct v3_passthrough_impl_state passthrough_impl;
// arch-independent state of the nested pager
struct v3_nested_impl_state nested_impl;
+#ifdef V3_CONFIG_SWAPPING
+ // swapping state, if enabled
+ struct v3_swap_impl_state swap_state;
+#endif
+
void * sched_priv_data;
struct v3_io_map io_map;
struct v3_telemetry_state telemetry;
#endif
+#ifdef V3_CONFIG_MEM_TRACK
+ struct v3_vm_mem_track memtrack_state;
+#endif
+
+#ifdef V3_CONFIG_MULTIBOOT
+ struct v3_vm_multiboot mb_state;
+#endif
+
+#ifdef V3_CONFIG_HVM
+ struct v3_vm_hvm hvm_state;
+#endif
+
+ // used to implement reset of regular VM and ROS
+ v3_counting_barrier_t reset_barrier;
uint64_t yield_cycle_period;
void * host_priv_data;
+ // This is always the total number of vcores in the VM
+ // With an HVM, these are partitioned as per hvm_state
int num_cores;
int avail_cores; // Available logical cores