X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_emulator.h;h=f149d0217cd244500f2017ae48699031a831c598;hb=debabd511ff9dc2d0e6cd608045ac44295fe7319;hp=e396474aeeef2440aa0ca5baa87778cfb62fa030;hpb=e70e95962c26832628d586e07f9cd1a2e1852d72;p=palacios.git diff --git a/palacios/include/palacios/vmm_emulator.h b/palacios/include/palacios/vmm_emulator.h index e396474..f149d02 100644 --- a/palacios/include/palacios/vmm_emulator.h +++ b/palacios/include/palacios/vmm_emulator.h @@ -22,68 +22,18 @@ #ifdef __V3VEE__ -#include #include #include +int v3_emulate_write_op(struct guest_info * info, addr_t write_gva, addr_t write_gpa, addr_t dst_addr, + int (*write_fn)(addr_t guest_addr, void * src, uint_t length, void * priv_data), + void * priv_data); - -struct emulated_page { - addr_t page_addr; - addr_t va; - pte32_t pte; - struct list_head page_list; -}; - -struct saved_page { - addr_t va; - pte32_t pte; - struct list_head page_list; -}; - - -struct write_region { - void * write_data; - - uint_t length; - int (*write)(addr_t write_addr, void * src, uint_t length, void * priv_data); - addr_t write_addr; - void * private_data; - - struct list_head write_list; -}; - - -struct emulation_state { - uint_t num_emulated_pages; - struct list_head emulated_pages; - - uint_t num_saved_pages; - struct list_head saved_pages; - - uint_t num_write_regions; - struct list_head write_regions; - - uint_t running : 1; - uint_t instr_length; - - uint_t tf_enabled : 1; -}; - - -int init_emulator(struct guest_info * info); - - -int v3_emulation_exit_handler(struct guest_info * info); - -int v3_emulate_memory_write(struct guest_info * info, addr_t fault_gva, - int (*write)(addr_t write_addr, void * src, uint_t length, void * priv_data), - addr_t write_addr, void * private_data); -int v3_emulate_memory_read(struct guest_info * info, addr_t fault_gva, - int (*read)(addr_t read_addr, void * dst, uint_t length, void * priv_data), - addr_t read_addr, void * private_data); +int v3_emulate_read_op(struct guest_info * info, addr_t read_gva, addr_t read_gpa, addr_t src_addr, + int (*read_fn)(addr_t guest_addr, void * dst, uint_t length, void * priv_data), + void * priv_data); #endif // !__V3VEE__