diff options
author | Jussi Kivilinna <jussi.kivilinna@mbnet.fi> | 2011-01-31 20:48:55 +0200 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-02-04 16:29:50 -0500 |
commit | 9be232563666b7d1bd424780aef7ee2aa261ba04 (patch) | |
tree | 28c4455cce240e9a81962d67cb613c692b254bf0 /drivers/net/wireless/zd1211rw/zd_chip.c | |
parent | 512119b36f7945a650877cbc7e9b5f4cc4d92e4c (diff) | |
download | talos-obmc-linux-9be232563666b7d1bd424780aef7ee2aa261ba04.tar.gz talos-obmc-linux-9be232563666b7d1bd424780aef7ee2aa261ba04.zip |
zd1211rw: add beacon watchdog and setting HW beacon more failsafe
When doing tx/rx at high packet rate (for example simply using ping -f),
device starts to fail to respond to control messages. On non-AP modes
this only causes problems for LED updating code but when we are running
in AP-mode we are writing new beacon to HW usually every 100ms. Now if
control message fails in HW beacon setup, device lock is kept locked
and beacon data partially written. This can and usually does cause:
1. HW beacon setup fail now on, as driver cannot acquire device lock.
2. Beacon-done interrupt stop working as device has incomplete beacon.
Therefore make zd_mac_config_beacon() always try to release device lock
and add beacon watchdog to restart beaconing when stall is detected.
Also fix zd_mac_config_beacon() try acquiring device lock for max 500ms,
as what old code appeared to be trying to do using loop and msleep(1).
Signed-off-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/zd1211rw/zd_chip.c')
0 files changed, 0 insertions, 0 deletions