All of lore.kernel.org
 help / color / mirror / Atom feed
From: Johannes Berg <johannes@sipsolutions.net>
To: Arend van Spriel <arend@broadcom.com>
Cc: "linux-wireless@vger.kernel.org" <linux-wireless@vger.kernel.org>,
	"John W. Linville" <linville@tuxdriver.com>
Subject: Re: rework on .flush() callback
Date: Fri, 16 Nov 2012 14:34:52 +0100	[thread overview]
Message-ID: <1353072892.9490.12.camel@jlt4.sipsolutions.net> (raw)
In-Reply-To: <50A4E458.4090508@broadcom.com>

Hi Arend,

> The brcmsmac driver still faces a lot of bug reports related to the 
> .flush() callback (see [1] from Dave Jones).
> 
> Previously I had looked into this and found that during the flush the 
> .tx callback still gets new frames. So I put ieee80211_stop_queues() in 
> the flush and upon exit call ieee80211_wake_queues(). Due to issues 
> still persisting we went a bit deeper in mac80211.
> 
> It turns out that mac80211 stops the netif queues for each interface 
> (except monitor iftype) and not the internal queues during a scan. So it 
> stops the netif queues, calls the flush(), and upon returning to the 
> associated channel it wakes up the netif queues.

Hmm, interesting. Yeah this is for scanning, that software scan stuff is
a bit buggy in this area, I agree. This only really works if there's
nothing on the internal queues, otherwise during flush the driver will
wake the queues and get more packets etc...

> The problem here is that in brcmsmac the flush does the 
> ieee80211_wake_queues() call, because that could also wakeup the netif 
> queues. So doing it in the driver seems a bad idea. Any suggestion on 
> how to solve this?

Yeah so .. I actually thought about this at some point, it's tricky. For
the global queues we check what reasons we had for stopping them, but we
don't do that for the netif queues. Maybe we should? I also think flush
should at least have the option to be per queue, so that we could do
something per sdata in mac80211 if the driver uses different HW queues
for different interfaces.

However, I'm not sure I'll have time to work on corner cases with
software scanning since we don't use that. I might work on the flush
thing though, that could be interesting.

johannes


  reply	other threads:[~2012-11-16 13:34 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-11-15 12:47 rework on .flush() callback Arend van Spriel
2012-11-16 13:34 ` Johannes Berg [this message]
2012-11-16 17:08   ` Arend van Spriel
2012-11-19 14:52     ` Johannes Berg

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=1353072892.9490.12.camel@jlt4.sipsolutions.net \
    --to=johannes@sipsolutions.net \
    --cc=arend@broadcom.com \
    --cc=linux-wireless@vger.kernel.org \
    --cc=linville@tuxdriver.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.