From: nbd Date: Tue, 17 May 2011 08:42:05 +0000 (+0000) Subject: ath9k: backport beacon related fixes from r26913, r26915 X-Git-Url: http://git.ozo.com/?p=openwrt-10.03%2F.git;a=commitdiff_plain;h=7e24d93f43a999788310886fc3e33d9e66170671;hp=f09d05c8b6684af8b1e4c83cb2ba5275326517fe ath9k: backport beacon related fixes from r26913, r26915 git-svn-id: svn://svn.openwrt.org/openwrt/branches/backfire@26917 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- diff --git a/package/mac80211/patches/580-ath9k_fix_adhoc_beacons.patch b/package/mac80211/patches/580-ath9k_fix_adhoc_beacons.patch new file mode 100644 index 000000000..d3eb76409 --- /dev/null +++ b/package/mac80211/patches/580-ath9k_fix_adhoc_beacons.patch @@ -0,0 +1,50 @@ +--- a/drivers/net/wireless/ath/ath9k/beacon.c ++++ b/drivers/net/wireless/ath/ath9k/beacon.c +@@ -351,9 +351,7 @@ void ath_beacon_tasklet(unsigned long da + 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,17 +386,27 @@ void ath_beacon_tasklet(unsigned long da + * on the tsf to safeguard against missing an swba. + */ + +- 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); +- slot = (tsftu % (intval * ATH_BCBUF)) / intval; +- vif = sc->beacon.bslot[slot]; ++ 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); ++ slot = (tsftu % (intval * ATH_BCBUF)) / intval; ++ vif = sc->beacon.bslot[slot]; ++ ++ 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]; ++ } + +- ath_dbg(common, ATH_DBG_BEACON, +- "slot %d [tsf %llu tsftu %u intval %u] vif %p\n", +- slot, tsf, tsftu / ATH_BCBUF, intval, vif); + + bfaddr = 0; + if (vif) { diff --git a/package/mac80211/patches/581-ath9k_fix_adhoc_nexttbtt.patch b/package/mac80211/patches/581-ath9k_fix_adhoc_nexttbtt.patch new file mode 100644 index 000000000..812bf8cf6 --- /dev/null +++ b/package/mac80211/patches/581-ath9k_fix_adhoc_nexttbtt.patch @@ -0,0 +1,11 @@ +--- a/drivers/net/wireless/ath/ath9k/beacon.c ++++ b/drivers/net/wireless/ath/ath9k/beacon.c +@@ -648,7 +648,7 @@ static void ath_beacon_config_adhoc(stru + delta = (tsf - sc->beacon.bc_tstamp); + else + delta = (tsf + 1 + (~0U - sc->beacon.bc_tstamp)); +- nexttbtt = tsf + roundup(delta, intval); ++ nexttbtt = tsf + intval - (delta % intval); + } + + ath_dbg(common, ATH_DBG_BEACON,