X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvm_guest.h;h=e646c86c5e585ad6209e1ad07199cdba7467d13f;hb=3650bf4aaa4f83afae52c8fee98fce6e3ee68deb;hp=bc12edc8021793fbfaa93ce7d93c7ca6ea64def1;hpb=5ef0e92d52b2698fd2706cd7cfc2b01526a6e319;p=palacios.git diff --git a/palacios/include/palacios/vm_guest.h b/palacios/include/palacios/vm_guest.h index bc12edc..e646c86 100644 --- a/palacios/include/palacios/vm_guest.h +++ b/palacios/include/palacios/vm_guest.h @@ -65,6 +65,18 @@ struct v3_sym_core_state; #endif +#ifdef V3_CONFIG_MEM_TRACK +#include +#endif + +#ifdef V3_CONFIG_MULTIBOOT +#include +#endif + +#ifdef V3_CONFIG_HVM +#include +#endif + #include @@ -147,6 +159,15 @@ struct guest_info { 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; @@ -182,6 +203,9 @@ struct v3_vm_info { 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; @@ -240,11 +264,26 @@ struct v3_vm_info { 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 + + 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