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=a4fca43e1e38a63ee252dc29e328d638e4c374f1;hpb=ce0f119828348c3c57a00c4aa268a8a223ccd7f8;p=palacios.git diff --git a/palacios/include/palacios/vm_guest.h b/palacios/include/palacios/vm_guest.h index a4fca43..e646c86 100644 --- a/palacios/include/palacios/vm_guest.h +++ b/palacios/include/palacios/vm_guest.h @@ -69,6 +69,14 @@ struct v3_sym_core_state; #include #endif +#ifdef V3_CONFIG_MULTIBOOT +#include +#endif + +#ifdef V3_CONFIG_HVM +#include +#endif + #include @@ -154,6 +162,12 @@ struct guest_info { #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; @@ -189,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; @@ -251,11 +268,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 + + 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