X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_dev_mgr.h;h=1e3f68b5dc70b3d64a6b7ec2899f0baa74e7bec3;hb=5e81abea907908ab9bdc0cb57a3537f05db77b5e;hp=a952e9feb995c17858ae06b3ed436aafb9f7f7b4;hpb=e2964f7234daa3429275c039769a313f0870c212;p=palacios.git diff --git a/palacios/include/palacios/vmm_dev_mgr.h b/palacios/include/palacios/vmm_dev_mgr.h index a952e9f..1e3f68b 100644 --- a/palacios/include/palacios/vmm_dev_mgr.h +++ b/palacios/include/palacios/vmm_dev_mgr.h @@ -26,7 +26,9 @@ #include #include #include +#include #include +#include struct v3_vm_info; @@ -48,9 +50,8 @@ struct vm_device { struct list_head dev_link; - - uint_t num_io_hooks; - struct list_head io_hooks; + uint_t num_res_hooks; + struct list_head res_hooks; }; @@ -75,10 +76,6 @@ struct vmm_dev_mgr { int v3_create_device(struct v3_vm_info * vm, const char * dev_name, v3_cfg_tree_t * cfg); - -void v3_free_device(struct vm_device * dev); - - struct vm_device * v3_find_dev(struct v3_vm_info * info, const char * dev_name); @@ -92,18 +89,22 @@ struct vm_device * v3_find_dev(struct v3_vm_info * info, const char * dev_name); int v3_init_dev_mgr(struct v3_vm_info * vm); -int v3_dev_mgr_deinit(struct v3_vm_info * vm); +int v3_deinit_dev_mgr(struct v3_vm_info * vm); +int v3_free_vm_devices(struct v3_vm_info * vm); -int v3_init_devices(); + + +int V3_init_devices(); +int V3_deinit_devices(); struct v3_device_ops { - int (*free)(struct vm_device * dev); + int (*free)(void * private_data); //int (*save)(struct vm_device *dev, struct *iostream); //int (*restore)(struct vm_device *dev, struct *iostream); @@ -115,17 +116,32 @@ struct v3_device_ops { int v3_dev_hook_io(struct vm_device * dev, - ushort_t port, - int (*read)(struct guest_info * core, ushort_t port, void * dst, uint_t length, void * priv_data), - int (*write)(struct guest_info * core, ushort_t port, void * src, uint_t length, void * priv_data)); + uint16_t port, + int (*read)(struct guest_info * core, uint16_t port, void * dst, uint_t length, void * priv_data), + int (*write)(struct guest_info * core, uint16_t port, void * src, uint_t length, void * priv_data)); int v3_dev_unhook_io(struct vm_device * dev, - ushort_t port); + uint16_t port); + + +int v3_dev_hook_msr(struct vm_device * dev, + uint32_t msr, + int (*read)(struct guest_info * core, uint32_t msr, struct v3_msr * dst, void * priv_data), + int (*write)(struct guest_info * core, uint32_t msr, struct v3_msr src, void * priv_data)); + +int v3_dev_unhook_msr(struct vm_device * dev, + uint32_t msr); + + + + +struct vm_device * v3_add_device(struct v3_vm_info * vm, char * name, + struct v3_device_ops * ops, void * private_data); +int v3_remove_device(struct vm_device * dev); int v3_attach_device(struct v3_vm_info * vm, struct vm_device * dev); int v3_detach_device(struct vm_device * dev); - struct vm_device * v3_allocate_device(char * name, struct v3_device_ops * ops, void * private_data); @@ -170,12 +186,14 @@ struct v3_dev_net_ops { /* This is ugly... */ void * frontend_data; + char fnt_mac[ETH_ALEN]; }; struct v3_dev_console_ops { int (*update_screen)(uint_t x, uint_t y, uint_t length, uint8_t * fb_data, void * private_data); int (*update_cursor)(uint_t x, uint_t y, void * private_data); int (*scroll)(int rows, void * private_data); + int (*set_text_resolution)(int cols, int rows, void * private_data); /* frontend implemented functions */ int (*get_screen)(uint_t x, uint_t y, uint_t length, void * frontend_data);