Move hostapd driver_ops to use similar set_key with wpa_supplicant

This commit is contained in:
Jouni Malinen 2009-03-25 17:49:22 +02:00 committed by Jouni Malinen
parent fb86519d12
commit 89d39d9d6c
15 changed files with 173 additions and 140 deletions

View file

@ -16,6 +16,7 @@
#ifndef DRIVER_H #ifndef DRIVER_H
#define DRIVER_H #define DRIVER_H
#include "defs.h"
#include "sta_flags.h" #include "sta_flags.h"
struct hostapd_data; struct hostapd_data;
@ -98,9 +99,9 @@ struct wpa_driver_ops {
*/ */
int (*set_privacy)(const char *ifname, void *priv, int enabled); int (*set_privacy)(const char *ifname, void *priv, int enabled);
int (*set_encryption)(const char *ifname, void *priv, const char *alg, int (*set_key)(const char *ifname, void *priv, wpa_alg alg,
const u8 *addr, int idx, const u8 *addr, int key_idx, int set_tx, const u8 *seq,
const u8 *key, size_t key_len, int txkey); size_t seq_len, const u8 *key, size_t key_len);
int (*get_seqnum)(const char *ifname, void *priv, const u8 *addr, int (*get_seqnum)(const char *ifname, void *priv, const u8 *addr,
int idx, u8 *seq); int idx, u8 *seq);
int (*get_seqnum_igtk)(const char *ifname, void *priv, const u8 *addr, int (*get_seqnum_igtk)(const char *ifname, void *priv, const u8 *addr,

View file

@ -426,29 +426,33 @@ madwifi_del_key(void *priv, const u8 *addr, int key_idx)
} }
static int static int
madwifi_set_key(const char *ifname, void *priv, const char *alg, madwifi_set_key(const char *ifname, void *priv, wpa_alg alg, const u8 *addr,
const u8 *addr, int key_idx, int key_idx, int set_tx, const u8 *seq, size_t seq_len,
const u8 *key, size_t key_len, int txkey) const u8 *key, size_t key_len)
{ {
struct madwifi_driver_data *drv = priv; struct madwifi_driver_data *drv = priv;
struct ieee80211req_key wk; struct ieee80211req_key wk;
u_int8_t cipher; u_int8_t cipher;
int ret; int ret;
if (strcmp(alg, "none") == 0) if (alg == WPA_ALG_NONE)
return madwifi_del_key(drv, addr, key_idx); return madwifi_del_key(drv, addr, key_idx);
wpa_printf(MSG_DEBUG, "%s: alg=%s addr=%s key_idx=%d", wpa_printf(MSG_DEBUG, "%s: alg=%d addr=%s key_idx=%d",
__func__, alg, ether_sprintf(addr), key_idx); __func__, alg, ether_sprintf(addr), key_idx);
if (strcmp(alg, "WEP") == 0) switch (alg) {
case WPA_ALG_WEP:
cipher = IEEE80211_CIPHER_WEP; cipher = IEEE80211_CIPHER_WEP;
else if (strcmp(alg, "TKIP") == 0) break;
case WPA_ALG_TKIP:
cipher = IEEE80211_CIPHER_TKIP; cipher = IEEE80211_CIPHER_TKIP;
else if (strcmp(alg, "CCMP") == 0) break;
case WPA_ALG_CCMP:
cipher = IEEE80211_CIPHER_AES_CCM; cipher = IEEE80211_CIPHER_AES_CCM;
else { break;
printf("%s: unknown/unsupported algorithm %s\n", default:
printf("%s: unknown/unsupported algorithm %d\n",
__func__, alg); __func__, alg);
return -1; return -1;
} }
@ -476,9 +480,9 @@ madwifi_set_key(const char *ifname, void *priv, const char *alg,
ret = set80211priv(drv, IEEE80211_IOCTL_SETKEY, &wk, sizeof(wk)); ret = set80211priv(drv, IEEE80211_IOCTL_SETKEY, &wk, sizeof(wk));
if (ret < 0) { if (ret < 0) {
wpa_printf(MSG_DEBUG, "%s: Failed to set key (addr %s" wpa_printf(MSG_DEBUG, "%s: Failed to set key (addr %s"
" key_idx %d alg '%s' key_len %lu txkey %d)", " key_idx %d alg %d key_len %lu set_tx %d)",
__func__, ether_sprintf(wk.ik_macaddr), key_idx, __func__, ether_sprintf(wk.ik_macaddr), key_idx,
alg, (unsigned long) key_len, txkey); alg, (unsigned long) key_len, set_tx);
} }
return ret; return ret;
@ -1318,7 +1322,7 @@ const struct wpa_driver_ops wpa_driver_atheros_ops = {
.deinit = madwifi_deinit, .deinit = madwifi_deinit,
.set_ieee8021x = madwifi_set_ieee8021x, .set_ieee8021x = madwifi_set_ieee8021x,
.set_privacy = madwifi_set_privacy, .set_privacy = madwifi_set_privacy,
.set_encryption = madwifi_set_key, .set_key = madwifi_set_key,
.get_seqnum = madwifi_get_seqnum, .get_seqnum = madwifi_get_seqnum,
.flush = madwifi_flush, .flush = madwifi_flush,
.set_generic_elem = madwifi_set_opt_ie, .set_generic_elem = madwifi_set_opt_ie,

View file

@ -341,28 +341,28 @@ bsd_del_key(void *priv, const u8 *addr, int key_idx)
} }
static int static int
bsd_set_key(const char *ifname, void *priv, const char *alg, bsd_set_key(const char *ifname, void *priv, wpa_alg alg,
const u8 *addr, int key_idx, const u8 *addr, int key_idx, int set_tx, const u8 *seq,
const u8 *key, size_t key_len, int txkey) size_t seq_len, const u8 *key, size_t key_len)
{ {
struct bsd_driver_data *drv = priv; struct bsd_driver_data *drv = priv;
struct ieee80211req_key wk; struct ieee80211req_key wk;
u_int8_t cipher; u_int8_t cipher;
if (strcmp(alg, "none") == 0) if (alg == WPA_ALG_NONE)
return bsd_del_key(drv, addr, key_idx); return bsd_del_key(drv, addr, key_idx);
wpa_printf(MSG_DEBUG, "%s: alg=%s addr=%s key_idx=%d", wpa_printf(MSG_DEBUG, "%s: alg=%d addr=%s key_idx=%d",
__func__, alg, ether_sprintf(addr), key_idx); __func__, alg, ether_sprintf(addr), key_idx);
if (strcmp(alg, "WEP") == 0) if (alg == WPA_ALG_WEP)
cipher = IEEE80211_CIPHER_WEP; cipher = IEEE80211_CIPHER_WEP;
else if (strcmp(alg, "TKIP") == 0) else if (alg == WPA_ALG_TKIP)
cipher = IEEE80211_CIPHER_TKIP; cipher = IEEE80211_CIPHER_TKIP;
else if (strcmp(alg, "CCMP") == 0) else if (alg == WPA_ALG_CCMP)
cipher = IEEE80211_CIPHER_AES_CCM; cipher = IEEE80211_CIPHER_AES_CCM;
else { else {
printf("%s: unknown/unsupported algorithm %s\n", printf("%s: unknown/unsupported algorithm %d\n",
__func__, alg); __func__, alg);
return -1; return -1;
} }
@ -756,7 +756,7 @@ const struct wpa_driver_ops wpa_driver_bsd_ops = {
.deinit = bsd_deinit, .deinit = bsd_deinit,
.set_ieee8021x = bsd_set_ieee8021x, .set_ieee8021x = bsd_set_ieee8021x,
.set_privacy = bsd_set_privacy, .set_privacy = bsd_set_privacy,
.set_encryption = bsd_set_key, .set_key = bsd_set_key,
.get_seqnum = bsd_get_seqnum, .get_seqnum = bsd_get_seqnum,
.flush = bsd_flush, .flush = bsd_flush,
.set_generic_elem = bsd_set_opt_ie, .set_generic_elem = bsd_set_opt_ie,

View file

@ -436,10 +436,10 @@ static int hostapd_ioctl(void *priv, struct prism2_hostapd_param *param,
} }
static int hostap_set_encryption(const char *ifname, void *priv, static int hostap_set_key(const char *ifname, void *priv, wpa_alg alg,
const char *alg, const u8 *addr, const u8 *addr, int key_idx, int set_tx,
int idx, const u8 *key, size_t key_len, const u8 *seq, size_t seq_len, const u8 *key,
int txkey) size_t key_len)
{ {
struct hostap_driver_data *drv = priv; struct hostap_driver_data *drv = priv;
struct prism2_hostapd_param *param; struct prism2_hostapd_param *param;
@ -458,10 +458,29 @@ static int hostap_set_encryption(const char *ifname, void *priv,
memset(param->sta_addr, 0xff, ETH_ALEN); memset(param->sta_addr, 0xff, ETH_ALEN);
else else
memcpy(param->sta_addr, addr, ETH_ALEN); memcpy(param->sta_addr, addr, ETH_ALEN);
os_strlcpy((char *) param->u.crypt.alg, alg, switch (alg) {
HOSTAP_CRYPT_ALG_NAME_LEN); case WPA_ALG_NONE:
param->u.crypt.flags = txkey ? HOSTAP_CRYPT_FLAG_SET_TX_KEY : 0; os_strlcpy((char *) param->u.crypt.alg, "NONE",
param->u.crypt.idx = idx; HOSTAP_CRYPT_ALG_NAME_LEN);
break;
case WPA_ALG_WEP:
os_strlcpy((char *) param->u.crypt.alg, "WEP",
HOSTAP_CRYPT_ALG_NAME_LEN);
break;
case WPA_ALG_TKIP:
os_strlcpy((char *) param->u.crypt.alg, "TKIP",
HOSTAP_CRYPT_ALG_NAME_LEN);
break;
case WPA_ALG_CCMP:
os_strlcpy((char *) param->u.crypt.alg, "CCMP",
HOSTAP_CRYPT_ALG_NAME_LEN);
break;
default:
os_free(buf);
return -1;
}
param->u.crypt.flags = set_tx ? HOSTAP_CRYPT_FLAG_SET_TX_KEY : 0;
param->u.crypt.idx = key_idx;
param->u.crypt.key_len = key_len; param->u.crypt.key_len = key_len;
memcpy((u8 *) (param + 1), key, key_len); memcpy((u8 *) (param + 1), key, key_len);
@ -1216,7 +1235,7 @@ const struct wpa_driver_ops wpa_driver_hostap_ops = {
.wireless_event_deinit = hostap_wireless_event_deinit, .wireless_event_deinit = hostap_wireless_event_deinit,
.set_ieee8021x = hostap_set_ieee8021x, .set_ieee8021x = hostap_set_ieee8021x,
.set_privacy = hostap_set_privacy, .set_privacy = hostap_set_privacy,
.set_encryption = hostap_set_encryption, .set_key = hostap_set_key,
.get_seqnum = hostap_get_seqnum, .get_seqnum = hostap_get_seqnum,
.flush = hostap_flush, .flush = hostap_flush,
.set_generic_elem = hostap_set_generic_elem, .set_generic_elem = hostap_set_generic_elem,

View file

@ -80,14 +80,16 @@ hostapd_set_privacy(struct hostapd_data *hapd, int enabled)
} }
static inline int static inline int
hostapd_set_encryption(const char *ifname, struct hostapd_data *hapd, hostapd_set_key(const char *ifname, struct hostapd_data *hapd,
const char *alg, const u8 *addr, int idx, wpa_alg alg, const u8 *addr, int key_idx,
u8 *key, size_t key_len, int txkey) int set_tx, const u8 *seq, size_t seq_len,
const u8 *key, size_t key_len)
{ {
if (hapd->driver == NULL || hapd->driver->set_encryption == NULL) if (hapd->driver == NULL || hapd->driver->set_key == NULL)
return 0; return 0;
return hapd->driver->set_encryption(ifname, hapd->drv_priv, alg, addr, return hapd->driver->set_key(ifname, hapd->drv_priv, alg, addr,
idx, key, key_len, txkey); key_idx, set_tx, seq, seq_len, key,
key_len);
} }
static inline int static inline int

View file

@ -458,29 +458,29 @@ madwifi_del_key(void *priv, const u8 *addr, int key_idx)
} }
static int static int
madwifi_set_key(const char *ifname, void *priv, const char *alg, madwifi_set_key(const char *ifname, void *priv, wpa_alg alg,
const u8 *addr, int key_idx, const u8 *addr, int key_idx, int set_tx, const u8 *seq,
const u8 *key, size_t key_len, int txkey) size_t seq_len, const u8 *key, size_t key_len)
{ {
struct madwifi_driver_data *drv = priv; struct madwifi_driver_data *drv = priv;
struct ieee80211req_key wk; struct ieee80211req_key wk;
u_int8_t cipher; u_int8_t cipher;
int ret; int ret;
if (strcmp(alg, "none") == 0) if (alg == WPA_ALG_NONE)
return madwifi_del_key(drv, addr, key_idx); return madwifi_del_key(drv, addr, key_idx);
wpa_printf(MSG_DEBUG, "%s: alg=%s addr=%s key_idx=%d", wpa_printf(MSG_DEBUG, "%s: alg=%d addr=%s key_idx=%d",
__func__, alg, ether_sprintf(addr), key_idx); __func__, alg, ether_sprintf(addr), key_idx);
if (strcmp(alg, "WEP") == 0) if (alg == WPA_ALG_WEP)
cipher = IEEE80211_CIPHER_WEP; cipher = IEEE80211_CIPHER_WEP;
else if (strcmp(alg, "TKIP") == 0) else if (alg == WPA_ALG_TKIP)
cipher = IEEE80211_CIPHER_TKIP; cipher = IEEE80211_CIPHER_TKIP;
else if (strcmp(alg, "CCMP") == 0) else if (alg == WPA_ALG_CCMP)
cipher = IEEE80211_CIPHER_AES_CCM; cipher = IEEE80211_CIPHER_AES_CCM;
else { else {
printf("%s: unknown/unsupported algorithm %s\n", printf("%s: unknown/unsupported algorithm %d\n",
__func__, alg); __func__, alg);
return -1; return -1;
} }
@ -508,9 +508,9 @@ madwifi_set_key(const char *ifname, void *priv, const char *alg,
ret = set80211priv(drv, IEEE80211_IOCTL_SETKEY, &wk, sizeof(wk)); ret = set80211priv(drv, IEEE80211_IOCTL_SETKEY, &wk, sizeof(wk));
if (ret < 0) { if (ret < 0) {
wpa_printf(MSG_DEBUG, "%s: Failed to set key (addr %s" wpa_printf(MSG_DEBUG, "%s: Failed to set key (addr %s"
" key_idx %d alg '%s' key_len %lu txkey %d)", " key_idx %d alg %d key_len %lu set_tx %d)",
__func__, ether_sprintf(wk.ik_macaddr), key_idx, __func__, ether_sprintf(wk.ik_macaddr), key_idx,
alg, (unsigned long) key_len, txkey); alg, (unsigned long) key_len, set_tx);
} }
return ret; return ret;
@ -1378,7 +1378,7 @@ const struct wpa_driver_ops wpa_driver_madwifi_ops = {
.deinit = madwifi_deinit, .deinit = madwifi_deinit,
.set_ieee8021x = madwifi_set_ieee8021x, .set_ieee8021x = madwifi_set_ieee8021x,
.set_privacy = madwifi_set_privacy, .set_privacy = madwifi_set_privacy,
.set_encryption = madwifi_set_key, .set_key = madwifi_set_key,
.get_seqnum = madwifi_get_seqnum, .get_seqnum = madwifi_get_seqnum,
.flush = madwifi_flush, .flush = madwifi_flush,
.set_generic_elem = madwifi_set_opt_ie, .set_generic_elem = madwifi_set_opt_ie,

View file

@ -264,7 +264,7 @@ static int hostapd_set_iface_flags(struct i802_driver_data *drv,
static int nl_set_encr(int ifindex, struct i802_driver_data *drv, static int nl_set_encr(int ifindex, struct i802_driver_data *drv,
const char *alg, const u8 *addr, int idx, const u8 *key, wpa_alg alg, const u8 *addr, int idx, const u8 *key,
size_t key_len, int txkey) size_t key_len, int txkey)
{ {
struct nl_msg *msg; struct nl_msg *msg;
@ -274,29 +274,34 @@ static int nl_set_encr(int ifindex, struct i802_driver_data *drv,
if (!msg) if (!msg)
return -ENOMEM; return -ENOMEM;
if (strcmp(alg, "none") == 0) { if (alg == WPA_ALG_NONE) {
genlmsg_put(msg, 0, 0, genl_family_get_id(drv->nl80211), 0, genlmsg_put(msg, 0, 0, genl_family_get_id(drv->nl80211), 0,
0, NL80211_CMD_DEL_KEY, 0); 0, NL80211_CMD_DEL_KEY, 0);
} else { } else {
genlmsg_put(msg, 0, 0, genl_family_get_id(drv->nl80211), 0, genlmsg_put(msg, 0, 0, genl_family_get_id(drv->nl80211), 0,
0, NL80211_CMD_NEW_KEY, 0); 0, NL80211_CMD_NEW_KEY, 0);
NLA_PUT(msg, NL80211_ATTR_KEY_DATA, key_len, key); NLA_PUT(msg, NL80211_ATTR_KEY_DATA, key_len, key);
if (strcmp(alg, "WEP") == 0) { switch (alg) {
case WPA_ALG_WEP:
if (key_len == 5) if (key_len == 5)
NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER,
0x000FAC01); 0x000FAC01);
else else
NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER,
0x000FAC05); 0x000FAC05);
} else if (strcmp(alg, "TKIP") == 0) break;
case WPA_ALG_TKIP:
NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, 0x000FAC02); NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, 0x000FAC02);
else if (strcmp(alg, "CCMP") == 0) break;
case WPA_ALG_CCMP:
NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, 0x000FAC04); NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, 0x000FAC04);
else if (strcmp(alg, "IGTK") == 0) break;
case WPA_ALG_IGTK:
NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, 0x000FAC06); NLA_PUT_U32(msg, NL80211_ATTR_KEY_CIPHER, 0x000FAC06);
else { break;
default:
wpa_printf(MSG_ERROR, "%s: Unsupported encryption " wpa_printf(MSG_ERROR, "%s: Unsupported encryption "
"algorithm '%s'", __func__, alg); "algorithm %d", __func__, alg);
nlmsg_free(msg); nlmsg_free(msg);
return -1; return -1;
} }
@ -326,7 +331,7 @@ static int nl_set_encr(int ifindex, struct i802_driver_data *drv,
0, NL80211_CMD_SET_KEY, 0); 0, NL80211_CMD_SET_KEY, 0);
NLA_PUT_U8(msg, NL80211_ATTR_KEY_IDX, idx); NLA_PUT_U8(msg, NL80211_ATTR_KEY_IDX, idx);
NLA_PUT_U32(msg, NL80211_ATTR_IFINDEX, ifindex); NLA_PUT_U32(msg, NL80211_ATTR_IFINDEX, ifindex);
if (strcmp(alg, "IGTK") == 0) if (alg == WPA_ALG_IGTK)
NLA_PUT_FLAG(msg, NL80211_ATTR_KEY_DEFAULT_MGMT); NLA_PUT_FLAG(msg, NL80211_ATTR_KEY_DEFAULT_MGMT);
else else
NLA_PUT_FLAG(msg, NL80211_ATTR_KEY_DEFAULT); NLA_PUT_FLAG(msg, NL80211_ATTR_KEY_DEFAULT);
@ -340,15 +345,15 @@ static int nl_set_encr(int ifindex, struct i802_driver_data *drv,
} }
static int i802_set_encryption(const char *iface, void *priv, const char *alg, static int i802_set_key(const char *iface, void *priv, wpa_alg alg,
const u8 *addr, int idx, const u8 *key, const u8 *addr, int key_idx, int set_tx, const u8 *seq,
size_t key_len, int txkey) size_t seq_len, const u8 *key, size_t key_len)
{ {
struct i802_driver_data *drv = priv; struct i802_driver_data *drv = priv;
int ret; int ret;
ret = nl_set_encr(if_nametoindex(iface), drv, alg, addr, idx, key, ret = nl_set_encr(if_nametoindex(iface), drv, alg, addr, key_idx, key,
key_len, txkey); key_len, set_tx);
if (ret < 0) if (ret < 0)
return ret; return ret;
@ -3107,7 +3112,7 @@ const struct wpa_driver_ops wpa_driver_nl80211_ops = {
.wireless_event_deinit = i802_wireless_event_deinit, .wireless_event_deinit = i802_wireless_event_deinit,
.set_ieee8021x = i802_set_ieee8021x, .set_ieee8021x = i802_set_ieee8021x,
.set_privacy = i802_set_privacy, .set_privacy = i802_set_privacy,
.set_encryption = i802_set_encryption, .set_key = i802_set_key,
.get_seqnum = i802_get_seqnum, .get_seqnum = i802_get_seqnum,
.flush = i802_flush, .flush = i802_flush,
.read_sta_data = i802_read_sta_data, .read_sta_data = i802_read_sta_data,

View file

@ -205,11 +205,10 @@ prism54_sta_set_flags(void *priv, const u8 *addr, int total_flags,
} }
/* set per station key */ static int prism54_set_key(const char *ifname, void *priv, wpa_alg alg,
static int prism54_set_encryption(const char *ifname, void *priv, const u8 *addr, int key_idx, int set_tx,
const char *alg, const u8 *addr, const u8 *seq, size_t seq_len,
int idx, const u8 *key, size_t key_len, const u8 *key, size_t key_len)
int txkey)
{ {
struct prism54_driver_data *drv = priv; struct prism54_driver_data *drv = priv;
pimdev_hdr *hdr; pimdev_hdr *hdr;
@ -230,22 +229,27 @@ static int prism54_set_encryption(const char *ifname, void *priv,
} else { } else {
memcpy(&keys->address[0], addr, ETH_ALEN); memcpy(&keys->address[0], addr, ETH_ALEN);
} }
if (!strcmp(alg, "WEP")) { switch (alg) {
case WPA_ALG_WEP:
keys->type = DOT11_PRIV_WEP; keys->type = DOT11_PRIV_WEP;
} else if (!strcmp(alg, "TKIP")) { break;
case WPA_ALG_TKIP:
keys->type = DOT11_PRIV_TKIP; keys->type = DOT11_PRIV_TKIP;
} else if (!strcmp(alg, "none")) { break;
case WPA_ALG_NONE:
/* the only way to clear the key is to deauth it */ /* the only way to clear the key is to deauth it */
/* and prism54 is capable to receive unencrypted packet */ /* and prism54 is capable to receive unencrypted packet */
/* so we do nothing here */ /* so we do nothing here */
free(hdr); free(hdr);
return 0; return 0;
} else { default:
printf("bad auth type: %s\n", alg); printf("bad auth type: %d\n", alg);
free(hdr);
return -1;
} }
buf = (u8 *) &keys->key[0]; buf = (u8 *) &keys->key[0];
keys->length = key_len; keys->length = key_len;
keys->keyid = idx; keys->keyid = key_idx;
keys->options = htons(DOT11_STAKEY_OPTION_DEFAULTKEY); keys->options = htons(DOT11_STAKEY_OPTION_DEFAULTKEY);
keys->reserved = 0; keys->reserved = 0;
@ -1079,7 +1083,7 @@ const struct wpa_driver_ops wpa_driver_prism54_ops = {
.deinit = prism54_driver_deinit, .deinit = prism54_driver_deinit,
/* .set_ieee8021x = prism54_init_1x, */ /* .set_ieee8021x = prism54_init_1x, */
.set_privacy = prism54_set_privacy_invoked, .set_privacy = prism54_set_privacy_invoked,
.set_encryption = prism54_set_encryption, .set_key = prism54_set_key,
.get_seqnum = prism54_get_seqnum, .get_seqnum = prism54_get_seqnum,
.flush = prism54_flush, .flush = prism54_flush,
.set_generic_elem = prism54_set_generic_elem, .set_generic_elem = prism54_set_generic_elem,

View file

@ -1006,12 +1006,13 @@ static int test_driver_set_privacy(const char *ifname, void *priv, int enabled)
} }
static int test_driver_set_encryption(const char *iface, void *priv, static int test_driver_set_key(const char *iface, void *priv, wpa_alg alg,
const char *alg, const u8 *addr, int idx, const u8 *addr, int key_idx, int set_tx,
const u8 *key, size_t key_len, int txkey) const u8 *seq, size_t seq_len,
const u8 *key, size_t key_len)
{ {
wpa_printf(MSG_DEBUG, "%s(iface=%s alg=%s idx=%d txkey=%d)", wpa_printf(MSG_DEBUG, "%s(iface=%s alg=%d idx=%d set_tx=%d)",
__func__, iface, alg, idx, txkey); __func__, iface, alg, key_idx, set_tx);
if (addr) if (addr)
wpa_printf(MSG_DEBUG, " addr=" MACSTR, MAC2STR(addr)); wpa_printf(MSG_DEBUG, " addr=" MACSTR, MAC2STR(addr));
if (key) if (key)
@ -1217,7 +1218,7 @@ const struct wpa_driver_ops wpa_driver_test_ops = {
.valid_bss_mask = test_driver_valid_bss_mask, .valid_bss_mask = test_driver_valid_bss_mask,
.set_ssid = test_driver_set_ssid, .set_ssid = test_driver_set_ssid,
.set_privacy = test_driver_set_privacy, .set_privacy = test_driver_set_privacy,
.set_encryption = test_driver_set_encryption, .set_key = test_driver_set_key,
.set_sta_vlan = test_driver_set_sta_vlan, .set_sta_vlan = test_driver_set_sta_vlan,
.sta_add = test_driver_sta_add, .sta_add = test_driver_sta_add,
.send_ether = test_driver_send_ether, .send_ether = test_driver_send_ether,

View file

@ -454,8 +454,8 @@ static void hostapd_broadcast_key_clear_iface(struct hostapd_data *hapd,
int i; int i;
for (i = 0; i < NUM_WEP_KEYS; i++) { for (i = 0; i < NUM_WEP_KEYS; i++) {
if (hostapd_set_encryption(ifname, hapd, "none", NULL, i, NULL, if (hostapd_set_key(ifname, hapd, WPA_ALG_NONE, NULL, i,
0, i == 0 ? 1 : 0)) { i == 0 ? 1 : 0, NULL, 0, NULL, 0)) {
wpa_printf(MSG_DEBUG, "Failed to clear default " wpa_printf(MSG_DEBUG, "Failed to clear default "
"encryption keys (ifname=%s keyidx=%d)", "encryption keys (ifname=%s keyidx=%d)",
ifname, i); ifname, i);
@ -464,9 +464,9 @@ static void hostapd_broadcast_key_clear_iface(struct hostapd_data *hapd,
#ifdef CONFIG_IEEE80211W #ifdef CONFIG_IEEE80211W
if (hapd->conf->ieee80211w) { if (hapd->conf->ieee80211w) {
for (i = NUM_WEP_KEYS; i < NUM_WEP_KEYS + 2; i++) { for (i = NUM_WEP_KEYS; i < NUM_WEP_KEYS + 2; i++) {
if (hostapd_set_encryption(ifname, hapd, "none", NULL, if (hostapd_set_key(ifname, hapd, WPA_ALG_NONE, NULL,
i, NULL, 0, i, i == 0 ? 1 : 0, NULL, 0,
i == 0 ? 1 : 0)) { NULL, 0)) {
wpa_printf(MSG_DEBUG, "Failed to clear " wpa_printf(MSG_DEBUG, "Failed to clear "
"default mgmt encryption keys " "default mgmt encryption keys "
"(ifname=%s keyidx=%d)", ifname, i); "(ifname=%s keyidx=%d)", ifname, i);
@ -491,11 +491,9 @@ static int hostapd_broadcast_wep_set(struct hostapd_data *hapd)
idx = ssid->wep.idx; idx = ssid->wep.idx;
if (ssid->wep.default_len && if (ssid->wep.default_len &&
hostapd_set_encryption(hapd->conf->iface, hostapd_set_key(hapd->conf->iface,
hapd, "WEP", NULL, idx, hapd, WPA_ALG_WEP, NULL, idx, idx == ssid->wep.idx,
ssid->wep.key[idx], NULL, 0, ssid->wep.key[idx], ssid->wep.len[idx])) {
ssid->wep.len[idx],
idx == ssid->wep.idx)) {
wpa_printf(MSG_WARNING, "Could not set WEP encryption."); wpa_printf(MSG_WARNING, "Could not set WEP encryption.");
errors++; errors++;
} }
@ -513,10 +511,9 @@ static int hostapd_broadcast_wep_set(struct hostapd_data *hapd)
continue; continue;
idx = key->idx; idx = key->idx;
if (hostapd_set_encryption(ifname, hapd, "WEP", NULL, if (hostapd_set_key(ifname, hapd, WPA_ALG_WEP, NULL,
idx, key->key[idx], idx, idx == key->idx, NULL, 0,
key->len[idx], key->key[idx], key->len[idx])) {
idx == key->idx)) {
wpa_printf(MSG_WARNING, "Could not set " wpa_printf(MSG_WARNING, "Could not set "
"dynamic VLAN WEP encryption."); "dynamic VLAN WEP encryption.");
errors++; errors++;
@ -647,10 +644,10 @@ static int hostapd_setup_encryption(char *iface, struct hostapd_data *hapd)
for (i = 0; i < 4; i++) { for (i = 0; i < 4; i++) {
if (hapd->conf->ssid.wep.key[i] && if (hapd->conf->ssid.wep.key[i] &&
hostapd_set_encryption(iface, hapd, "WEP", NULL, hostapd_set_key(iface, hapd, WPA_ALG_WEP, NULL, i,
i, hapd->conf->ssid.wep.key[i], i == hapd->conf->ssid.wep.idx, NULL, 0,
hapd->conf->ssid.wep.len[i], hapd->conf->ssid.wep.key[i],
i == hapd->conf->ssid.wep.idx)) { hapd->conf->ssid.wep.len[i])) {
wpa_printf(MSG_WARNING, "Could not set WEP " wpa_printf(MSG_WARNING, "Could not set WEP "
"encryption."); "encryption.");
return -1; return -1;
@ -839,7 +836,7 @@ static int hostapd_wpa_auth_get_msk(void *ctx, const u8 *addr, u8 *msk,
} }
static int hostapd_wpa_auth_set_key(void *ctx, int vlan_id, const char *alg, static int hostapd_wpa_auth_set_key(void *ctx, int vlan_id, wpa_alg alg,
const u8 *addr, int idx, u8 *key, const u8 *addr, int idx, u8 *key,
size_t key_len) size_t key_len)
{ {
@ -852,8 +849,8 @@ static int hostapd_wpa_auth_set_key(void *ctx, int vlan_id, const char *alg,
return -1; return -1;
} }
return hostapd_set_encryption(ifname, hapd, alg, addr, idx, return hostapd_set_key(ifname, hapd, alg, addr, idx, 1, NULL, 0,
key, key_len, 1); key, key_len);
} }

View file

@ -220,8 +220,8 @@ ieee802_1x_group_alloc(struct hostapd_data *hapd, const char *ifname)
wpa_hexdump_key(MSG_DEBUG, "Default WEP key (dynamic VLAN)", wpa_hexdump_key(MSG_DEBUG, "Default WEP key (dynamic VLAN)",
key->key[key->idx], key->len[key->idx]); key->key[key->idx], key->len[key->idx]);
if (hostapd_set_encryption(ifname, hapd, "WEP", NULL, key->idx, if (hostapd_set_key(ifname, hapd, WPA_ALG_WEP, NULL, key->idx, 1,
key->key[key->idx], key->len[key->idx], 1)) NULL, 0, key->key[key->idx], key->len[key->idx]))
printf("Could not set dynamic VLAN WEP encryption key.\n"); printf("Could not set dynamic VLAN WEP encryption key.\n");
hostapd_set_ieee8021x(ifname, hapd, 1); hostapd_set_ieee8021x(ifname, hapd, 1);
@ -335,10 +335,9 @@ void ieee802_1x_tx_key(struct hostapd_data *hapd, struct sta_info *sta)
/* TODO: set encryption in TX callback, i.e., only after STA /* TODO: set encryption in TX callback, i.e., only after STA
* has ACKed EAPOL-Key frame */ * has ACKed EAPOL-Key frame */
if (hostapd_set_encryption(hapd->conf->iface, hapd, "WEP", if (hostapd_set_key(hapd->conf->iface, hapd, WPA_ALG_WEP,
sta->addr, 0, ikey, sta->addr, 0, 1, NULL, 0, ikey,
hapd->conf->individual_wep_key_len, hapd->conf->individual_wep_key_len)) {
1)) {
wpa_printf(MSG_ERROR, "Could not set individual WEP " wpa_printf(MSG_ERROR, "Could not set individual WEP "
"encryption."); "encryption.");
} }
@ -1483,10 +1482,10 @@ static void ieee802_1x_rekey(void *eloop_ctx, void *timeout_ctx)
/* TODO: Could setup key for RX here, but change default TX keyid only /* TODO: Could setup key for RX here, but change default TX keyid only
* after new broadcast key has been sent to all stations. */ * after new broadcast key has been sent to all stations. */
if (hostapd_set_encryption(hapd->conf->iface, hapd, "WEP", NULL, if (hostapd_set_key(hapd->conf->iface, hapd, WPA_ALG_WEP, NULL,
hapd->default_wep_key_idx, hapd->default_wep_key_idx, 1, NULL, 0,
hapd->default_wep_key, hapd->default_wep_key,
hapd->conf->default_wep_key_len, 1)) { hapd->conf->default_wep_key_len)) {
hostapd_logger(hapd, NULL, HOSTAPD_MODULE_IEEE8021X, hostapd_logger(hapd, NULL, HOSTAPD_MODULE_IEEE8021X,
HOSTAPD_LEVEL_WARNING, "failed to configure a " HOSTAPD_LEVEL_WARNING, "failed to configure a "
"new broadcast key"); "new broadcast key");
@ -1691,8 +1690,8 @@ int ieee802_1x_init(struct hostapd_data *hapd)
hostapd_set_privacy(hapd, 1); hostapd_set_privacy(hapd, 1);
for (i = 0; i < 4; i++) for (i = 0; i < 4; i++)
hostapd_set_encryption(hapd->conf->iface, hapd, hostapd_set_key(hapd->conf->iface, hapd, WPA_ALG_NONE,
"none", NULL, i, NULL, 0, 0); NULL, i, 0, NULL, 0, NULL, 0);
ieee802_1x_rekey(hapd, NULL); ieee802_1x_rekey(hapd, NULL);

View file

@ -661,10 +661,9 @@ int vlan_setup_encryption_dyn(struct hostapd_data *hapd,
* functions for setting up dynamic broadcast keys. */ * functions for setting up dynamic broadcast keys. */
for (i = 0; i < 4; i++) { for (i = 0; i < 4; i++) {
if (mssid->wep.key[i] && if (mssid->wep.key[i] &&
hostapd_set_encryption(dyn_vlan, hapd, "WEP", NULL, hostapd_set_key(dyn_vlan, hapd, WPA_ALG_WEP, NULL, i,
i, mssid->wep.key[i], i == mssid->wep.idx, NULL, 0,
mssid->wep.len[i], mssid->wep.key[i], mssid->wep.len[i])) {
i == mssid->wep.idx)) {
printf("VLAN: Could not set WEP encryption for " printf("VLAN: Could not set WEP encryption for "
"dynamic VLAN.\n"); "dynamic VLAN.\n");
return -1; return -1;

View file

@ -102,7 +102,7 @@ static inline int wpa_auth_get_msk(struct wpa_authenticator *wpa_auth,
static inline int wpa_auth_set_key(struct wpa_authenticator *wpa_auth, static inline int wpa_auth_set_key(struct wpa_authenticator *wpa_auth,
int vlan_id, int vlan_id,
const char *alg, const u8 *addr, int idx, wpa_alg alg, const u8 *addr, int idx,
u8 *key, size_t key_len) u8 *key, size_t key_len)
{ {
if (wpa_auth->cb.set_key == NULL) if (wpa_auth->cb.set_key == NULL)
@ -1143,7 +1143,8 @@ void wpa_remove_ptk(struct wpa_state_machine *sm)
{ {
sm->PTK_valid = FALSE; sm->PTK_valid = FALSE;
os_memset(&sm->PTK, 0, sizeof(sm->PTK)); os_memset(&sm->PTK, 0, sizeof(sm->PTK));
wpa_auth_set_key(sm->wpa_auth, 0, "none", sm->addr, 0, (u8 *) "", 0); wpa_auth_set_key(sm->wpa_auth, 0, WPA_ALG_NONE, sm->addr, 0, (u8 *) "",
0);
sm->pairwise_set = FALSE; sm->pairwise_set = FALSE;
eloop_cancel_timeout(wpa_rekey_ptk, sm->wpa_auth, sm); eloop_cancel_timeout(wpa_rekey_ptk, sm->wpa_auth, sm);
} }
@ -1211,18 +1212,18 @@ void wpa_auth_sm_event(struct wpa_state_machine *sm, wpa_event event)
} }
static const char * wpa_alg_txt(int alg) static wpa_alg wpa_alg_enum(int alg)
{ {
switch (alg) { switch (alg) {
case WPA_CIPHER_CCMP: case WPA_CIPHER_CCMP:
return "CCMP"; return WPA_ALG_CCMP;
case WPA_CIPHER_TKIP: case WPA_CIPHER_TKIP:
return "TKIP"; return WPA_ALG_TKIP;
case WPA_CIPHER_WEP104: case WPA_CIPHER_WEP104:
case WPA_CIPHER_WEP40: case WPA_CIPHER_WEP40:
return "WEP"; return WPA_ALG_WEP;
default: default:
return ""; return WPA_ALG_NONE;
} }
} }
@ -1610,13 +1611,13 @@ SM_STATE(WPA_PTK, PTKINITDONE)
SM_ENTRY_MA(WPA_PTK, PTKINITDONE, wpa_ptk); SM_ENTRY_MA(WPA_PTK, PTKINITDONE, wpa_ptk);
sm->EAPOLKeyReceived = FALSE; sm->EAPOLKeyReceived = FALSE;
if (sm->Pair) { if (sm->Pair) {
char *alg; wpa_alg alg;
int klen; int klen;
if (sm->pairwise == WPA_CIPHER_TKIP) { if (sm->pairwise == WPA_CIPHER_TKIP) {
alg = "TKIP"; alg = WPA_ALG_TKIP;
klen = 32; klen = 32;
} else { } else {
alg = "CCMP"; alg = WPA_ALG_CCMP;
klen = 16; klen = 16;
} }
if (wpa_auth_set_key(sm->wpa_auth, 0, alg, sm->addr, 0, if (wpa_auth_set_key(sm->wpa_auth, 0, alg, sm->addr, 0,
@ -1996,13 +1997,13 @@ static void wpa_group_setkeysdone(struct wpa_authenticator *wpa_auth,
group->changed = TRUE; group->changed = TRUE;
group->wpa_group_state = WPA_GROUP_SETKEYSDONE; group->wpa_group_state = WPA_GROUP_SETKEYSDONE;
wpa_auth_set_key(wpa_auth, group->vlan_id, wpa_auth_set_key(wpa_auth, group->vlan_id,
wpa_alg_txt(wpa_auth->conf.wpa_group), wpa_alg_enum(wpa_auth->conf.wpa_group),
NULL, group->GN, group->GTK[group->GN - 1], NULL, group->GN, group->GTK[group->GN - 1],
group->GTK_len); group->GTK_len);
#ifdef CONFIG_IEEE80211W #ifdef CONFIG_IEEE80211W
if (wpa_auth->conf.ieee80211w != WPA_NO_IEEE80211W) { if (wpa_auth->conf.ieee80211w != WPA_NO_IEEE80211W) {
wpa_auth_set_key(wpa_auth, group->vlan_id, "IGTK", wpa_auth_set_key(wpa_auth, group->vlan_id, WPA_ALG_IGTK,
NULL, group->GN_igtk, NULL, group->GN_igtk,
group->IGTK[group->GN_igtk - 4], group->IGTK[group->GN_igtk - 4],
WPA_IGTK_LEN); WPA_IGTK_LEN);

View file

@ -15,6 +15,7 @@
#ifndef WPA_AUTH_H #ifndef WPA_AUTH_H
#define WPA_AUTH_H #define WPA_AUTH_H
#include "defs.h"
#include "eapol_common.h" #include "eapol_common.h"
#include "wpa_common.h" #include "wpa_common.h"
@ -187,7 +188,7 @@ struct wpa_auth_callbacks {
int (*get_eapol)(void *ctx, const u8 *addr, wpa_eapol_variable var); int (*get_eapol)(void *ctx, const u8 *addr, wpa_eapol_variable var);
const u8 * (*get_psk)(void *ctx, const u8 *addr, const u8 *prev_psk); const u8 * (*get_psk)(void *ctx, const u8 *addr, const u8 *prev_psk);
int (*get_msk)(void *ctx, const u8 *addr, u8 *msk, size_t *len); int (*get_msk)(void *ctx, const u8 *addr, u8 *msk, size_t *len);
int (*set_key)(void *ctx, int vlan_id, const char *alg, const u8 *addr, int (*set_key)(void *ctx, int vlan_id, wpa_alg alg, const u8 *addr,
int idx, u8 *key, size_t key_len); int idx, u8 *key, size_t key_len);
int (*get_seqnum)(void *ctx, const u8 *addr, int idx, u8 *seq); int (*get_seqnum)(void *ctx, const u8 *addr, int idx, u8 *seq);
int (*get_seqnum_igtk)(void *ctx, const u8 *addr, int idx, u8 *seq); int (*get_seqnum_igtk)(void *ctx, const u8 *addr, int idx, u8 *seq);

View file

@ -840,7 +840,7 @@ static int wpa_ft_parse_ies(const u8 *ies, size_t ies_len,
static inline int wpa_auth_set_key(struct wpa_authenticator *wpa_auth, static inline int wpa_auth_set_key(struct wpa_authenticator *wpa_auth,
int vlan_id, int vlan_id,
const char *alg, const u8 *addr, int idx, wpa_alg alg, const u8 *addr, int idx,
u8 *key, size_t key_len) u8 *key, size_t key_len)
{ {
if (wpa_auth->cb.set_key == NULL) if (wpa_auth->cb.set_key == NULL)
@ -852,15 +852,15 @@ static inline int wpa_auth_set_key(struct wpa_authenticator *wpa_auth,
static void wpa_ft_install_ptk(struct wpa_state_machine *sm) static void wpa_ft_install_ptk(struct wpa_state_machine *sm)
{ {
char *alg; wpa_alg alg;
int klen; int klen;
/* MLME-SETKEYS.request(PTK) */ /* MLME-SETKEYS.request(PTK) */
if (sm->pairwise == WPA_CIPHER_TKIP) { if (sm->pairwise == WPA_CIPHER_TKIP) {
alg = "TKIP"; alg = WPA_ALG_TKIP;
klen = 32; klen = 32;
} else if (sm->pairwise == WPA_CIPHER_CCMP) { } else if (sm->pairwise == WPA_CIPHER_CCMP) {
alg = "CCMP"; alg = WPA_ALG_CCMP;
klen = 16; klen = 16;
} else } else
return; return;