From: Lei Xia Date: Thu, 27 Jan 2011 19:50:03 +0000 (-0600) Subject: Fix to the VNET clean code X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=commitdiff_plain;h=da5c386c3153196bd0aa4610d8ad513d3f7f1bbc;p=palacios.git Fix to the VNET clean code --- diff --git a/palacios/src/palacios/vmm_vnet_core.c b/palacios/src/palacios/vmm_vnet_core.c index 60b5569..18720b1 100644 --- a/palacios/src/palacios/vmm_vnet_core.c +++ b/palacios/src/palacios/vmm_vnet_core.c @@ -264,6 +264,27 @@ int v3_vnet_add_route(struct v3_vnet_route route) { } +/* delete all route entries with specfied src or dst device id */ +static void inline del_routes(int dev_id){ + struct vnet_route_info * route = NULL; + unsigned long flags; + + flags = v3_lock_irqsave(vnet_state.lock); + + list_for_each_entry(route, &(vnet_state.routes), node) { + if((route->route_def.dst_type == LINK_INTERFACE && + route->route_def.dst_id == dev_id) || + (route->route_def.src_type == LINK_INTERFACE && + route->route_def.src_id == dev_id)){ + + list_del(&(route->node)); + list_del(&(route->match_node)); + V3_Free(route); + } + } + + v3_unlock_irqrestore(vnet_state.lock, flags); +} /* At the end allocate a route_list * This list will be inserted into the cache so we don't need to free it @@ -518,6 +539,7 @@ int v3_vnet_del_dev(int dev_id){ dev = find_dev_by_id(dev_id); if (dev != NULL){ list_del(&(dev->node)); + del_routes(dev_id); } v3_unlock_irqrestore(vnet_state.lock, flags);