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=cb0b41d85141415b0f227e1f96b977e984e0cc37;hb=0121a4503305424096e2b5c5bd3b6c3af2d813e5;hpb=7c9087090f06a3fdf041f650912c36b6b12d7a82 diff --git a/palacios/include/palacios/vmm_sym_swap.h b/palacios/include/palacios/vmm_sym_swap.h index cb0b41d..e104acc 100644 --- a/palacios/include/palacios/vmm_sym_swap.h +++ b/palacios/include/palacios/vmm_sym_swap.h @@ -25,6 +25,7 @@ #include #include +#include struct v3_swap_ops { @@ -43,24 +44,41 @@ 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)); } - int v3_init_sym_swap(struct guest_info * info); -addr_t v3_get_swapped_pg_addr(struct guest_info * info, pte32_t * pte); - int v3_register_swap_disk(struct guest_info * info, int dev_index, struct v3_swap_ops * ops, void * private_data); -int v3_swap_out_notify(struct guest_info * info, int pg_index, 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 * 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); + #endif #endif