X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_dev_mgr.h;h=1dd80311aa5899c60db38cfc1bd942be8f0f2e32;hb=ee75afdf55f45c216a5285eb2d6eadd934aac59c;hp=7e4708f6975f0438262b9fd1849fd1f687fb8356;hpb=3e5e5a12e64630d7a37ed32b8d7e2d993c79f7e0;p=palacios-OLD.git diff --git a/palacios/include/palacios/vmm_dev_mgr.h b/palacios/include/palacios/vmm_dev_mgr.h index 7e4708f..1dd8031 100644 --- a/palacios/include/palacios/vmm_dev_mgr.h +++ b/palacios/include/palacios/vmm_dev_mgr.h @@ -62,6 +62,9 @@ struct vmm_dev_mgr { struct list_head net_list; struct hashtable * net_table; + struct list_head char_list; + struct hashtable * char_table; + struct list_head console_list; struct hashtable * console_table; @@ -158,15 +161,35 @@ struct v3_dev_blk_ops { }; struct v3_dev_net_ops { + /* Backend implemented functions */ int (*send)(uint8_t * buf, uint32_t count, void * private_data, struct vm_device *dest_dev); - int (*receive)(uint8_t * buf, uint32_t count, void * private_data, struct vm_device *src_dev); + void (*start_rx)(void *back_data); + void (*stop_rx)(void *back_data); + + /* Frontend implemented functions */ + int (*recv)(uint8_t * buf, uint32_t count, void * frnt_data); + void (*poll)(struct v3_vm_info * vm, void * frnt_data); + void (*start_tx)(void * frnt_data); + void (*stop_tx)(void * frnt_data); + /* This is ugly... */ + void * frontend_data; }; struct v3_dev_console_ops { }; +struct v3_dev_char_ops { + /* Backend implemented functions */ + int (*write)(uint8_t * buf, uint64_t len, void * private_data); + // int (*read)(uint8_t * buf, uint64_t len, void * private_data); + + /* Frontend Implemented functions */ + int (*push)(uint8_t * buf, uint64_t len, void * private_data); +}; + + int v3_dev_add_blk_frontend(struct v3_vm_info * vm, char * name, int (*connect)(struct v3_vm_info * vm, @@ -175,6 +198,7 @@ int v3_dev_add_blk_frontend(struct v3_vm_info * vm, v3_cfg_tree_t * cfg, void * private_data), void * priv_data); + int v3_dev_connect_blk(struct v3_vm_info * vm, char * frontend_name, struct v3_dev_blk_ops * ops, @@ -197,6 +221,24 @@ int v3_dev_connect_net(struct v3_vm_info * vm, void * private_data); +int v3_dev_add_char_frontend(struct v3_vm_info * vm, + char * name, + int (*connect)(struct v3_vm_info * vm, + void * frontend_data, + struct v3_dev_char_ops * ops, + v3_cfg_tree_t * cfg, + void * private_data, + void ** push_fn_arg), + void * priv_data); + +int v3_dev_connect_char(struct v3_vm_info * vm, + char * frontend_name, + struct v3_dev_char_ops * ops, + v3_cfg_tree_t * cfg, + void * private_data, + void ** push_fn_arg); + + #endif // ! __V3VEE__ #endif