3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-03 19:02:34 +01:00

netdev: Remove un-needed pairwise set_key call

This seems to be no longer needed as the kernel looks up the key by the
sta specific key index.
This commit is contained in:
Denis Kenzior 2018-06-21 17:32:54 -07:00
parent 2177b22caa
commit b5e01226cb

View File

@ -77,7 +77,6 @@ struct netdev {
struct eapol_sm *sm; struct eapol_sm *sm;
struct handshake_state *handshake; struct handshake_state *handshake;
uint32_t pairwise_new_key_cmd_id; uint32_t pairwise_new_key_cmd_id;
uint32_t pairwise_set_key_cmd_id;
uint32_t group_new_key_cmd_id; uint32_t group_new_key_cmd_id;
uint32_t group_management_new_key_cmd_id; uint32_t group_management_new_key_cmd_id;
uint32_t set_station_cmd_id; uint32_t set_station_cmd_id;
@ -478,11 +477,6 @@ static void netdev_connect_free(struct netdev *netdev)
netdev->pairwise_new_key_cmd_id = 0; netdev->pairwise_new_key_cmd_id = 0;
} }
if (netdev->pairwise_set_key_cmd_id) {
l_genl_family_cancel(nl80211, netdev->pairwise_set_key_cmd_id);
netdev->pairwise_set_key_cmd_id = 0;
}
if (netdev->group_new_key_cmd_id) { if (netdev->group_new_key_cmd_id) {
l_genl_family_cancel(nl80211, netdev->group_new_key_cmd_id); l_genl_family_cancel(nl80211, netdev->group_new_key_cmd_id);
netdev->group_new_key_cmd_id = 0; netdev->group_new_key_cmd_id = 0;
@ -900,22 +894,21 @@ static void netdev_setting_keys_failed(struct netdev *netdev,
struct l_genl_msg *msg; struct l_genl_msg *msg;
/* /*
* Something went wrong with our new_key, set_key, new_key, * Something went wrong with our sequence:
* set_station * 1. new_key(ptk)
* 2. new_key(gtk) [optional]
* 3. new_key(igtk) [optional]
* 4. set_station
* *
* Cancel all pending commands, then de-authenticate * Cancel all pending commands, then de-authenticate
*/ */
l_genl_family_cancel(nl80211, netdev->pairwise_new_key_cmd_id); l_genl_family_cancel(nl80211, netdev->pairwise_new_key_cmd_id);
netdev->pairwise_new_key_cmd_id = 0; netdev->pairwise_new_key_cmd_id = 0;
l_genl_family_cancel(nl80211, netdev->pairwise_set_key_cmd_id);
netdev->pairwise_set_key_cmd_id = 0;
l_genl_family_cancel(nl80211, netdev->group_new_key_cmd_id); l_genl_family_cancel(nl80211, netdev->group_new_key_cmd_id);
netdev->group_new_key_cmd_id = 0; netdev->group_new_key_cmd_id = 0;
l_genl_family_cancel(nl80211, l_genl_family_cancel(nl80211, netdev->group_management_new_key_cmd_id);
netdev->group_management_new_key_cmd_id);
netdev->group_management_new_key_cmd_id = 0; netdev->group_management_new_key_cmd_id = 0;
l_genl_family_cancel(nl80211, netdev->set_station_cmd_id); l_genl_family_cancel(nl80211, netdev->set_station_cmd_id);
@ -1161,15 +1154,15 @@ static void netdev_set_igtk(uint32_t ifindex, uint8_t key_index,
netdev_setting_keys_failed(netdev, MMPDU_REASON_CODE_UNSPECIFIED); netdev_setting_keys_failed(netdev, MMPDU_REASON_CODE_UNSPECIFIED);
} }
static void netdev_set_pairwise_key_cb(struct l_genl_msg *msg, void *data) static void netdev_new_pairwise_key_cb(struct l_genl_msg *msg, void *data)
{ {
struct netdev *netdev = data; struct netdev *netdev = data;
netdev->pairwise_set_key_cmd_id = 0; netdev->pairwise_new_key_cmd_id = 0;
if (l_genl_msg_get_error(msg) < 0) { if (l_genl_msg_get_error(msg) < 0) {
l_error("Set Key for Pairwise Key failed for ifindex: %d", l_error("New Key for Pairwise Key failed for ifindex: %d",
netdev->index); netdev->index);
goto error; goto error;
} }
@ -1191,40 +1184,6 @@ error:
netdev_setting_keys_failed(netdev, MMPDU_REASON_CODE_UNSPECIFIED); netdev_setting_keys_failed(netdev, MMPDU_REASON_CODE_UNSPECIFIED);
} }
static struct l_genl_msg *netdev_build_cmd_set_key_pairwise(
struct netdev *netdev)
{
uint8_t key_id = 0;
struct l_genl_msg *msg;
msg = l_genl_msg_new_sized(NL80211_CMD_SET_KEY, 512);
l_genl_msg_append_attr(msg, NL80211_ATTR_KEY_IDX, 1, &key_id);
l_genl_msg_append_attr(msg, NL80211_ATTR_IFINDEX, 4, &netdev->index);
l_genl_msg_append_attr(msg, NL80211_ATTR_KEY_DEFAULT, 0, NULL);
l_genl_msg_enter_nested(msg, NL80211_ATTR_KEY_DEFAULT_TYPES);
l_genl_msg_append_attr(msg, NL80211_KEY_DEFAULT_TYPE_UNICAST, 0, NULL);
l_genl_msg_leave_nested(msg);
return msg;
}
static void netdev_new_pairwise_key_cb(struct l_genl_msg *msg, void *data)
{
struct netdev *netdev = data;
netdev->pairwise_new_key_cmd_id = 0;
if (l_genl_msg_get_error(msg) >= 0)
return;
l_error("New Key for Pairwise Key failed for ifindex: %d",
netdev->index);
netdev_setting_keys_failed(netdev, MMPDU_REASON_CODE_UNSPECIFIED);
}
static struct l_genl_msg *netdev_build_cmd_new_key_pairwise( static struct l_genl_msg *netdev_build_cmd_new_key_pairwise(
struct netdev *netdev, struct netdev *netdev,
uint32_t cipher, uint32_t cipher,
@ -1272,19 +1231,12 @@ static void netdev_set_tk(uint32_t ifindex, const uint8_t *aa,
rc = MMPDU_REASON_CODE_UNSPECIFIED; rc = MMPDU_REASON_CODE_UNSPECIFIED;
msg = netdev_build_cmd_new_key_pairwise(netdev, cipher, aa, tk_buf, msg = netdev_build_cmd_new_key_pairwise(netdev, cipher, aa, tk_buf,
crypto_cipher_key_len(cipher)); crypto_cipher_key_len(cipher));
netdev->pairwise_new_key_cmd_id = l_genl_family_send(nl80211, msg, netdev->pairwise_new_key_cmd_id =
netdev_new_pairwise_key_cb, netdev, NULL); l_genl_family_send(nl80211, msg, netdev_new_pairwise_key_cb,
if (!netdev->pairwise_new_key_cmd_id)
goto send_failed;
msg = netdev_build_cmd_set_key_pairwise(netdev);
netdev->pairwise_set_key_cmd_id =
l_genl_family_send(nl80211, msg, netdev_set_pairwise_key_cb,
netdev, NULL); netdev, NULL);
if (netdev->pairwise_set_key_cmd_id > 0) if (netdev->pairwise_new_key_cmd_id > 0)
return; return;
send_failed:
l_genl_msg_unref(msg); l_genl_msg_unref(msg);
invalid_key: invalid_key:
netdev_setting_keys_failed(netdev, rc); netdev_setting_keys_failed(netdev, rc);