mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-11-02 10:34:05 +02:00
93f00c0eb5
- fix a semi-random heisenbug by replacing the previous noderef fix with a simple hack that is not 100% correct, but safe. - add ad-hoc atim fixes by bruno - add napi polling fixes by sven-ola - fix compile breakage with debug enabled git-svn-id: svn://svn.openwrt.org/openwrt/trunk@12838 3c298f89-4303-0410-b956-a3cf2f4a3e73
53 lines
1.7 KiB
Diff
53 lines
1.7 KiB
Diff
--- a/ath/if_ath.c
|
|
+++ b/ath/if_ath.c
|
|
@@ -389,6 +389,7 @@
|
|
static int ath_outdoor = AH_FALSE; /* enable outdoor use */
|
|
static int ath_xchanmode = AH_TRUE; /* enable extended channels */
|
|
static int ath_maxvaps = ATH_MAXVAPS_DEFAULT; /* set default maximum vaps */
|
|
+static int bstuck_thresh = BSTUCK_THRESH; /* Stuck beacon count required for reset */
|
|
static char *autocreate = NULL;
|
|
static char *ratectl = DEF_RATE_CTL;
|
|
static int rfkill = 0;
|
|
@@ -432,6 +433,7 @@
|
|
#ifdef ATH_CAP_TPC
|
|
MODULE_PARM(tpc, "i");
|
|
#endif
|
|
+MODULE_PARM(bstuck_thresh, "i");
|
|
MODULE_PARM(autocreate, "s");
|
|
MODULE_PARM(ratectl, "s");
|
|
#else
|
|
@@ -445,6 +447,7 @@
|
|
#ifdef ATH_CAP_TPC
|
|
module_param(tpc, int, 0600);
|
|
#endif
|
|
+module_param(bstuck_thresh, int, 0600);
|
|
module_param(autocreate, charp, 0600);
|
|
module_param(ratectl, charp, 0600);
|
|
#endif
|
|
@@ -457,6 +460,7 @@
|
|
MODULE_PARM_DESC(tpc, "Enable/disable per-packet transmit power control (TPC) "
|
|
"capability");
|
|
#endif
|
|
+MODULE_PARM_DESC(bstuck_thresh, "Override default stuck beacon threshold");
|
|
MODULE_PARM_DESC(autocreate, "Create ath device in "
|
|
"[sta|ap|wds|adhoc|ahdemo|monitor] mode. defaults to sta, use "
|
|
"'none' to disable");
|
|
@@ -5062,7 +5066,7 @@
|
|
DPRINTF(sc, ATH_DEBUG_BEACON_PROC,
|
|
"Missed %u consecutive beacons (n_beacon=%u)\n",
|
|
sc->sc_bmisscount, n_beacon);
|
|
- if (sc->sc_bmisscount > BSTUCK_THRESH)
|
|
+ if (sc->sc_bmisscount > bstuck_thresh)
|
|
ATH_SCHEDULE_TQUEUE(&sc->sc_bstucktq, needmark);
|
|
return;
|
|
}
|
|
@@ -5218,7 +5222,7 @@
|
|
* check will be true, in which case return
|
|
* without resetting the driver.
|
|
*/
|
|
- if (sc->sc_bmisscount <= BSTUCK_THRESH)
|
|
+ if (sc->sc_bmisscount <= bstuck_thresh)
|
|
return;
|
|
EPRINTF(sc, "Stuck beacon; resetting (beacon miss count: %u)\n",
|
|
sc->sc_bmisscount);
|