提交 afbe3718 编写于 作者: Y Yoni Divinsky 提交者: Luciano Coelho

wlcore: do not send stop fwlog cmd if fw is hanged

If the driver received a watchdog interrupt then the
assumption is that the fw is hanged. Avoid sending
the stop fwlog command in case of a watchdog recovey
to avoid waiting for the 2 seconds timeout of the command.
Signed-off-by: NYoni Divinsky <yoni.divinsky@ti.com>
Signed-off-by: NLuciano Coelho <coelho@ti.com>
上级 a1c597f2
...@@ -544,6 +544,7 @@ static irqreturn_t wl1271_irq(int irq, void *cookie) ...@@ -544,6 +544,7 @@ static irqreturn_t wl1271_irq(int irq, void *cookie)
if (unlikely(intr & WL1271_ACX_INTR_WATCHDOG)) { if (unlikely(intr & WL1271_ACX_INTR_WATCHDOG)) {
wl1271_error("watchdog interrupt received! " wl1271_error("watchdog interrupt received! "
"starting recovery."); "starting recovery.");
wl->watchdog_recovery = true;
wl12xx_queue_recovery_work(wl); wl12xx_queue_recovery_work(wl);
/* restarting the chip. ignore any other interrupt. */ /* restarting the chip. ignore any other interrupt. */
...@@ -782,10 +783,12 @@ static void wl12xx_read_fwlog_panic(struct wl1271 *wl) ...@@ -782,10 +783,12 @@ static void wl12xx_read_fwlog_panic(struct wl1271 *wl)
/* /*
* Make sure the chip is awake and the logger isn't active. * Make sure the chip is awake and the logger isn't active.
* This might fail if the firmware hanged. * Do not send a stop fwlog command if the fw is hanged.
*/ */
if (!wl1271_ps_elp_wakeup(wl)) if (!wl1271_ps_elp_wakeup(wl) && !wl->watchdog_recovery)
wl12xx_cmd_stop_fwlog(wl); wl12xx_cmd_stop_fwlog(wl);
else
goto out;
/* Read the first memory block address */ /* Read the first memory block address */
wl12xx_fw_status(wl, wl->fw_status_1, wl->fw_status_2); wl12xx_fw_status(wl, wl->fw_status_1, wl->fw_status_2);
...@@ -879,6 +882,7 @@ static void wl1271_recovery_work(struct work_struct *work) ...@@ -879,6 +882,7 @@ static void wl1271_recovery_work(struct work_struct *work)
vif = wl12xx_wlvif_to_vif(wlvif); vif = wl12xx_wlvif_to_vif(wlvif);
__wl1271_op_remove_interface(wl, vif, false); __wl1271_op_remove_interface(wl, vif, false);
} }
wl->watchdog_recovery = false;
mutex_unlock(&wl->mutex); mutex_unlock(&wl->mutex);
wl1271_op_stop(wl->hw); wl1271_op_stop(wl->hw);
...@@ -893,6 +897,7 @@ static void wl1271_recovery_work(struct work_struct *work) ...@@ -893,6 +897,7 @@ static void wl1271_recovery_work(struct work_struct *work)
wlcore_wake_queues(wl, WLCORE_QUEUE_STOP_REASON_FW_RESTART); wlcore_wake_queues(wl, WLCORE_QUEUE_STOP_REASON_FW_RESTART);
return; return;
out_unlock: out_unlock:
wl->watchdog_recovery = false;
mutex_unlock(&wl->mutex); mutex_unlock(&wl->mutex);
} }
......
...@@ -252,6 +252,7 @@ struct wl1271 { ...@@ -252,6 +252,7 @@ struct wl1271 {
/* Hardware recovery work */ /* Hardware recovery work */
struct work_struct recovery_work; struct work_struct recovery_work;
bool watchdog_recovery;
/* Pointer that holds DMA-friendly block for the mailbox */ /* Pointer that holds DMA-friendly block for the mailbox */
struct event_mailbox *mbox; struct event_mailbox *mbox;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册