X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?p=palacios.git;a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_sym_swap.h;h=e104acc77fecc5a9f83cf3f3a59e16f9ce185e30;hp=6bb3788f6ff5c7f2e9eb0fa600c7562d28750f49;hb=0121a4503305424096e2b5c5bd3b6c3af2d813e5;hpb=6fe9fe338ec19b212b43bb2c25322dce3cdbb490 diff --git a/palacios/include/palacios/vmm_sym_swap.h b/palacios/include/palacios/vmm_sym_swap.h index 6bb3788..e104acc 100644 --- a/palacios/include/palacios/vmm_sym_swap.h +++ b/palacios/include/palacios/vmm_sym_swap.h @@ -45,12 +45,20 @@ 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; + uint32_t list_size; +#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,7 +73,9 @@ 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); -addr_t v3_get_swapped_pg_addr(struct guest_info * info, pte32_t * shadow_pte, pte32_t * guest_pte); +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 * guest_pte); +addr_t v3_map_swp_page(struct guest_info * info, pte32_t * shadow_pte, pte32_t * guest_pte, void * swp_page_ptr); int v3_swap_flush(struct guest_info * info);