X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_dev_mgr.h;h=11b0d2880ebe11f37e42700f60a507b9ffab92d0;hb=a5c5675571882a9b8a7594ef07fe303b195ef9ae;hp=0caef8b1ee04fc92b8e4e6dfb2523f9f3416075e;hpb=df58bd3c484a52b1e166dc28e7b9b6fd94e5a023;p=palacios.git diff --git a/palacios/include/palacios/vmm_dev_mgr.h b/palacios/include/palacios/vmm_dev_mgr.h index 0caef8b..11b0d28 100644 --- a/palacios/include/palacios/vmm_dev_mgr.h +++ b/palacios/include/palacios/vmm_dev_mgr.h @@ -1,6 +1,8 @@ #ifndef _VMM_DEV_MGR #define _VMM_DEV_MGR +#ifdef __V3VEE__ + #include #include #include @@ -19,12 +21,25 @@ struct vmm_dev_mgr { uint_t num_mem_hooks; struct list_head mem_hooks; - uint_t num_irq_hooks; - struct list_head irq_hooks; }; +// Registration of devices + +// +// The following device manager functions should only be called +// when the guest is stopped +// + +int v3_attach_device(struct guest_info *vm, struct vm_device * dev); +int v3_unattach_device(struct vm_device *dev); + + + + + + struct dev_io_hook { ushort_t port; @@ -34,10 +49,7 @@ struct dev_io_hook { struct vm_device * dev; // Do not touch anything below this - /* - struct dev_io_hook *dev_next, *dev_prev; - struct dev_io_hook *mgr_next, *mgr_prev; - */ + struct list_head dev_list; struct list_head mgr_list; }; @@ -53,49 +65,15 @@ struct dev_mem_hook { struct list_head mgr_list; }; -struct dev_irq_hook { - uint_t irq; - int (*handler)(uint_t irq, struct vm_device * dev); +int dev_mgr_init(struct guest_info * info); +int dev_mgr_deinit(struct guest_info * info); - struct vm_device * dev; - - struct list_head dev_list; - struct list_head mgr_list; -}; - -// Registration of devices - -// -// The following device manager functions should only be called -// when the guest is stopped -// - -int dev_mgr_init(struct vmm_dev_mgr *mgr); -int dev_mgr_deinit(struct vmm_dev_mgr * mgr); - - - -int attach_device(struct guest_info *vm, struct vm_device * dev); -int unattach_device(struct vm_device *dev); - - -int dev_mgr_add_device(struct vmm_dev_mgr * mgr, struct vm_device * dev); -int dev_mgr_remove_device(struct vmm_dev_mgr * mgr, struct vm_device * dev); - - -/* - int dev_mgr_add_io_hook(struct vmm_dev_mgr * mgr, struct dev_io_hook * hook); - int dev_mgr_remove_io_hook(struct vmm_dev_mgr * mgr, struct dev_io_hook * hook); - int dev_add_io_hook(struct vmm_dev_mgr * mgr, struct dev_io_hook * hook); - int dev_remove_io_hook(struct vmm_dev_mgr * mgr, struct dev_io_hook * hook); - struct dev_io_hook * dev_find_io_hook(struct vm_device * dev, ushort_t port); - struct dev_io_hook * dev_mgr_find_io_hook(struct vmm_dev_mgr * mgr, ushort_t port) -*/ - -void PrintDebugDevMgr(struct vmm_dev_mgr * mgr); +void PrintDebugDevMgr(struct guest_info * info); void PrintDebugDev(struct vm_device * dev); void PrintDebugDevIO(struct vm_device * dev); void PrintDebugDevMgrIO(struct vmm_dev_mgr * mgr); +#endif // ! __V3VEE__ + #endif