X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_sym_swap.h;h=a8646ef86f0072e905600c5afe3a0c10c6635ff4;hb=d0dd50e04b4847a2b170d11c849f477b7ca84168;hp=6bb3788f6ff5c7f2e9eb0fa600c7562d28750f49;hpb=6fe9fe338ec19b212b43bb2c25322dce3cdbb490;p=palacios.git diff --git a/palacios/include/palacios/vmm_sym_swap.h b/palacios/include/palacios/vmm_sym_swap.h index 6bb3788..a8646ef 100644 --- a/palacios/include/palacios/vmm_sym_swap.h +++ b/palacios/include/palacios/vmm_sym_swap.h @@ -45,12 +45,19 @@ struct v3_swap_dev { struct v3_sym_swap_state { struct v3_swap_dev devs[256]; +#ifdef CONFIG_SYMBIOTIC_SWAP_TELEMETRY + uint32_t read_faults; + uint32_t write_faults; + uint32_t flushes; + uint32_t mapped_pages; +#endif + // shadow pointers struct hashtable * shdw_ptr_ht; }; - - +// Present = 0 and Dirty = 0 +// fixme static inline int is_swapped_pte32(pte32_t * pte) { return ((pte->present == 0) && (*(uint32_t *)pte != 0)); } @@ -65,6 +72,7 @@ int v3_register_swap_disk(struct guest_info * info, int dev_index, int v3_swap_in_notify(struct guest_info * info, int pg_index, int dev_index); +int v3_get_vaddr_perms(struct guest_info * info, addr_t vaddr, pte32_t * guest_pte, pf_error_t * page_perms); addr_t v3_get_swapped_pg_addr(struct guest_info * info, pte32_t * shadow_pte, pte32_t * guest_pte); int v3_swap_flush(struct guest_info * info);