mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-11-04 06:54:27 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			142 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
Index: compat-wireless-2011-02-25/net/mac80211/scan.c
 | 
						|
===================================================================
 | 
						|
--- compat-wireless-2011-02-25.orig/net/mac80211/scan.c	2011-03-07 14:43:55.695666042 +0100
 | 
						|
+++ compat-wireless-2011-02-25/net/mac80211/scan.c	2011-03-07 14:43:57.594439631 +0100
 | 
						|
@@ -258,10 +258,12 @@ static bool ieee80211_prep_hw_scan(struc
 | 
						|
 	return true;
 | 
						|
 }
 | 
						|
 
 | 
						|
-static bool __ieee80211_scan_completed(struct ieee80211_hw *hw, bool aborted,
 | 
						|
+static void __ieee80211_scan_completed(struct ieee80211_hw *hw, bool aborted,
 | 
						|
 				       bool was_hw_scan)
 | 
						|
 {
 | 
						|
 	struct ieee80211_local *local = hw_to_local(hw);
 | 
						|
+	bool on_oper_chan;
 | 
						|
+	bool enable_beacons = false;
 | 
						|
 
 | 
						|
 	lockdep_assert_held(&local->mtx);
 | 
						|
 
 | 
						|
@@ -275,12 +277,12 @@ static bool __ieee80211_scan_completed(s
 | 
						|
 		aborted = true;
 | 
						|
 
 | 
						|
 	if (WARN_ON(!local->scan_req))
 | 
						|
-		return false;
 | 
						|
+		return;
 | 
						|
 
 | 
						|
 	if (was_hw_scan && !aborted && ieee80211_prep_hw_scan(local)) {
 | 
						|
 		int rc = drv_hw_scan(local, local->scan_sdata, local->hw_scan_req);
 | 
						|
 		if (rc == 0)
 | 
						|
-			return false;
 | 
						|
+			return;
 | 
						|
 	}
 | 
						|
 
 | 
						|
 	kfree(local->hw_scan_req);
 | 
						|
@@ -294,26 +296,13 @@ static bool __ieee80211_scan_completed(s
 | 
						|
 	local->scanning = 0;
 | 
						|
 	local->scan_channel = NULL;
 | 
						|
 
 | 
						|
-	return true;
 | 
						|
-}
 | 
						|
-
 | 
						|
-static void __ieee80211_scan_completed_finish(struct ieee80211_hw *hw,
 | 
						|
-					      bool was_hw_scan)
 | 
						|
-{
 | 
						|
-	struct ieee80211_local *local = hw_to_local(hw);
 | 
						|
-	bool on_oper_chan;
 | 
						|
-	bool enable_beacons = false;
 | 
						|
-
 | 
						|
-	mutex_lock(&local->mtx);
 | 
						|
 	on_oper_chan = ieee80211_cfg_on_oper_channel(local);
 | 
						|
 
 | 
						|
 	WARN_ON(local->scanning & (SCAN_SW_SCANNING | SCAN_HW_SCANNING));
 | 
						|
 
 | 
						|
-	if (was_hw_scan || !on_oper_chan) {
 | 
						|
-		if (WARN_ON(local->scan_channel))
 | 
						|
-			local->scan_channel = NULL;
 | 
						|
+	if (was_hw_scan || !on_oper_chan)
 | 
						|
 		ieee80211_hw_config(local, IEEE80211_CONF_CHANGE_CHANNEL);
 | 
						|
-	} else
 | 
						|
+	else
 | 
						|
 		/* Set power back to normal operating levels. */
 | 
						|
 		ieee80211_hw_config(local, 0);
 | 
						|
 
 | 
						|
@@ -331,7 +320,6 @@ static void __ieee80211_scan_completed_f
 | 
						|
 	}
 | 
						|
 
 | 
						|
 	ieee80211_recalc_idle(local);
 | 
						|
-	mutex_unlock(&local->mtx);
 | 
						|
 
 | 
						|
 	ieee80211_mlme_notify_scan_completed(local);
 | 
						|
 	ieee80211_ibss_notify_scan_completed(local);
 | 
						|
@@ -686,12 +674,14 @@ void ieee80211_scan_work(struct work_str
 | 
						|
 {
 | 
						|
 	struct ieee80211_local *local =
 | 
						|
 		container_of(work, struct ieee80211_local, scan_work.work);
 | 
						|
-	struct ieee80211_sub_if_data *sdata = local->scan_sdata;
 | 
						|
+	struct ieee80211_sub_if_data *sdata;
 | 
						|
 	unsigned long next_delay = 0;
 | 
						|
-	bool aborted, hw_scan, finish;
 | 
						|
+	bool aborted, hw_scan;
 | 
						|
 
 | 
						|
 	mutex_lock(&local->mtx);
 | 
						|
 
 | 
						|
+	sdata = local->scan_sdata;
 | 
						|
+
 | 
						|
 	if (test_and_clear_bit(SCAN_COMPLETED, &local->scanning)) {
 | 
						|
 		aborted = test_and_clear_bit(SCAN_ABORTED, &local->scanning);
 | 
						|
 		goto out_complete;
 | 
						|
@@ -755,17 +745,11 @@ void ieee80211_scan_work(struct work_str
 | 
						|
 	} while (next_delay == 0);
 | 
						|
 
 | 
						|
 	ieee80211_queue_delayed_work(&local->hw, &local->scan_work, next_delay);
 | 
						|
-	mutex_unlock(&local->mtx);
 | 
						|
-	return;
 | 
						|
+	goto out;
 | 
						|
 
 | 
						|
 out_complete:
 | 
						|
 	hw_scan = test_bit(SCAN_HW_SCANNING, &local->scanning);
 | 
						|
-	finish = __ieee80211_scan_completed(&local->hw, aborted, hw_scan);
 | 
						|
-	mutex_unlock(&local->mtx);
 | 
						|
-	if (finish)
 | 
						|
-		__ieee80211_scan_completed_finish(&local->hw, hw_scan);
 | 
						|
-	return;
 | 
						|
-
 | 
						|
+	__ieee80211_scan_completed(&local->hw, aborted, hw_scan);
 | 
						|
 out:
 | 
						|
 	mutex_unlock(&local->mtx);
 | 
						|
 }
 | 
						|
@@ -835,7 +819,6 @@ int ieee80211_request_internal_scan(stru
 | 
						|
 void ieee80211_scan_cancel(struct ieee80211_local *local)
 | 
						|
 {
 | 
						|
 	bool abortscan;
 | 
						|
-	bool finish = false;
 | 
						|
 
 | 
						|
 	/*
 | 
						|
 	 * We are only canceling software scan, or deferred scan that was not
 | 
						|
@@ -855,14 +838,17 @@ void ieee80211_scan_cancel(struct ieee80
 | 
						|
 
 | 
						|
 	mutex_lock(&local->mtx);
 | 
						|
 	abortscan = local->scan_req && !test_bit(SCAN_HW_SCANNING, &local->scanning);
 | 
						|
-	if (abortscan)
 | 
						|
-		finish = __ieee80211_scan_completed(&local->hw, true, false);
 | 
						|
-	mutex_unlock(&local->mtx);
 | 
						|
-
 | 
						|
 	if (abortscan) {
 | 
						|
-		/* The scan is canceled, but stop work from being pending */
 | 
						|
-		cancel_delayed_work_sync(&local->scan_work);
 | 
						|
+		/*
 | 
						|
+		 * The scan is canceled, but stop work from being pending.
 | 
						|
+		 *
 | 
						|
+		 * If the work is currently running, it must be blocked on
 | 
						|
+		 * the mutex, but we'll set scan_sdata = NULL and it'll
 | 
						|
+		 * simply exit once it acquires the mutex.
 | 
						|
+		 */
 | 
						|
+		cancel_delayed_work(&local->scan_work);
 | 
						|
+		/* and clean up */
 | 
						|
+		__ieee80211_scan_completed(&local->hw, true, false);
 | 
						|
 	}
 | 
						|
-	if (finish)
 | 
						|
-		__ieee80211_scan_completed_finish(&local->hw, false);
 | 
						|
+	mutex_unlock(&local->mtx);
 | 
						|
 }
 |