提交 f2c0d8df 编写于 作者: R Ron Mercer 提交者: David S. Miller

qlge: Protect reset recovery with rtnl_lock().

Move the call to rtnl_lock() to before the internal call to
ql_adapter_down()/ql_adapter_up().  This prevents collisions that can
happen when recovering from an asic error.
Signed-off-by: NRon Mercer <ron.mercer@qlogic.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 06a49f72
...@@ -3703,7 +3703,7 @@ static void ql_asic_reset_work(struct work_struct *work) ...@@ -3703,7 +3703,7 @@ static void ql_asic_reset_work(struct work_struct *work)
struct ql_adapter *qdev = struct ql_adapter *qdev =
container_of(work, struct ql_adapter, asic_reset_work.work); container_of(work, struct ql_adapter, asic_reset_work.work);
int status; int status;
rtnl_lock();
status = ql_adapter_down(qdev); status = ql_adapter_down(qdev);
if (status) if (status)
goto error; goto error;
...@@ -3711,12 +3711,12 @@ static void ql_asic_reset_work(struct work_struct *work) ...@@ -3711,12 +3711,12 @@ static void ql_asic_reset_work(struct work_struct *work)
status = ql_adapter_up(qdev); status = ql_adapter_up(qdev);
if (status) if (status)
goto error; goto error;
rtnl_unlock();
return; return;
error: error:
QPRINTK(qdev, IFUP, ALERT, QPRINTK(qdev, IFUP, ALERT,
"Driver up/down cycle failed, closing device\n"); "Driver up/down cycle failed, closing device\n");
rtnl_lock();
set_bit(QL_ADAPTER_UP, &qdev->flags); set_bit(QL_ADAPTER_UP, &qdev->flags);
dev_close(qdev->ndev); dev_close(qdev->ndev);
rtnl_unlock(); rtnl_unlock();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册