driver_bsd.c: Use new MLME method of association.

Old way does not work with all drivers on NetBSD and FreeBSD are
also using this so should be a safe change. [Bug 312]

Signed-off-by: Roy Marples <roy@marples.name>
This commit is contained in:
Roy Marples 2009-05-29 22:41:43 +03:00 committed by Jouni Malinen
parent 66d4085f0a
commit a5b73cc49d

View File

@ -1172,10 +1172,6 @@ wpa_driver_bsd_associate(void *priv, struct wpa_driver_associate_params *params)
/* XXX error handling is wrong but unclear what to do... */ /* XXX error handling is wrong but unclear what to do... */
if (wpa_driver_bsd_set_wpa_ie(drv, params->wpa_ie, params->wpa_ie_len) < 0) if (wpa_driver_bsd_set_wpa_ie(drv, params->wpa_ie, params->wpa_ie_len) < 0)
return -1; return -1;
#ifndef NEW_FREEBSD_MLME_ASSOC
if (wpa_driver_bsd_set_ssid(drv, params->ssid, params->ssid_len) < 0)
return -1;
#endif
privacy = !(params->pairwise_suite == CIPHER_NONE && privacy = !(params->pairwise_suite == CIPHER_NONE &&
params->group_suite == CIPHER_NONE && params->group_suite == CIPHER_NONE &&
@ -1193,11 +1189,9 @@ wpa_driver_bsd_associate(void *priv, struct wpa_driver_associate_params *params)
os_memset(&mlme, 0, sizeof(mlme)); os_memset(&mlme, 0, sizeof(mlme));
mlme.im_op = IEEE80211_MLME_ASSOC; mlme.im_op = IEEE80211_MLME_ASSOC;
#ifdef NEW_FREEBSD_MLME_ASSOC
if (params->ssid != NULL) if (params->ssid != NULL)
os_memcpy(mlme.im_ssid, params->ssid, params->ssid_len); os_memcpy(mlme.im_ssid, params->ssid, params->ssid_len);
mlme.im_ssid_len = params->ssid_len; mlme.im_ssid_len = params->ssid_len;
#endif
if (params->bssid != NULL) if (params->bssid != NULL)
os_memcpy(mlme.im_macaddr, params->bssid, IEEE80211_ADDR_LEN); os_memcpy(mlme.im_macaddr, params->bssid, IEEE80211_ADDR_LEN);
if (set80211var(drv, IEEE80211_IOC_MLME, &mlme, sizeof(mlme)) < 0) if (set80211var(drv, IEEE80211_IOC_MLME, &mlme, sizeof(mlme)) < 0)