All of lore.kernel.org
 help / color / mirror / Atom feed
From: Gertjan van Wingerde <gwingerde@gmail.com>
To: Stanislaw Gruszka <sgruszka@redhat.com>
Cc: "John W. Linville" <linville@tuxdriver.com>,
	linux-wireless@vger.kernel.org, users@rt2x00.serialmonkey.com,
	Jakub Kicinski <moorray@wp.pl>
Subject: Re: [PATCH] rt2x00: rt2800usb: schedule txdone work on timeout
Date: Tue, 20 Mar 2012 05:23:34 +0100	[thread overview]
Message-ID: <4F680646.4040707@gmail.com> (raw)
In-Reply-To: <1332146385-10330-1-git-send-email-sgruszka@redhat.com>

On 03/19/12 09:39, Stanislaw Gruszka wrote:
> This is fix for my current commit
> ed61e2b02027935520d1be884fac0b2ffce8379a
> "rt2x00: rt2800usb: rework txdone code"
> 
> We should schedule txdone work on timeout, otherwise if newer get
> tx status from hardware, we will never report tx status to mac80211
> and eventually never wakeup tx queue.
> 
> Reported-by: Jakub Kicinski <moorray@wp.pl>
> Signed-off-by: Stanislaw Gruszka <sgruszka@redhat.com>

Acked-by: Gertjan van Wingerde <gwingerde@gmail.com>

> ---
>  drivers/net/wireless/rt2x00/rt2800usb.c |    8 +++++++-
>  1 files changed, 7 insertions(+), 1 deletions(-)
> 
> diff --git a/drivers/net/wireless/rt2x00/rt2800usb.c b/drivers/net/wireless/rt2x00/rt2800usb.c
> index cd490ab..f97f846 100644
> --- a/drivers/net/wireless/rt2x00/rt2800usb.c
> +++ b/drivers/net/wireless/rt2x00/rt2800usb.c
> @@ -163,7 +163,13 @@ static bool rt2800usb_tx_sta_fifo_read_completed(struct rt2x00_dev *rt2x00dev,
>  
>  		/* Reschedule urb to read TX status again instantly */
>  		return true;
> -	} else if (rt2800usb_txstatus_pending(rt2x00dev)) {
> +	}
> +
> +	/* Check if there is any entry that timedout waiting on TX status */
> +	if (rt2800usb_txstatus_timeout(rt2x00dev))
> +		queue_work(rt2x00dev->workqueue, &rt2x00dev->txdone_work);
> +
> +	if (rt2800usb_txstatus_pending(rt2x00dev)) {
>  		/* Read register after 250 us */
>  		hrtimer_start(&rt2x00dev->txstatus_timer, ktime_set(0, 250000),
>  			      HRTIMER_MODE_REL);


-- 
---
Gertjan

      reply	other threads:[~2012-03-20  4:23 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-03-19  8:39 [PATCH] rt2x00: rt2800usb: schedule txdone work on timeout Stanislaw Gruszka
2012-03-20  4:23 ` Gertjan van Wingerde [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4F680646.4040707@gmail.com \
    --to=gwingerde@gmail.com \
    --cc=linux-wireless@vger.kernel.org \
    --cc=linville@tuxdriver.com \
    --cc=moorray@wp.pl \
    --cc=sgruszka@redhat.com \
    --cc=users@rt2x00.serialmonkey.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.