提交 66f4bc81 编写于 作者: D David S. Miller

Merge branch 'ldmsw-fixes'

Shannon Nelson says:

====================
ldmvsw: port removal stability

Under heavy reboot stress testing we found a couple of timing issues
when removing the device that could cause the kernel great heartburn,
addressed by these two patches.
====================
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
...@@ -411,13 +411,14 @@ static int vsw_port_remove(struct vio_dev *vdev) ...@@ -411,13 +411,14 @@ static int vsw_port_remove(struct vio_dev *vdev)
if (port) { if (port) {
del_timer_sync(&port->vio.timer); del_timer_sync(&port->vio.timer);
del_timer_sync(&port->clean_timer);
napi_disable(&port->napi); napi_disable(&port->napi);
unregister_netdev(port->dev);
list_del_rcu(&port->list); list_del_rcu(&port->list);
synchronize_rcu(); synchronize_rcu();
del_timer_sync(&port->clean_timer);
spin_lock_irqsave(&port->vp->lock, flags); spin_lock_irqsave(&port->vp->lock, flags);
sunvnet_port_rm_txq_common(port); sunvnet_port_rm_txq_common(port);
spin_unlock_irqrestore(&port->vp->lock, flags); spin_unlock_irqrestore(&port->vp->lock, flags);
...@@ -427,7 +428,6 @@ static int vsw_port_remove(struct vio_dev *vdev) ...@@ -427,7 +428,6 @@ static int vsw_port_remove(struct vio_dev *vdev)
dev_set_drvdata(&vdev->dev, NULL); dev_set_drvdata(&vdev->dev, NULL);
unregister_netdev(port->dev);
free_netdev(port->dev); free_netdev(port->dev);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册