Commit bbb2adc7 authored by Vladimir Kondratiev's avatar Vladimir Kondratiev Committed by John W. Linville

wil6210: check error in wil_target_reset()

When resetting target in wil_target_reset(), error may occur.
Indicate error via error code. In case of error, don't attempt to further
interact with card, specifically don't attempt firmware download or
interrupts enabling.

Move wil_rx_fini() to be always executed to prevent memory leak.
Signed-off-by: default avatarVladimir Kondratiev <qca_vkondrat@qca.qualcomm.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 02525a79
...@@ -309,7 +309,7 @@ void wil_priv_deinit(struct wil6210_priv *wil) ...@@ -309,7 +309,7 @@ void wil_priv_deinit(struct wil6210_priv *wil)
destroy_workqueue(wil->wmi_wq); destroy_workqueue(wil->wmi_wq);
} }
static void wil_target_reset(struct wil6210_priv *wil) static int wil_target_reset(struct wil6210_priv *wil)
{ {
int delay = 0; int delay = 0;
u32 hw_state; u32 hw_state;
...@@ -395,7 +395,7 @@ static void wil_target_reset(struct wil6210_priv *wil) ...@@ -395,7 +395,7 @@ static void wil_target_reset(struct wil6210_priv *wil)
if (delay++ > 100) { if (delay++ > 100) {
wil_err(wil, "Reset not completed, hw_state 0x%08x\n", wil_err(wil, "Reset not completed, hw_state 0x%08x\n",
hw_state); hw_state);
return; return -ETIME;
} }
} while (hw_state != HW_MACHINE_BOOT_DONE); } while (hw_state != HW_MACHINE_BOOT_DONE);
...@@ -407,6 +407,7 @@ static void wil_target_reset(struct wil6210_priv *wil) ...@@ -407,6 +407,7 @@ static void wil_target_reset(struct wil6210_priv *wil)
wmb(); /* order is important here */ wmb(); /* order is important here */
wil_dbg_misc(wil, "Reset completed in %d ms\n", delay); wil_dbg_misc(wil, "Reset completed in %d ms\n", delay);
return 0;
#undef R #undef R
#undef W #undef W
...@@ -471,10 +472,11 @@ int wil_reset(struct wil6210_priv *wil) ...@@ -471,10 +472,11 @@ int wil_reset(struct wil6210_priv *wil)
flush_workqueue(wil->wmi_wq_conn); flush_workqueue(wil->wmi_wq_conn);
flush_workqueue(wil->wmi_wq); flush_workqueue(wil->wmi_wq);
/* TODO: put MAC in reset */ rc = wil_target_reset(wil);
wil_target_reset(wil);
wil_rx_fini(wil); wil_rx_fini(wil);
if (rc)
return rc;
/* init after reset */ /* init after reset */
wil->pending_connect_cid = -1; wil->pending_connect_cid = -1;
......
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