Search Linux Wireless

Re: [PATCH 3/4] wlcore: do not send stop fwlog cmd if fw is hanged

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, May 8, 2012 at 2:02 PM, Yoni Divinsky <yoni.divinsky@xxxxxx> wrote:
> 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: Yoni Divinsky <yoni.divinsky@xxxxxx>
> ---
>  drivers/net/wireless/ti/wlcore/main.c   |    9 +++++++--
>  drivers/net/wireless/ti/wlcore/wlcore.h |    1 +
>  2 files changed, 8 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/net/wireless/ti/wlcore/main.c b/drivers/net/wireless/ti/wlcore/main.c
> index 45fe911..b8dcef3 100644
> --- a/drivers/net/wireless/ti/wlcore/main.c
> +++ b/drivers/net/wireless/ti/wlcore/main.c
> @@ -582,6 +582,7 @@ static irqreturn_t wl1271_irq(int irq, void *cookie)
>                if (unlikely(intr & WL1271_ACX_INTR_WATCHDOG)) {
>                        wl1271_error("watchdog interrupt received! "
>                                     "starting recovery.");
> +                       wl->watchdog_recovery = true;
>                        wl12xx_queue_recovery_work(wl);
>
>                        /* restarting the chip. ignore any other interrupt. */
> @@ -820,10 +821,12 @@ static void wl12xx_read_fwlog_panic(struct wl1271 *wl)
>
>        /*
>         * 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);
> +       else
> +               goto out;
>
>        /* Read the first memory block address */
>        wl12xx_fw_status(wl, wl->fw_status);
> @@ -926,6 +929,7 @@ static void wl1271_recovery_work(struct work_struct *work)
>         * to restart the HW.
>         */
>        ieee80211_wake_queues(wl->hw);
> +       wl->watchdog_recovery = false;
>        return;

Please change watchdog_recovery only inside the wl->mutex.

>  out_unlock:
>        mutex_unlock(&wl->mutex);

Please change watchdog_recovery to false here as well.

> @@ -1049,6 +1053,7 @@ int wl1271_plt_start(struct wl1271 *wl)
>
>                wl->plt = true;
>                wl->state = WL1271_STATE_ON;
> +               wl->watchdog_recovery = false;
>                wl1271_notice("firmware booted in PLT mode (%s)",
>                              wl->chip.fw_ver_str);

This is not needed here once watchdog_recovery is always set to false
indie recovery_work().

Arik
--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Wireless Personal Area Network]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite Hiking]     [MIPS Linux]     [ARM Linux]     [Linux RAID]

  Powered by Linux