X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmm_vnet.h;h=97486748a303ff4bc8176f651dbc33fed73be2f0;hb=06577917122b2b412618525d0f36fbd2438e9bae;hp=86af1a2c984c8b77f3be66fc13620c0895e4d52f;hpb=e49df33562b190c348b3a117044136c704442c6b;p=palacios-OLD.git diff --git a/palacios/include/palacios/vmm_vnet.h b/palacios/include/palacios/vmm_vnet.h index 86af1a2..9748674 100644 --- a/palacios/include/palacios/vmm_vnet.h +++ b/palacios/include/palacios/vmm_vnet.h @@ -25,34 +25,31 @@ #include #include -#define MAC_ANY 0 -#define MAC_NOT 1 -#define MAC_NONE 2 -#define MAC_ADDR 3 +#define MAC_NOSET 0 +#define MAC_ANY 11 +#define MAC_NOT 12 +#define MAC_NONE 13 +#define MAC_ADDR 14 -#define LINK_INTERFACE 0 -#define LINK_EDGE 1 -#define LINK_ANY 2 +#define LINK_NOSET 0 +#define LINK_INTERFACE 11 +#define LINK_EDGE 12 +#define LINK_ANY 13 -#define VNET_HASH_SIZE 17 -#define VMM_DRIVERN 1 -#define GUEST_DRIVERN 0 - -#define HOST_LNX_BRIDGE 1 -#define CTL_VM_BRIDGE 2 +#define VNET_HASH_SIZE 17 //routing table entry struct v3_vnet_route { - uint8_t src_mac[6]; - uint8_t dst_mac[6]; + uint8_t src_mac[ETH_ALEN]; + uint8_t dst_mac[ETH_ALEN]; uint8_t src_mac_qual; uint8_t dst_mac_qual; - uint32_t dst_id; + int dst_id; uint8_t dst_type; - uint32_t src_id; + int src_id; uint8_t src_type; } __attribute__((packed)); @@ -78,17 +75,6 @@ struct v3_vnet_pkt { } __attribute__((packed)); } __attribute__((packed)); - -struct v3_vnet_dev_ops { - int (*input)(struct v3_vm_info * vm, - struct v3_vnet_pkt * pkt, - void * dev_data); - void (*poll) (struct v3_vm_info * vm, void * dev_data); - - void (*start_tx)(void * dev_data); - void (*stop_tx)(void * dev_data); -}; - struct v3_vnet_bridge_ops { int (*input)(struct v3_vm_info * vm, struct v3_vnet_pkt * pkt, @@ -97,25 +83,40 @@ struct v3_vnet_bridge_ops { void * private_data); }; -int v3_init_vnet(void); -void v3_deinit_vnet(void); - -int v3_vnet_send_pkt(struct v3_vnet_pkt * pkt, void * private_data); - -void v3_vnet_poll(struct v3_vm_info * vm); +#define HOST_LNX_BRIDGE 1 +#define CTL_VM_BRIDGE 2 -int v3_vnet_add_route(struct v3_vnet_route route); int v3_vnet_add_bridge(struct v3_vm_info * vm, struct v3_vnet_bridge_ops * ops, uint8_t type, void * priv_data); +int v3_vnet_add_route(struct v3_vnet_route route); +int v3_vnet_send_pkt(struct v3_vnet_pkt * pkt, void * private_data); +int v3_vnet_find_dev(uint8_t * mac); + +#ifdef __V3VEE__ + +#define VMM_DRIVERN 1 +#define GUEST_DRIVERN 0 + +struct v3_vnet_dev_ops { + int (*input)(struct v3_vm_info * vm, + struct v3_vnet_pkt * pkt, + void * dev_data); + void (*poll) (struct v3_vm_info * vm, void * dev_data); +}; +int v3_init_vnet(void); +void v3_deinit_vnet(void); + +void v3_vnet_poll(struct v3_vm_info * vm); -int v3_vnet_add_dev(struct v3_vm_info * info, uint8_t mac[6], +int v3_vnet_add_dev(struct v3_vm_info * info, uint8_t * mac, struct v3_vnet_dev_ops * ops, void * priv_data); int v3_vnet_del_dev(int dev_id); +#endif #endif