New hardware, old problem: stuck beacon when here is WiFi traffic
Adrian Chadd
adrian at freebsd.org
Sun Apr 28 19:38:22 UTC 2013
On 28 April 2013 11:50, Lev Serebryakov <lev at freebsd.org> wrote:
> 300M. Only 11-30M seen by client now, but no beacon stucks.
> After AP hangs several forced beacon stucks + hostaptd restart
> allow client to re-associate.
Right. That's likely because 11n aggregation wasn't enabled. I don't know why.
> Log with dev.ath.0.debug=0x900000020 attached ("sudo" messages are left as
> "time marks").
Cool, thanks.
It's odd. The descriptor list(s) look fine - ie, the descriptors
aren't out of order or anything. (Ie, the descriptor and link pointers
line up with the order that the ath_buf's are in the TXQ.)
And the descriptors in your particular setup aren't chained into
multi-descriptor lists, they're one descriptor per frame. There used
to be bugs with my 11n TX code and which ath_buf to check the status
of in a list of ath_bufs, but this last test is with no aggregation.
So that's not a problem.
The next step is seeing whether the hardware queue is actually just
plain stuck, or whether it's idle. If it's idle, it may just be
waiting for another call to ath_hal_txstart() or whatever the call is
to re-trigger it. The only reason it would be idle like that though is
if it hit the end of the descriptor list at about the same time we
appended a frame to the list. However, every time we append a frame to
the hardware queue, we also call ath_hal_txstart() to re-kick TX.
There's some race condition hack that Sam threw in that gets enabled
only if you compile things with TDMA support enabled. Would you mind
compiling in TDMA support (add options IEEE80211_SUPPORT_TDMA) to your
kernel config and rebuild? I'd like to see if that TX queue workaround
is effective at helping us out here.
Does this happen with tcp iperf? or only udp iperf?
adrian
More information about the freebsd-wireless
mailing list