X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvm_guest.h;h=84468b233529441ca67e87db35b4f923d64c6ae1;hb=de5c2110458436a9300aa0a171dbbe83e415ee4d;hp=3029c3cd60cdb98680b23b1a805c9163a1df4ffc;hpb=1c5bf75232c70f01570ddc8b075f9455b7c6ba34;p=palacios.git diff --git a/palacios/include/palacios/vm_guest.h b/palacios/include/palacios/vm_guest.h index 3029c3c..84468b2 100644 --- a/palacios/include/palacios/vm_guest.h +++ b/palacios/include/palacios/vm_guest.h @@ -39,6 +39,7 @@ #include #include #include +#include #include #include #include @@ -69,11 +70,17 @@ struct v3_sym_core_state; #include #endif +#ifdef V3_CONFIG_MULTIBOOT +#include +#endif + #ifdef V3_CONFIG_HVM #include #endif - +#ifdef V3_CONFIG_CACHEPART +#include +#endif #include @@ -94,6 +101,9 @@ struct guest_info { struct v3_core_timeouts timeouts; void * sched_priv_data; + // Resource constraints/etc for the thread running this core + v3_resource_control_t resource_control; + v3_paging_mode_t shdw_pg_mode; // arch-independent state of shadow pager struct v3_shdw_pg_state shdw_pg_state; @@ -197,6 +207,11 @@ struct v3_vm_info { char name[128]; v3_vm_class_t vm_class; + + // Resource control for whole VM - determined early and used + // when building the VM, then cloned to each core + v3_resource_control_t resource_control; + struct v3_fw_cfg_state fw_cfg_state; // This is always the total RAM (addresses 0...mem_size) @@ -264,10 +279,22 @@ struct v3_vm_info { 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; + +#ifdef V3_CONFIG_CACHEPART + v3_cachepart_t cachepart_state; +#endif + + uint64_t yield_cycle_period;