diff options
author | Pedersen, Thomas <twp@qca.qualcomm.com> | 2016-09-06 20:59:00 +0200 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2016-09-12 12:27:14 +0200 |
commit | 5df20f2141eadb5430caaad20eceac61cfe0f139 (patch) | |
tree | 9eafed51548165087bd7c490e72cd30ccf39bdfb /net/mac80211/mesh_pathtbl.c | |
parent | mac80211: fix sequence number assignment for PS response frames (diff) | |
download | linux-5df20f2141eadb5430caaad20eceac61cfe0f139.tar.xz linux-5df20f2141eadb5430caaad20eceac61cfe0f139.zip |
mac80211: make mpath path fixing more robust
A fixed mpath was not quite being treated as such:
1) if a PERR frame was received, a fixed mpath was
deactivated.
2) queued path discovery for fixed mpath was potentially
being considered, changing mpath state.
3) other mpath flags were potentially being inherited when
fixing the mpath. Just assign PATH_FIXED and SN_VALID.
This solves several issues when fixing a mesh path in one
direction. The reverse direction mpath should probably
also be fixed, or root announcements at least be enabled.
Signed-off-by: Thomas Pedersen <twp@qca.qualcomm.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/mac80211/mesh_pathtbl.c')
-rw-r--r-- | net/mac80211/mesh_pathtbl.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/mac80211/mesh_pathtbl.c b/net/mac80211/mesh_pathtbl.c index 6db2ddfa0695..f0e6175a9821 100644 --- a/net/mac80211/mesh_pathtbl.c +++ b/net/mac80211/mesh_pathtbl.c @@ -826,7 +826,7 @@ void mesh_path_fix_nexthop(struct mesh_path *mpath, struct sta_info *next_hop) mpath->metric = 0; mpath->hop_count = 0; mpath->exp_time = 0; - mpath->flags |= MESH_PATH_FIXED; + mpath->flags = MESH_PATH_FIXED | MESH_PATH_SN_VALID; mesh_path_activate(mpath); spin_unlock_bh(&mpath->state_lock); mesh_path_tx_pending(mpath); |