AP: Allow both WPA passphrase and PSK to be configured

Instead of dropping the configured PSK and deriving it based on
passphrase, use the provided PSK as-is and also maintain a copy of
the passphrase since it can be of use later. This allows both values
to be configured without havign to derive the PSK every time the
network is initialized.
This commit is contained in:
Jouni Malinen 2009-12-21 12:11:08 +02:00 committed by Jouni Malinen
parent 1078126f64
commit 0ae687bd10

View file

@ -448,16 +448,8 @@ static int hostapd_config_read_wpa_psk(const char *fname,
} }
int hostapd_setup_wpa_psk(struct hostapd_bss_config *conf) static int hostapd_derive_psk(struct hostapd_ssid *ssid)
{ {
struct hostapd_ssid *ssid = &conf->ssid;
if (ssid->wpa_passphrase != NULL) {
if (ssid->wpa_psk != NULL) {
wpa_printf(MSG_ERROR, "Warning: both WPA PSK and "
"passphrase set. Using passphrase.");
os_free(ssid->wpa_psk);
}
ssid->wpa_psk = os_zalloc(sizeof(struct hostapd_wpa_psk)); ssid->wpa_psk = os_zalloc(sizeof(struct hostapd_wpa_psk));
if (ssid->wpa_psk == NULL) { if (ssid->wpa_psk == NULL) {
wpa_printf(MSG_ERROR, "Unable to alloc space for PSK"); wpa_printf(MSG_ERROR, "Unable to alloc space for PSK");
@ -465,14 +457,32 @@ int hostapd_setup_wpa_psk(struct hostapd_bss_config *conf)
} }
wpa_hexdump_ascii(MSG_DEBUG, "SSID", wpa_hexdump_ascii(MSG_DEBUG, "SSID",
(u8 *) ssid->ssid, ssid->ssid_len); (u8 *) ssid->ssid, ssid->ssid_len);
wpa_hexdump_ascii(MSG_DEBUG, "PSK (ASCII passphrase)", wpa_hexdump_ascii_key(MSG_DEBUG, "PSK (ASCII passphrase)",
(u8 *) ssid->wpa_passphrase, (u8 *) ssid->wpa_passphrase,
os_strlen(ssid->wpa_passphrase)); os_strlen(ssid->wpa_passphrase));
pbkdf2_sha1(ssid->wpa_passphrase, pbkdf2_sha1(ssid->wpa_passphrase,
ssid->ssid, ssid->ssid_len, ssid->ssid, ssid->ssid_len,
4096, ssid->wpa_psk->psk, PMK_LEN); 4096, ssid->wpa_psk->psk, PMK_LEN);
wpa_hexdump(MSG_DEBUG, "PSK (from passphrase)", wpa_hexdump_key(MSG_DEBUG, "PSK (from passphrase)",
ssid->wpa_psk->psk, PMK_LEN); ssid->wpa_psk->psk, PMK_LEN);
return 0;
}
int hostapd_setup_wpa_psk(struct hostapd_bss_config *conf)
{
struct hostapd_ssid *ssid = &conf->ssid;
if (ssid->wpa_passphrase != NULL) {
if (ssid->wpa_psk != NULL) {
wpa_printf(MSG_DEBUG, "Using pre-configured WPA PSK "
"instead of passphrase");
} else {
wpa_printf(MSG_DEBUG, "Deriving WPA PSK based on "
"passphrase");
if (hostapd_derive_psk(ssid) < 0)
return -1;
}
ssid->wpa_psk->group = 1; ssid->wpa_psk->group = 1;
} }