mirror of
https://github.com/vanhoefm/fragattacks.git
synced 2025-01-18 02:44:03 -05:00
9f2cf23e2e
This patch add functionality of mesh SAE PMKSA caching. If the local STA
already has peer's PMKSA entry in the cache, skip SAE authentication and
start AMPE with the cached value.
If the peer does not support PMKSA caching or does not have the local
STA's PMKSA entry in the cache, AMPE will fail and the PMKSA cache entry
of the peer will be removed. Then STA retries with ordinary SAE
authentication.
If the peer does not support PMKSA caching and the local STA uses
no_auto_peer=1, the local STA can not retry SAE authentication because
NEW_PEER_CANDIDATE event cannot start SAE authentication when
no_auto_peer=1. So this patch extends MESH_PEER_ADD command to use
duration(sec). Throughout the duration, the local STA can start SAE
authentication triggered by NEW_PEER_CANDIDATE even though
no_auto_peer=1.
This commit requires commit 70c93963ed
('SAE: Fix PMKID calculation for PMKSA cache'). Without that commit,
chosen PMK comparison will fail.
Signed-off-by: Masashi Honma <masashi.honma@gmail.com>
47 lines
1.5 KiB
C
47 lines
1.5 KiB
C
/*
|
|
* WPA Supplicant - Basic mesh peer management
|
|
* Copyright (c) 2013-2014, cozybit, Inc. All rights reserved.
|
|
*
|
|
* This software may be distributed under the terms of the BSD license.
|
|
* See README for more details.
|
|
*/
|
|
|
|
#ifndef MESH_MPM_H
|
|
#define MESH_MPM_H
|
|
|
|
/* notify MPM of new mesh peer to be inserted in MPM and driver */
|
|
void wpa_mesh_new_mesh_peer(struct wpa_supplicant *wpa_s, const u8 *addr,
|
|
struct ieee802_11_elems *elems);
|
|
void mesh_mpm_deinit(struct wpa_supplicant *wpa_s, struct hostapd_iface *ifmsh);
|
|
void mesh_mpm_auth_peer(struct wpa_supplicant *wpa_s, const u8 *addr);
|
|
void mesh_mpm_free_sta(struct hostapd_data *hapd, struct sta_info *sta);
|
|
void wpa_mesh_set_plink_state(struct wpa_supplicant *wpa_s,
|
|
struct sta_info *sta,
|
|
enum mesh_plink_state state);
|
|
int mesh_mpm_close_peer(struct wpa_supplicant *wpa_s, const u8 *addr);
|
|
int mesh_mpm_connect_peer(struct wpa_supplicant *wpa_s, const u8 *addr,
|
|
int duration);
|
|
|
|
#ifdef CONFIG_MESH
|
|
|
|
void mesh_mpm_action_rx(struct wpa_supplicant *wpa_s,
|
|
const struct ieee80211_mgmt *mgmt, size_t len);
|
|
void mesh_mpm_mgmt_rx(struct wpa_supplicant *wpa_s, struct rx_mgmt *rx_mgmt);
|
|
|
|
#else /* CONFIG_MESH */
|
|
|
|
static inline void mesh_mpm_action_rx(struct wpa_supplicant *wpa_s,
|
|
const struct ieee80211_mgmt *mgmt,
|
|
size_t len)
|
|
{
|
|
}
|
|
|
|
static inline void mesh_mpm_mgmt_rx(struct wpa_supplicant *wpa_s,
|
|
struct rx_mgmt *rx_mgmt)
|
|
{
|
|
}
|
|
|
|
#endif /* CONFIG_MESH */
|
|
|
|
#endif /* MESH_MPM_H */
|