mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	mac80211: initialize rate control earlier for tdls station
Currently when TDLS station in driver goes from authenticated to associated state it can not use rate control parameters because rate control is not initialized yet. Some drivers require parameters already initialized by rate control when entering associated state. It can be done by initializing rate control after station transition to associated state but before notifying driver about that. Signed-off-by: Marek Puzyniak <marek.puzyniak@tieto.com> Signed-off-by: Arik Nemtsov <arikx.nemtsov@intel.com> [fix comment to say 'associated' instead of 'authorized'] Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
		
							parent
							
								
									f3b0bbb35d
								
							
						
					
					
						commit
						c23e31cf7b
					
				| @ -977,6 +977,14 @@ static int sta_apply_auth_flags(struct ieee80211_local *local, | |||||||
| 	if (mask & BIT(NL80211_STA_FLAG_ASSOCIATED) && | 	if (mask & BIT(NL80211_STA_FLAG_ASSOCIATED) && | ||||||
| 	    set & BIT(NL80211_STA_FLAG_ASSOCIATED) && | 	    set & BIT(NL80211_STA_FLAG_ASSOCIATED) && | ||||||
| 	    !test_sta_flag(sta, WLAN_STA_ASSOC)) { | 	    !test_sta_flag(sta, WLAN_STA_ASSOC)) { | ||||||
|  | 		/*
 | ||||||
|  | 		 * When peer becomes associated, init rate control as | ||||||
|  | 		 * well. Some drivers require rate control initialized | ||||||
|  | 		 * before drv_sta_state() is called. | ||||||
|  | 		 */ | ||||||
|  | 		if (test_sta_flag(sta, WLAN_STA_TDLS_PEER)) | ||||||
|  | 			rate_control_rate_init(sta); | ||||||
|  | 
 | ||||||
| 		ret = sta_info_move_state(sta, IEEE80211_STA_ASSOC); | 		ret = sta_info_move_state(sta, IEEE80211_STA_ASSOC); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| @ -1378,11 +1386,6 @@ static int ieee80211_change_station(struct wiphy *wiphy, | |||||||
| 	if (err) | 	if (err) | ||||||
| 		goto out_err; | 		goto out_err; | ||||||
| 
 | 
 | ||||||
| 	/* When peer becomes authorized, init rate control as well */ |  | ||||||
| 	if (test_sta_flag(sta, WLAN_STA_TDLS_PEER) && |  | ||||||
| 	    test_sta_flag(sta, WLAN_STA_AUTHORIZED)) |  | ||||||
| 		rate_control_rate_init(sta); |  | ||||||
| 
 |  | ||||||
| 	mutex_unlock(&local->sta_mtx); | 	mutex_unlock(&local->sta_mtx); | ||||||
| 
 | 
 | ||||||
| 	if ((sdata->vif.type == NL80211_IFTYPE_AP || | 	if ((sdata->vif.type == NL80211_IFTYPE_AP || | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Marek Puzyniak
						Marek Puzyniak