linux-wireless.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3] mac80211: keep sending peer candidate events while in listen state
@ 2014-11-21  9:11 Nishikawa, Kenzoh
  2014-11-21  9:47 ` Johannes Berg
  0 siblings, 1 reply; 3+ messages in thread
From: Nishikawa, Kenzoh @ 2014-11-21  9:11 UTC (permalink / raw)
  To: linux-wireless@vger.kernel.org
  Cc: devel@lists.open80211s.org, Bob Copeland (me@bobcopeland.com)

Instead of sending peer candidate events just once, send them as long as the peer remains in the LISTEN state in the peering state machine, when userspace is implementing the peering manager.  Userspace may silence the events from a peer by progressing the state machine or by setting the link state to BLOCKED.

Fixes the problem that a mesh peering process won't be fired again after the previous first peering trial fails due to like air propagation error if the peering is managed by user space such as wpa_supplicant.

This patch works with another patch for wpa_supplicant described here which fires a peering process again triggered by the notice from kernel.
http://lists.shmoo.com/pipermail/hostap/2014-November/031235.html

Signed-off-by: Kenzoh Nishikawa <Kenzoh.Nishikawa at jp.sony.com>
---
net/mac80211/mesh_plink.c |    7 +++++++
1 file changed, 7 insertions(+)

diff --git a/net/mac80211/mesh_plink.c b/net/mac80211/mesh_plink.c index 32c7bd0..dfc429b 100644
--- a/net/mac80211/mesh_plink.c
+++ b/net/mac80211/mesh_plink.c
@@ -524,6 +524,13 @@ void mesh_neighbour_update(struct ieee80211_sub_if_data *sdata,
 	    sdata->u.mesh.mshcfg.auto_open_plinks &&
 	    rssi_threshold_check(sta, sdata))
 		changed = mesh_plink_open(sta);
+	else if (sta->plink_state == NL80211_PLINK_LISTEN &&
+		(sdata->u.mesh.user_mpm ||
+		sdata->u.mesh.security & IEEE80211_MESH_SEC_AUTHED))
+		cfg80211_notify_new_peer_candidate(sdata->dev, hw_addr,
+							   elems->ie_start,
+							   elems->total_len,
+							   GFP_ATOMIC);
 
 	ieee80211_mps_frame_release(sta, elems);
 out:


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH v3] mac80211: keep sending peer candidate events while in listen state
  2014-11-21  9:11 [PATCH v3] mac80211: keep sending peer candidate events while in listen state Nishikawa, Kenzoh
@ 2014-11-21  9:47 ` Johannes Berg
  2014-11-21  9:48   ` Johannes Berg
  0 siblings, 1 reply; 3+ messages in thread
From: Johannes Berg @ 2014-11-21  9:47 UTC (permalink / raw)
  To: Nishikawa, Kenzoh
  Cc: linux-wireless@vger.kernel.org, devel@lists.open80211s.org,
	Bob Copeland (me@bobcopeland.com)

On Fri, 2014-11-21 at 09:11 +0000, Nishikawa, Kenzoh wrote:
> Instead of sending peer candidate events just once, send them as long as the peer remains in the LISTEN state in the peering state machine, when userspace is implementing the peering manager.  Userspace may silence the events from a peer by progressing the state machine or by setting the link state to BLOCKED.
> 
> Fixes the problem that a mesh peering process won't be fired again after the previous first peering trial fails due to like air propagation error if the peering is managed by user space such as wpa_supplicant.
> 
> This patch works with another patch for wpa_supplicant described here which fires a peering process again triggered by the notice from kernel.
> http://lists.shmoo.com/pipermail/hostap/2014-November/031235.html

Please break those long lines to <72 characters.


> +	else if (sta->plink_state == NL80211_PLINK_LISTEN &&
> +		(sdata->u.mesh.user_mpm ||
> +		sdata->u.mesh.security & IEEE80211_MESH_SEC_AUTHED))

the latter two lines should be indented by one more space

johannes


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH v3] mac80211: keep sending peer candidate events while in listen state
  2014-11-21  9:47 ` Johannes Berg
@ 2014-11-21  9:48   ` Johannes Berg
  0 siblings, 0 replies; 3+ messages in thread
From: Johannes Berg @ 2014-11-21  9:48 UTC (permalink / raw)
  To: Nishikawa, Kenzoh
  Cc: linux-wireless@vger.kernel.org, devel@lists.open80211s.org,
	Bob Copeland (me@bobcopeland.com)

On Fri, 2014-11-21 at 10:47 +0100, Johannes Berg wrote:

> > +	else if (sta->plink_state == NL80211_PLINK_LISTEN &&
> > +		(sdata->u.mesh.user_mpm ||
> > +		sdata->u.mesh.security & IEEE80211_MESH_SEC_AUTHED))
> 
> the latter two lines should be indented by one more space

Actually the third by 2 to match the containing parenthesis.

johannes


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2014-11-21  9:49 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-11-21  9:11 [PATCH v3] mac80211: keep sending peer candidate events while in listen state Nishikawa, Kenzoh
2014-11-21  9:47 ` Johannes Berg
2014-11-21  9:48   ` Johannes Berg

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).