58 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
From: Sara Sharon <sara.sharon@intel.com>
 | 
						|
Date: Mon, 25 Jan 2016 15:46:35 +0200
 | 
						|
Subject: [PATCH] mac80211: fix ibss scan parameters
 | 
						|
 | 
						|
When joining IBSS a full scan should be initiated in order to search
 | 
						|
for existing cell, unless the fixed_channel parameter was set.
 | 
						|
A default channel to create the IBSS on if no cell was found is
 | 
						|
provided as well.
 | 
						|
However - a scan is initiated only on the default channel provided
 | 
						|
regardless of whether ifibss->fixed_channel is set or not, with the
 | 
						|
obvious result of the cell not joining existing IBSS cell that is
 | 
						|
on another channel.
 | 
						|
 | 
						|
Fixes: 76bed0f43b27 ("mac80211: IBSS fix scan request")
 | 
						|
Signed-off-by: Sara Sharon <sara.sharon@intel.com>
 | 
						|
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
 | 
						|
---
 | 
						|
 | 
						|
--- a/net/mac80211/ibss.c
 | 
						|
+++ b/net/mac80211/ibss.c
 | 
						|
@@ -7,6 +7,7 @@
 | 
						|
  * Copyright 2007, Michael Wu <flamingice@sourmilk.net>
 | 
						|
  * Copyright 2009, Johannes Berg <johannes@sipsolutions.net>
 | 
						|
  * Copyright 2013-2014  Intel Mobile Communications GmbH
 | 
						|
+ * Copyright(c) 2016 Intel Deutschland GmbH
 | 
						|
  *
 | 
						|
  * This program is free software; you can redistribute it and/or modify
 | 
						|
  * it under the terms of the GNU General Public License version 2 as
 | 
						|
@@ -1483,14 +1484,21 @@ static void ieee80211_sta_find_ibss(stru
 | 
						|
 
 | 
						|
 		sdata_info(sdata, "Trigger new scan to find an IBSS to join\n");
 | 
						|
 
 | 
						|
-		num = ieee80211_ibss_setup_scan_channels(local->hw.wiphy,
 | 
						|
-							 &ifibss->chandef,
 | 
						|
-							 channels,
 | 
						|
-							 ARRAY_SIZE(channels));
 | 
						|
 		scan_width = cfg80211_chandef_to_scan_width(&ifibss->chandef);
 | 
						|
-		ieee80211_request_ibss_scan(sdata, ifibss->ssid,
 | 
						|
-					    ifibss->ssid_len, channels, num,
 | 
						|
-					    scan_width);
 | 
						|
+
 | 
						|
+		if (ifibss->fixed_channel) {
 | 
						|
+			num = ieee80211_ibss_setup_scan_channels(local->hw.wiphy,
 | 
						|
+								 &ifibss->chandef,
 | 
						|
+								 channels,
 | 
						|
+								 ARRAY_SIZE(channels));
 | 
						|
+			ieee80211_request_ibss_scan(sdata, ifibss->ssid,
 | 
						|
+						    ifibss->ssid_len, channels,
 | 
						|
+						    num, scan_width);
 | 
						|
+		} else {
 | 
						|
+			ieee80211_request_ibss_scan(sdata, ifibss->ssid,
 | 
						|
+						    ifibss->ssid_len, NULL,
 | 
						|
+						    0, scan_width);
 | 
						|
+		}
 | 
						|
 	} else {
 | 
						|
 		int interval = IEEE80211_SCAN_INTERVAL;
 | 
						|
 
 |