X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_emulator.h;h=46836cd888f577e1043f20092ba88c0973bb2fd8;hb=6541ca672276d841db22cc18a003303cf517ea89;hp=45cfa44176141a591c3589b13ba62ce2cfe45e5c;hpb=7cdedeb7a01b51c5242cce94924f2ea246008e7d;p=palacios.git diff --git a/palacios/include/palacios/vmm_emulator.h b/palacios/include/palacios/vmm_emulator.h index 45cfa44..46836cd 100644 --- a/palacios/include/palacios/vmm_emulator.h +++ b/palacios/include/palacios/vmm_emulator.h @@ -22,68 +22,19 @@ #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 v3_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), + int (*write_fn)(addr_t guest_addr, void * src, uint_t length, void * priv_data), + void * priv_data); #endif // !__V3VEE__