提交 acc5efbc 编写于 作者: P Patrick McHardy 提交者: David S. Miller

[VLAN]: Clean up unregister_vlan_dev

Save two levels of indentation by aborting on error conditions,
remove unnecessary initialization to NULL and remove two obvious
comments.
Signed-off-by: NPatrick McHardy <kaber@trash.net>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 69ab4b7d
...@@ -142,63 +142,55 @@ static void vlan_rcu_free(struct rcu_head *rcu) ...@@ -142,63 +142,55 @@ static void vlan_rcu_free(struct rcu_head *rcu)
static int unregister_vlan_dev(struct net_device *real_dev, static int unregister_vlan_dev(struct net_device *real_dev,
unsigned short vlan_id) unsigned short vlan_id)
{ {
struct net_device *dev = NULL; struct net_device *dev;
int real_dev_ifindex = real_dev->ifindex; int real_dev_ifindex = real_dev->ifindex;
struct vlan_group *grp; struct vlan_group *grp;
int i, ret; unsigned int i;
int ret;
/* sanity check */
if (vlan_id >= VLAN_VID_MASK) if (vlan_id >= VLAN_VID_MASK)
return -EINVAL; return -EINVAL;
ASSERT_RTNL(); ASSERT_RTNL();
grp = __vlan_find_group(real_dev_ifindex); grp = __vlan_find_group(real_dev_ifindex);
if (!grp)
return -ENOENT;
ret = 0; dev = vlan_group_get_device(grp, vlan_id);
if (!dev)
if (grp) { return -ENOENT;
dev = vlan_group_get_device(grp, vlan_id);
if (dev) {
/* Remove proc entry */
vlan_proc_rem_dev(dev);
/* Take it out of our own structures, but be sure to
* interlock with HW accelerating devices or SW vlan
* input packet processing.
*/
if (real_dev->features & NETIF_F_HW_VLAN_FILTER)
real_dev->vlan_rx_kill_vid(real_dev, vlan_id);
vlan_group_set_device(grp, vlan_id, NULL); vlan_proc_rem_dev(dev);
synchronize_net();
/* Take it out of our own structures, but be sure to interlock with
* HW accelerating devices or SW vlan input packet processing.
*/
if (real_dev->features & NETIF_F_HW_VLAN_FILTER)
real_dev->vlan_rx_kill_vid(real_dev, vlan_id);
/* Caller unregisters (and if necessary, puts) vlan_group_set_device(grp, vlan_id, NULL);
* VLAN device, but we get rid of the reference to synchronize_net();
* real_dev here.
*/
dev_put(real_dev);
/* If the group is now empty, kill off the /* Caller unregisters (and if necessary, puts) VLAN device, but we
* group. * get rid of the reference to real_dev here.
*/ */
for (i = 0; i < VLAN_VID_MASK; i++) dev_put(real_dev);
if (vlan_group_get_device(grp, i))
break;
if (i == VLAN_VID_MASK) { /* If the group is now empty, kill off the group. */
if (real_dev->features & NETIF_F_HW_VLAN_RX) ret = 0;
real_dev->vlan_rx_register(real_dev, NULL); for (i = 0; i < VLAN_VID_MASK; i++)
if (vlan_group_get_device(grp, i))
break;
hlist_del_rcu(&grp->hlist); if (i == VLAN_VID_MASK) {
if (real_dev->features & NETIF_F_HW_VLAN_RX)
real_dev->vlan_rx_register(real_dev, NULL);
/* Free the group, after all cpu's are done. */ hlist_del_rcu(&grp->hlist);
call_rcu(&grp->rcu, vlan_rcu_free);
grp = NULL; /* Free the group, after all cpu's are done. */
ret = 1; call_rcu(&grp->rcu, vlan_rcu_free);
} ret = 1;
}
} }
return ret; return ret;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册