Commit 3161addd authored by Maya Erez's avatar Maya Erez Committed by Kalle Valo

wil6210: prevent access to 11AD device if resume fails

In case wil6210 resume fails, wil6210 suspend function will try
to access the suspended device in the next kernel suspend.
To prevent that, add wil_status_suspended flag to indicate if the
device is already suspended and clear it only if the resume succeeds.
Signed-off-by: default avatarMaya Erez <qca_merez@qca.qualcomm.com>
Signed-off-by: default avatarKalle Valo <kvalo@qca.qualcomm.com>
parent 98a830a9
...@@ -71,6 +71,11 @@ int wil_suspend(struct wil6210_priv *wil, bool is_runtime) ...@@ -71,6 +71,11 @@ int wil_suspend(struct wil6210_priv *wil, bool is_runtime)
wil_dbg_pm(wil, "suspend: %s\n", is_runtime ? "runtime" : "system"); wil_dbg_pm(wil, "suspend: %s\n", is_runtime ? "runtime" : "system");
if (test_bit(wil_status_suspended, wil->status)) {
wil_dbg_pm(wil, "trying to suspend while suspended\n");
return 0;
}
/* if netif up, hardware is alive, shut it down */ /* if netif up, hardware is alive, shut it down */
if (ndev->flags & IFF_UP) { if (ndev->flags & IFF_UP) {
rc = wil_down(wil); rc = wil_down(wil);
...@@ -86,10 +91,14 @@ int wil_suspend(struct wil6210_priv *wil, bool is_runtime) ...@@ -86,10 +91,14 @@ int wil_suspend(struct wil6210_priv *wil, bool is_runtime)
if (wil->platform_ops.suspend) { if (wil->platform_ops.suspend) {
rc = wil->platform_ops.suspend(wil->platform_handle); rc = wil->platform_ops.suspend(wil->platform_handle);
if (rc) if (rc) {
wil_enable_irq(wil); wil_enable_irq(wil);
goto out;
}
} }
set_bit(wil_status_suspended, wil->status);
out: out:
wil_dbg_pm(wil, "suspend: %s => %d\n", wil_dbg_pm(wil, "suspend: %s => %d\n",
is_runtime ? "runtime" : "system", rc); is_runtime ? "runtime" : "system", rc);
...@@ -117,10 +126,13 @@ int wil_resume(struct wil6210_priv *wil, bool is_runtime) ...@@ -117,10 +126,13 @@ int wil_resume(struct wil6210_priv *wil, bool is_runtime)
/* if netif up, bring hardware up /* if netif up, bring hardware up
* During open(), IFF_UP set after actual device method * During open(), IFF_UP set after actual device method
* invocation. This prevent recursive call to wil_up() * invocation. This prevent recursive call to wil_up().
* wil_status_suspended will be cleared in wil_reset
*/ */
if (ndev->flags & IFF_UP) if (ndev->flags & IFF_UP)
rc = wil_up(wil); rc = wil_up(wil);
else
clear_bit(wil_status_suspended, wil->status);
out: out:
wil_dbg_pm(wil, "resume: %s => %d\n", wil_dbg_pm(wil, "resume: %s => %d\n",
......
...@@ -412,6 +412,7 @@ enum { /* for wil6210_priv.status */ ...@@ -412,6 +412,7 @@ enum { /* for wil6210_priv.status */
wil_status_irqen, /* FIXME: interrupts enabled - for debug */ wil_status_irqen, /* FIXME: interrupts enabled - for debug */
wil_status_napi_en, /* NAPI enabled protected by wil->mutex */ wil_status_napi_en, /* NAPI enabled protected by wil->mutex */
wil_status_resetting, /* reset in progress */ wil_status_resetting, /* reset in progress */
wil_status_suspended, /* suspend completed, device is suspended */
wil_status_last /* keep last */ wil_status_last /* keep last */
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment