Commit 77565794 authored by Vasanthakumar Thiagarajan's avatar Vasanthakumar Thiagarajan Committed by Kalle Valo

ath6kl: Recover from "wmi ctrl ep is full" condition

In some error conditions, fw pauses HTC pipes which would
result in control endpoint full condition. When we hit this
case, most of the time the device will be unusable. Re-initialize
the target to recover from this situation.
Signed-off-by: default avatarVasanthakumar Thiagarajan <vthiagar@qca.qualcomm.com>
Signed-off-by: default avatarKalle Valo <kvalo@qca.qualcomm.com>
parent 92332993
...@@ -660,6 +660,7 @@ enum ath6kl_state { ...@@ -660,6 +660,7 @@ enum ath6kl_state {
enum ath6kl_fw_err { enum ath6kl_fw_err {
ATH6KL_FW_ASSERT, ATH6KL_FW_ASSERT,
ATH6KL_FW_HB_RESP_FAILURE, ATH6KL_FW_HB_RESP_FAILURE,
ATH6KL_FW_EP_FULL,
}; };
struct ath6kl { struct ath6kl {
......
...@@ -30,6 +30,8 @@ static void ath6kl_recovery_work(struct work_struct *work) ...@@ -30,6 +30,8 @@ static void ath6kl_recovery_work(struct work_struct *work)
ath6kl_init_hw_restart(ar); ath6kl_init_hw_restart(ar);
ar->state = ATH6KL_STATE_ON; ar->state = ATH6KL_STATE_ON;
clear_bit(WMI_CTRL_EP_FULL, &ar->flag);
ar->fw_recovery.err_reason = 0; ar->fw_recovery.err_reason = 0;
if (ar->fw_recovery.enable) if (ar->fw_recovery.enable)
......
...@@ -594,6 +594,7 @@ enum htc_send_full_action ath6kl_tx_queue_full(struct htc_target *target, ...@@ -594,6 +594,7 @@ enum htc_send_full_action ath6kl_tx_queue_full(struct htc_target *target,
*/ */
set_bit(WMI_CTRL_EP_FULL, &ar->flag); set_bit(WMI_CTRL_EP_FULL, &ar->flag);
ath6kl_err("wmi ctrl ep is full\n"); ath6kl_err("wmi ctrl ep is full\n");
ath6kl_recovery_err_notify(ar, ATH6KL_FW_EP_FULL);
return action; return action;
} }
......
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