X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?p=palacios.git;a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvm_guest.h;h=84468b233529441ca67e87db35b4f923d64c6ae1;hp=7a78c0a36a0623aee1960f4d506b9fab4a8e4b14;hb=de5c2110458436a9300aa0a171dbbe83e415ee4d;hpb=f5c4d198501cfa5563c399b536f7ea5a5f61a93e diff --git a/palacios/include/palacios/vm_guest.h b/palacios/include/palacios/vm_guest.h index 7a78c0a..84468b2 100644 --- a/palacios/include/palacios/vm_guest.h +++ b/palacios/include/palacios/vm_guest.h @@ -78,7 +78,9 @@ struct v3_sym_core_state; #include #endif - +#ifdef V3_CONFIG_CACHEPART +#include +#endif #include @@ -99,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; @@ -202,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) @@ -280,6 +290,11 @@ struct v3_vm_info { // 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;