|
@@ -123,7 +123,6 @@ static void mesh_sync_offset_rx_bcn_presp(struct ieee80211_sub_if_data *sdata,
|
|
|
*/
|
|
|
|
|
|
if (elems->mesh_config && mesh_peer_tbtt_adjusting(elems)) {
|
|
|
- clear_sta_flag(sta, WLAN_STA_TOFFSET_KNOWN);
|
|
|
msync_dbg(sdata, "STA %pM : is adjusting TBTT\n",
|
|
|
sta->sta.addr);
|
|
|
goto no_sync;
|
|
@@ -172,11 +171,9 @@ static void mesh_sync_offset_adjust_tbtt(struct ieee80211_sub_if_data *sdata,
|
|
|
struct beacon_data *beacon)
|
|
|
{
|
|
|
struct ieee80211_if_mesh *ifmsh = &sdata->u.mesh;
|
|
|
- u8 cap;
|
|
|
|
|
|
WARN_ON(ifmsh->mesh_sp_id != IEEE80211_SYNC_METHOD_NEIGHBOR_OFFSET);
|
|
|
WARN_ON(!rcu_read_lock_held());
|
|
|
- cap = beacon->meshconf->meshconf_cap;
|
|
|
|
|
|
spin_lock_bh(&ifmsh->sync_offset_lock);
|
|
|
|
|
@@ -190,21 +187,13 @@ static void mesh_sync_offset_adjust_tbtt(struct ieee80211_sub_if_data *sdata,
|
|
|
"TBTT : kicking off TBTT adjustment with clockdrift_max=%lld\n",
|
|
|
ifmsh->sync_offset_clockdrift_max);
|
|
|
set_bit(MESH_WORK_DRIFT_ADJUST, &ifmsh->wrkq_flags);
|
|
|
-
|
|
|
- ifmsh->adjusting_tbtt = true;
|
|
|
} else {
|
|
|
msync_dbg(sdata,
|
|
|
"TBTT : max clockdrift=%lld; too small to adjust\n",
|
|
|
(long long)ifmsh->sync_offset_clockdrift_max);
|
|
|
ifmsh->sync_offset_clockdrift_max = 0;
|
|
|
-
|
|
|
- ifmsh->adjusting_tbtt = false;
|
|
|
}
|
|
|
spin_unlock_bh(&ifmsh->sync_offset_lock);
|
|
|
-
|
|
|
- beacon->meshconf->meshconf_cap = ifmsh->adjusting_tbtt ?
|
|
|
- IEEE80211_MESHCONF_CAPAB_TBTT_ADJUSTING | cap :
|
|
|
- ~IEEE80211_MESHCONF_CAPAB_TBTT_ADJUSTING & cap;
|
|
|
}
|
|
|
|
|
|
static const struct sync_method sync_methods[] = {
|