Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c6820f1e authored by Felix Fietkau's avatar Felix Fietkau Committed by John W. Linville
Browse files

ath9k: fix ad-hoc mode beacon selection



In ad-hoc mode, beacon timers are configured differently compared to AP
mode, and (depending on the scenario) can vary enough to make the beacon
tasklet not detect slot 0 based on the TSF.
Since staggered beacons are not (and cannot be) used in ad-hoc mode, it
makes more sense to just hardcode slot 0 here, avoiding unnecessary
TSF reads and calculations.

Signed-off-by: default avatarFelix Fietkau <nbd@openwrt.org>
Reported-by: default avatarRajkumar Manoharan <rmanoharan@atheros.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent ed9d0102
Loading
Loading
Loading
Loading
+20 −12
Original line number Diff line number Diff line
@@ -351,9 +351,7 @@ void ath_beacon_tasklet(unsigned long data)
	struct ath_buf *bf = NULL;
	struct ieee80211_vif *vif;
	int slot;
	u32 bfaddr, bc = 0, tsftu;
	u64 tsf;
	u16 intval;
	u32 bfaddr, bc = 0;

	/*
	 * Check if the previous beacon has gone out.  If
@@ -388,8 +386,13 @@ void ath_beacon_tasklet(unsigned long data)
	 * on the tsf to safeguard against missing an swba.
	 */

	intval = cur_conf->beacon_interval ? : ATH_DEFAULT_BINTVAL;

	if (ah->opmode == NL80211_IFTYPE_AP) {
		u16 intval;
		u32 tsftu;
		u64 tsf;

		intval = cur_conf->beacon_interval ? : ATH_DEFAULT_BINTVAL;
		tsf = ath9k_hw_gettsf64(ah);
		tsf += TU_TO_USEC(ah->config.sw_beacon_response_time);
		tsftu = TSF_TO_TU((tsf * ATH_BCBUF) >>32, tsf * ATH_BCBUF);
@@ -399,6 +402,11 @@ void ath_beacon_tasklet(unsigned long data)
		ath_dbg(common, ATH_DBG_BEACON,
			"slot %d [tsf %llu tsftu %u intval %u] vif %p\n",
			slot, tsf, tsftu / ATH_BCBUF, intval, vif);
	} else {
		slot = 0;
		vif = sc->beacon.bslot[slot];
	}


	bfaddr = 0;
	if (vif) {