nl80211: Use device AP SME capability
This changes the auto-detection of whether or not the device contains the AP SME away from monitor interface addition failing to the explicit attribute in nl80211. Keep the old auto-detection for a little while so that ath6kl isn't broken right away. Signed-hostap: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
		
							parent
							
								
									7a5257bbc9
								
							
						
					
					
						commit
						61cbe2ffd8
					
				
					 1 changed files with 22 additions and 10 deletions
				
			
		|  | @ -200,11 +200,11 @@ struct wpa_driver_nl80211_data { | ||||||
| 
 | 
 | ||||||
| 	int monitor_sock; | 	int monitor_sock; | ||||||
| 	int monitor_ifidx; | 	int monitor_ifidx; | ||||||
| 	int no_monitor_iface_capab; |  | ||||||
| 
 | 
 | ||||||
| 	unsigned int disabled_11b_rates:1; | 	unsigned int disabled_11b_rates:1; | ||||||
| 	unsigned int pending_remain_on_chan:1; | 	unsigned int pending_remain_on_chan:1; | ||||||
| 	unsigned int in_interface_list:1; | 	unsigned int in_interface_list:1; | ||||||
|  | 	unsigned int device_ap_sme:1; | ||||||
| 
 | 
 | ||||||
| 	u64 remain_on_chan_cookie; | 	u64 remain_on_chan_cookie; | ||||||
| 	u64 send_action_cookie; | 	u64 send_action_cookie; | ||||||
|  | @ -1546,7 +1546,7 @@ static void nl80211_new_station_event(struct wpa_driver_nl80211_data *drv, | ||||||
| 	addr = nla_data(tb[NL80211_ATTR_MAC]); | 	addr = nla_data(tb[NL80211_ATTR_MAC]); | ||||||
| 	wpa_printf(MSG_DEBUG, "nl80211: New station " MACSTR, MAC2STR(addr)); | 	wpa_printf(MSG_DEBUG, "nl80211: New station " MACSTR, MAC2STR(addr)); | ||||||
| 
 | 
 | ||||||
| 	if (is_ap_interface(drv->nlmode) && drv->no_monitor_iface_capab) { | 	if (is_ap_interface(drv->nlmode) && drv->device_ap_sme) { | ||||||
| 		u8 *ies = NULL; | 		u8 *ies = NULL; | ||||||
| 		size_t ies_len = 0; | 		size_t ies_len = 0; | ||||||
| 		if (tb[NL80211_ATTR_IE]) { | 		if (tb[NL80211_ATTR_IE]) { | ||||||
|  | @ -1579,7 +1579,7 @@ static void nl80211_del_station_event(struct wpa_driver_nl80211_data *drv, | ||||||
| 	wpa_printf(MSG_DEBUG, "nl80211: Delete station " MACSTR, | 	wpa_printf(MSG_DEBUG, "nl80211: Delete station " MACSTR, | ||||||
| 		   MAC2STR(addr)); | 		   MAC2STR(addr)); | ||||||
| 
 | 
 | ||||||
| 	if (is_ap_interface(drv->nlmode) && drv->no_monitor_iface_capab) { | 	if (is_ap_interface(drv->nlmode) && drv->device_ap_sme) { | ||||||
| 		drv_event_disassoc(drv->ctx, addr); | 		drv_event_disassoc(drv->ctx, addr); | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
|  | @ -1858,6 +1858,7 @@ struct wiphy_info_data { | ||||||
| 	struct wpa_driver_capa *capa; | 	struct wpa_driver_capa *capa; | ||||||
| 
 | 
 | ||||||
| 	unsigned int error:1; | 	unsigned int error:1; | ||||||
|  | 	unsigned int device_ap_sme:1; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -2039,6 +2040,9 @@ broken_combination: | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if (tb[NL80211_ATTR_DEVICE_AP_SME]) | ||||||
|  | 		info->device_ap_sme = 1; | ||||||
|  | 
 | ||||||
| 	return NL_SKIP; | 	return NL_SKIP; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -2096,6 +2100,8 @@ static int wpa_driver_nl80211_capa(struct wpa_driver_nl80211_data *drv) | ||||||
| 	drv->capa.flags |= WPA_DRIVER_FLAGS_EAPOL_TX_STATUS; | 	drv->capa.flags |= WPA_DRIVER_FLAGS_EAPOL_TX_STATUS; | ||||||
| 	drv->capa.flags |= WPA_DRIVER_FLAGS_DEAUTH_TX_STATUS; | 	drv->capa.flags |= WPA_DRIVER_FLAGS_DEAUTH_TX_STATUS; | ||||||
| 
 | 
 | ||||||
|  | 	drv->device_ap_sme = info.device_ap_sme; | ||||||
|  | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -4209,7 +4215,7 @@ static int wpa_driver_nl80211_send_mlme(void *priv, const u8 *data, | ||||||
| 					      data, data_len, NULL, 1); | 					      data, data_len, NULL, 1); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (drv->no_monitor_iface_capab && is_ap_interface(drv->nlmode)) { | 	if (drv->device_ap_sme && is_ap_interface(drv->nlmode)) { | ||||||
| 		return nl80211_send_frame_cmd(drv, drv->ap_oper_freq, 0, | 		return nl80211_send_frame_cmd(drv, drv->ap_oper_freq, 0, | ||||||
| 					      data, data_len, NULL, 0); | 					      data, data_len, NULL, 0); | ||||||
| 	} | 	} | ||||||
|  | @ -5044,9 +5050,15 @@ nl80211_create_monitor_interface(struct wpa_driver_nl80211_data *drv) | ||||||
| 				     0); | 				     0); | ||||||
| 
 | 
 | ||||||
| 	if (drv->monitor_ifidx == -EOPNOTSUPP) { | 	if (drv->monitor_ifidx == -EOPNOTSUPP) { | ||||||
|  | 		/*
 | ||||||
|  | 		 * This is backward compatibility for a few versions of | ||||||
|  | 		 * the kernel only that didn't advertise the right | ||||||
|  | 		 * attributes for the only driver that then supported | ||||||
|  | 		 * AP mode w/o monitor -- ath6kl. | ||||||
|  | 		 */ | ||||||
| 		wpa_printf(MSG_DEBUG, "nl80211: Driver does not support " | 		wpa_printf(MSG_DEBUG, "nl80211: Driver does not support " | ||||||
| 			   "monitor interface type - try to run without it"); | 			   "monitor interface type - try to run without it"); | ||||||
| 		drv->no_monitor_iface_capab = 1; | 		drv->device_ap_sme = 1; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (drv->monitor_ifidx < 0) | 	if (drv->monitor_ifidx < 0) | ||||||
|  | @ -5129,7 +5141,7 @@ static int wpa_driver_nl80211_hapd_send_eapol( | ||||||
| 	int qos = flags & WPA_STA_WMM; | 	int qos = flags & WPA_STA_WMM; | ||||||
| 
 | 
 | ||||||
| #ifdef CONFIG_AP | #ifdef CONFIG_AP | ||||||
| 	if (drv->no_monitor_iface_capab) | 	if (drv->device_ap_sme) | ||||||
| 		return nl80211_send_eapol_data(bss, addr, data, data_len, | 		return nl80211_send_eapol_data(bss, addr, data, data_len, | ||||||
| 					       own_addr); | 					       own_addr); | ||||||
| #endif /* CONFIG_AP */ | #endif /* CONFIG_AP */ | ||||||
|  | @ -5262,7 +5274,7 @@ static int wpa_driver_nl80211_ap(struct wpa_driver_nl80211_data *drv, | ||||||
| 		return -1; | 		return -1; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (drv->no_monitor_iface_capab) { | 	if (drv->device_ap_sme) { | ||||||
| 		if (wpa_driver_nl80211_probe_req_report(&drv->first_bss, 1) < 0) | 		if (wpa_driver_nl80211_probe_req_report(&drv->first_bss, 1) < 0) | ||||||
| 		{ | 		{ | ||||||
| 			wpa_printf(MSG_DEBUG, "nl80211: Failed to enable " | 			wpa_printf(MSG_DEBUG, "nl80211: Failed to enable " | ||||||
|  | @ -5824,13 +5836,13 @@ static int wpa_driver_nl80211_set_mode(struct i802_bss *bss, | ||||||
| done: | done: | ||||||
| 	if (!ret && is_ap_interface(nlmode)) { | 	if (!ret && is_ap_interface(nlmode)) { | ||||||
| 		/* Setup additional AP mode functionality if needed */ | 		/* Setup additional AP mode functionality if needed */ | ||||||
| 		if (!drv->no_monitor_iface_capab && drv->monitor_ifidx < 0 && | 		if (!drv->device_ap_sme && drv->monitor_ifidx < 0 && | ||||||
| 		    nl80211_create_monitor_interface(drv) && | 		    nl80211_create_monitor_interface(drv) && | ||||||
| 		    !drv->no_monitor_iface_capab) | 		    !drv->device_ap_sme) | ||||||
| 			return -1; | 			return -1; | ||||||
| 	} else if (!ret && !is_ap_interface(nlmode)) { | 	} else if (!ret && !is_ap_interface(nlmode)) { | ||||||
| 		/* Remove additional AP mode functionality */ | 		/* Remove additional AP mode functionality */ | ||||||
| 		if (was_ap && drv->no_monitor_iface_capab) | 		if (was_ap && drv->device_ap_sme) | ||||||
| 			wpa_driver_nl80211_probe_req_report(bss, 0); | 			wpa_driver_nl80211_probe_req_report(bss, 0); | ||||||
| 		nl80211_remove_monitor_interface(drv); | 		nl80211_remove_monitor_interface(drv); | ||||||
| 		bss->beacon_set = 0; | 		bss->beacon_set = 0; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Johannes Berg
						Johannes Berg