f6930bec33
Replace various void * / int argument combinations with common structures: - ieee80211_ratectl_tx_status for *_tx_complete(); - ieee80211_ratectl_tx_stats for *_tx_update(); While here, improve amrr_tx_update() for a bit: 1. In case, if receiver is not known (typical for Ralink USB drivers), refresh Tx rate for all nodes on the interface. 2. There was a misuse: - otus(4) sends non-decreasing counters (as originally intended); - but ural(4), rum(4) and run(4) are using 'read & clear' registers to obtain statistics for some period of time (and those 'last period' values are used as arguments for tx_update()). If arguments are not big enough, they are just discarded after the next call. Fix: move counting into *_tx_update() (now otus(4) will zero out all node counters after every tx_update() call) Tested with: - Intel 3945BG (wpi(4)), STA mode. - WUSB54GC (rum(4)), STA / HOSTAP mode. - RTL8188EU (urtwn(4)), STA mode. Reviewed by: adrian Differential Revision: https://reviews.freebsd.org/D8037 |
||
---|---|---|
.. | ||
if_rsu.c | ||
if_rsureg.h | ||
if_rum.c | ||
if_rumfw.h | ||
if_rumreg.h | ||
if_rumvar.h | ||
if_run.c | ||
if_runreg.h | ||
if_runvar.h | ||
if_uath.c | ||
if_uathreg.h | ||
if_uathvar.h | ||
if_upgt.c | ||
if_upgtvar.h | ||
if_ural.c | ||
if_uralreg.h | ||
if_uralvar.h | ||
if_urtw.c | ||
if_urtwreg.h | ||
if_urtwvar.h | ||
if_zyd.c | ||
if_zydfw.h | ||
if_zydreg.h |