mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-05 04:32:34 +01:00
netdev: separate over-air and over-ds netdev APIs
This commit is contained in:
parent
0d45316891
commit
6c5fe246a7
66
src/netdev.c
66
src/netdev.c
@ -3658,10 +3658,25 @@ static void prepare_ft(struct netdev *netdev, struct scan_bss *target_bss)
|
|||||||
{
|
{
|
||||||
struct netdev_handshake_state *nhs;
|
struct netdev_handshake_state *nhs;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We reuse the handshake_state object and reset what's needed.
|
||||||
|
* Could also create a new object and copy most of the state but
|
||||||
|
* we would end up doing more work.
|
||||||
|
*/
|
||||||
|
memcpy(netdev->prev_snonce, netdev->handshake->snonce, 32);
|
||||||
|
|
||||||
memcpy(netdev->prev_bssid, netdev->handshake->aa, 6);
|
memcpy(netdev->prev_bssid, netdev->handshake->aa, 6);
|
||||||
netdev->prev_frequency = netdev->frequency;
|
netdev->prev_frequency = netdev->frequency;
|
||||||
netdev->frequency = target_bss->frequency;
|
netdev->frequency = target_bss->frequency;
|
||||||
|
|
||||||
|
handshake_state_set_authenticator_address(netdev->handshake,
|
||||||
|
target_bss->addr);
|
||||||
|
|
||||||
|
if (target_bss->rsne)
|
||||||
|
handshake_state_set_authenticator_ie(netdev->handshake,
|
||||||
|
target_bss->rsne);
|
||||||
|
memcpy(netdev->handshake->mde + 2, target_bss->mde, 3);
|
||||||
|
|
||||||
netdev->associated = false;
|
netdev->associated = false;
|
||||||
netdev->operational = false;
|
netdev->operational = false;
|
||||||
netdev->in_ft = true;
|
netdev->in_ft = true;
|
||||||
@ -3809,8 +3824,7 @@ static const struct wiphy_radio_work_item_ops ft_work_ops = {
|
|||||||
.do_work = netdev_ft_work_ready,
|
.do_work = netdev_ft_work_ready,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int fast_transition(struct netdev *netdev, struct scan_bss *target_bss,
|
int netdev_fast_transition(struct netdev *netdev, struct scan_bss *target_bss,
|
||||||
bool over_air,
|
|
||||||
netdev_connect_cb_t cb)
|
netdev_connect_cb_t cb)
|
||||||
{
|
{
|
||||||
if (!netdev->operational)
|
if (!netdev->operational)
|
||||||
@ -3823,32 +3837,13 @@ static int fast_transition(struct netdev *netdev, struct scan_bss *target_bss,
|
|||||||
|
|
||||||
prepare_ft(netdev, target_bss);
|
prepare_ft(netdev, target_bss);
|
||||||
|
|
||||||
/*
|
|
||||||
* We reuse the handshake_state object and reset what's needed.
|
|
||||||
* Could also create a new object and copy most of the state but
|
|
||||||
* we would end up doing more work.
|
|
||||||
*/
|
|
||||||
memcpy(netdev->prev_snonce, netdev->handshake->snonce, 32);
|
|
||||||
handshake_state_new_snonce(netdev->handshake);
|
handshake_state_new_snonce(netdev->handshake);
|
||||||
|
|
||||||
handshake_state_set_authenticator_address(netdev->handshake,
|
|
||||||
target_bss->addr);
|
|
||||||
|
|
||||||
if (target_bss->rsne)
|
|
||||||
handshake_state_set_authenticator_ie(netdev->handshake,
|
|
||||||
target_bss->rsne);
|
|
||||||
memcpy(netdev->handshake->mde + 2, target_bss->mde, 3);
|
|
||||||
|
|
||||||
netdev->connect_cb = cb;
|
netdev->connect_cb = cb;
|
||||||
|
|
||||||
if (over_air)
|
|
||||||
netdev->ap = ft_over_air_sm_new(netdev->handshake,
|
netdev->ap = ft_over_air_sm_new(netdev->handshake,
|
||||||
netdev_ft_tx_authenticate,
|
netdev_ft_tx_authenticate,
|
||||||
netdev_ft_tx_associate, netdev);
|
netdev_ft_tx_associate, netdev);
|
||||||
else
|
|
||||||
netdev->ap = ft_over_ds_sm_new(netdev->handshake,
|
|
||||||
netdev_ft_over_ds_tx_authenticate,
|
|
||||||
netdev_ft_tx_associate, netdev);
|
|
||||||
|
|
||||||
wiphy_radio_work_insert(netdev->wiphy, &netdev->work, 1,
|
wiphy_radio_work_insert(netdev->wiphy, &netdev->work, 1,
|
||||||
&ft_work_ops);
|
&ft_work_ops);
|
||||||
@ -3856,17 +3851,32 @@ static int fast_transition(struct netdev *netdev, struct scan_bss *target_bss,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int netdev_fast_transition(struct netdev *netdev, struct scan_bss *target_bss,
|
|
||||||
netdev_connect_cb_t cb)
|
|
||||||
{
|
|
||||||
return fast_transition(netdev, target_bss, true, cb);
|
|
||||||
}
|
|
||||||
|
|
||||||
int netdev_fast_transition_over_ds(struct netdev *netdev,
|
int netdev_fast_transition_over_ds(struct netdev *netdev,
|
||||||
struct scan_bss *target_bss,
|
struct scan_bss *target_bss,
|
||||||
netdev_connect_cb_t cb)
|
netdev_connect_cb_t cb)
|
||||||
{
|
{
|
||||||
return fast_transition(netdev, target_bss, false, cb);
|
if (!netdev->operational)
|
||||||
|
return -ENOTCONN;
|
||||||
|
|
||||||
|
if (!netdev->handshake->mde || !target_bss->mde_present ||
|
||||||
|
l_get_le16(netdev->handshake->mde + 2) !=
|
||||||
|
l_get_le16(target_bss->mde))
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
prepare_ft(netdev, target_bss);
|
||||||
|
|
||||||
|
handshake_state_new_snonce(netdev->handshake);
|
||||||
|
|
||||||
|
netdev->connect_cb = cb;
|
||||||
|
|
||||||
|
netdev->ap = ft_over_ds_sm_new(netdev->handshake,
|
||||||
|
netdev_ft_over_ds_tx_authenticate,
|
||||||
|
netdev_ft_tx_associate, netdev);
|
||||||
|
|
||||||
|
wiphy_radio_work_insert(netdev->wiphy, &netdev->work, 1,
|
||||||
|
&ft_work_ops);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void netdev_preauth_cb(const uint8_t *pmk, void *user_data)
|
static void netdev_preauth_cb(const uint8_t *pmk, void *user_data)
|
||||||
|
Loading…
Reference in New Issue
Block a user