139beb93cSSam Leffler /* 239beb93cSSam Leffler * wpa_supplicant - WPA2/RSN PMKSA cache functions 3f05cddf9SRui Paulo * Copyright (c) 2003-2009, 2011-2012, Jouni Malinen <j@w1.fi> 439beb93cSSam Leffler * 5f05cddf9SRui Paulo * This software may be distributed under the terms of the BSD license. 6f05cddf9SRui Paulo * See README for more details. 739beb93cSSam Leffler */ 839beb93cSSam Leffler 939beb93cSSam Leffler #ifndef PMKSA_CACHE_H 1039beb93cSSam Leffler #define PMKSA_CACHE_H 1139beb93cSSam Leffler 1239beb93cSSam Leffler /** 1339beb93cSSam Leffler * struct rsn_pmksa_cache_entry - PMKSA cache entry 1439beb93cSSam Leffler */ 1539beb93cSSam Leffler struct rsn_pmksa_cache_entry { 1639beb93cSSam Leffler struct rsn_pmksa_cache_entry *next; 1739beb93cSSam Leffler u8 pmkid[PMKID_LEN]; 18780fb4a2SCy Schubert u8 pmk[PMK_LEN_MAX]; 1939beb93cSSam Leffler size_t pmk_len; 2039beb93cSSam Leffler os_time_t expiration; 2139beb93cSSam Leffler int akmp; /* WPA_KEY_MGMT_* */ 2239beb93cSSam Leffler u8 aa[ETH_ALEN]; 2339beb93cSSam Leffler 2485732ac8SCy Schubert /* 2585732ac8SCy Schubert * If FILS Cache Identifier is included (fils_cache_id_set), this PMKSA 2685732ac8SCy Schubert * cache entry is applicable to all BSSs (any BSSID/aa[]) that 2785732ac8SCy Schubert * advertise the same FILS Cache Identifier within the same ESS. 2885732ac8SCy Schubert */ 2985732ac8SCy Schubert u8 fils_cache_id[2]; 3085732ac8SCy Schubert unsigned int fils_cache_id_set:1; 31*c1d255d3SCy Schubert unsigned int dpp_pfs:1; 3285732ac8SCy Schubert 3339beb93cSSam Leffler os_time_t reauth_time; 3439beb93cSSam Leffler 3539beb93cSSam Leffler /** 3639beb93cSSam Leffler * network_ctx - Network configuration context 3739beb93cSSam Leffler * 3839beb93cSSam Leffler * This field is only used to match PMKSA cache entries to a specific 3939beb93cSSam Leffler * network configuration (e.g., a specific SSID and security policy). 4039beb93cSSam Leffler * This can be a pointer to the configuration entry, but PMKSA caching 4139beb93cSSam Leffler * code does not dereference the value and this could be any kind of 4239beb93cSSam Leffler * identifier. 4339beb93cSSam Leffler */ 4439beb93cSSam Leffler void *network_ctx; 4539beb93cSSam Leffler int opportunistic; 46*c1d255d3SCy Schubert bool external; 4739beb93cSSam Leffler }; 4839beb93cSSam Leffler 4939beb93cSSam Leffler struct rsn_pmksa_cache; 5039beb93cSSam Leffler 51f05cddf9SRui Paulo enum pmksa_free_reason { 52f05cddf9SRui Paulo PMKSA_FREE, 53f05cddf9SRui Paulo PMKSA_REPLACE, 54f05cddf9SRui Paulo PMKSA_EXPIRE, 55f05cddf9SRui Paulo }; 56f05cddf9SRui Paulo 57780fb4a2SCy Schubert #if defined(IEEE8021X_EAPOL) && !defined(CONFIG_NO_WPA) 5839beb93cSSam Leffler 5939beb93cSSam Leffler struct rsn_pmksa_cache * 6039beb93cSSam Leffler pmksa_cache_init(void (*free_cb)(struct rsn_pmksa_cache_entry *entry, 61f05cddf9SRui Paulo void *ctx, enum pmksa_free_reason reason), 6239beb93cSSam Leffler void *ctx, struct wpa_sm *sm); 6339beb93cSSam Leffler void pmksa_cache_deinit(struct rsn_pmksa_cache *pmksa); 6439beb93cSSam Leffler struct rsn_pmksa_cache_entry * pmksa_cache_get(struct rsn_pmksa_cache *pmksa, 65f05cddf9SRui Paulo const u8 *aa, const u8 *pmkid, 6685732ac8SCy Schubert const void *network_ctx, 6785732ac8SCy Schubert int akmp); 68e28a4053SRui Paulo int pmksa_cache_list(struct rsn_pmksa_cache *pmksa, char *buf, size_t len); 6985732ac8SCy Schubert struct rsn_pmksa_cache_entry * pmksa_cache_head(struct rsn_pmksa_cache *pmksa); 7039beb93cSSam Leffler struct rsn_pmksa_cache_entry * 7139beb93cSSam Leffler pmksa_cache_add(struct rsn_pmksa_cache *pmksa, const u8 *pmk, size_t pmk_len, 72780fb4a2SCy Schubert const u8 *pmkid, const u8 *kck, size_t kck_len, 7385732ac8SCy Schubert const u8 *aa, const u8 *spa, void *network_ctx, int akmp, 7485732ac8SCy Schubert const u8 *cache_id); 7585732ac8SCy Schubert struct rsn_pmksa_cache_entry * 7685732ac8SCy Schubert pmksa_cache_add_entry(struct rsn_pmksa_cache *pmksa, 7785732ac8SCy Schubert struct rsn_pmksa_cache_entry *entry); 7839beb93cSSam Leffler struct rsn_pmksa_cache_entry * pmksa_cache_get_current(struct wpa_sm *sm); 7939beb93cSSam Leffler void pmksa_cache_clear_current(struct wpa_sm *sm); 8039beb93cSSam Leffler int pmksa_cache_set_current(struct wpa_sm *sm, const u8 *pmkid, 8139beb93cSSam Leffler const u8 *bssid, void *network_ctx, 8285732ac8SCy Schubert int try_opportunistic, const u8 *fils_cache_id, 8385732ac8SCy Schubert int akmp); 8439beb93cSSam Leffler struct rsn_pmksa_cache_entry * 8539beb93cSSam Leffler pmksa_cache_get_opportunistic(struct rsn_pmksa_cache *pmksa, 8685732ac8SCy Schubert void *network_ctx, const u8 *aa, int akmp); 875b9c547cSRui Paulo void pmksa_cache_flush(struct rsn_pmksa_cache *pmksa, void *network_ctx, 88*c1d255d3SCy Schubert const u8 *pmk, size_t pmk_len, bool external_only); 8939beb93cSSam Leffler 905b9c547cSRui Paulo #else /* IEEE8021X_EAPOL */ 9139beb93cSSam Leffler 9239beb93cSSam Leffler static inline struct rsn_pmksa_cache * 9339beb93cSSam Leffler pmksa_cache_init(void (*free_cb)(struct rsn_pmksa_cache_entry *entry, 945b9c547cSRui Paulo void *ctx, enum pmksa_free_reason reason), 9539beb93cSSam Leffler void *ctx, struct wpa_sm *sm) 9639beb93cSSam Leffler { 9739beb93cSSam Leffler return (void *) -1; 9839beb93cSSam Leffler } 9939beb93cSSam Leffler 10039beb93cSSam Leffler static inline void pmksa_cache_deinit(struct rsn_pmksa_cache *pmksa) 10139beb93cSSam Leffler { 10239beb93cSSam Leffler } 10339beb93cSSam Leffler 10439beb93cSSam Leffler static inline struct rsn_pmksa_cache_entry * 105f05cddf9SRui Paulo pmksa_cache_get(struct rsn_pmksa_cache *pmksa, const u8 *aa, const u8 *pmkid, 10685732ac8SCy Schubert const void *network_ctx, int akmp) 10739beb93cSSam Leffler { 10839beb93cSSam Leffler return NULL; 10939beb93cSSam Leffler } 11039beb93cSSam Leffler 11139beb93cSSam Leffler static inline struct rsn_pmksa_cache_entry * 11239beb93cSSam Leffler pmksa_cache_get_current(struct wpa_sm *sm) 11339beb93cSSam Leffler { 11439beb93cSSam Leffler return NULL; 11539beb93cSSam Leffler } 11639beb93cSSam Leffler 117e28a4053SRui Paulo static inline int pmksa_cache_list(struct rsn_pmksa_cache *pmksa, char *buf, 118e28a4053SRui Paulo size_t len) 11939beb93cSSam Leffler { 12039beb93cSSam Leffler return -1; 12139beb93cSSam Leffler } 12239beb93cSSam Leffler 12339beb93cSSam Leffler static inline struct rsn_pmksa_cache_entry * 12485732ac8SCy Schubert pmksa_cache_head(struct rsn_pmksa_cache *pmksa) 12585732ac8SCy Schubert { 12685732ac8SCy Schubert return NULL; 12785732ac8SCy Schubert } 12885732ac8SCy Schubert 12985732ac8SCy Schubert static inline struct rsn_pmksa_cache_entry * 13085732ac8SCy Schubert pmksa_cache_add_entry(struct rsn_pmksa_cache *pmksa, 13185732ac8SCy Schubert struct rsn_pmksa_cache_entry *entry) 13285732ac8SCy Schubert { 13385732ac8SCy Schubert return NULL; 13485732ac8SCy Schubert } 13585732ac8SCy Schubert 13685732ac8SCy Schubert static inline struct rsn_pmksa_cache_entry * 13739beb93cSSam Leffler pmksa_cache_add(struct rsn_pmksa_cache *pmksa, const u8 *pmk, size_t pmk_len, 138780fb4a2SCy Schubert const u8 *pmkid, const u8 *kck, size_t kck_len, 13985732ac8SCy Schubert const u8 *aa, const u8 *spa, void *network_ctx, int akmp, 14085732ac8SCy Schubert const u8 *cache_id) 14139beb93cSSam Leffler { 14239beb93cSSam Leffler return NULL; 14339beb93cSSam Leffler } 14439beb93cSSam Leffler 14539beb93cSSam Leffler static inline void pmksa_cache_clear_current(struct wpa_sm *sm) 14639beb93cSSam Leffler { 14739beb93cSSam Leffler } 14839beb93cSSam Leffler 14939beb93cSSam Leffler static inline int pmksa_cache_set_current(struct wpa_sm *sm, const u8 *pmkid, 15039beb93cSSam Leffler const u8 *bssid, 15139beb93cSSam Leffler void *network_ctx, 15285732ac8SCy Schubert int try_opportunistic, 15385732ac8SCy Schubert const u8 *fils_cache_id, 15485732ac8SCy Schubert int akmp) 15539beb93cSSam Leffler { 15639beb93cSSam Leffler return -1; 15739beb93cSSam Leffler } 15839beb93cSSam Leffler 159f05cddf9SRui Paulo static inline void pmksa_cache_flush(struct rsn_pmksa_cache *pmksa, 1605b9c547cSRui Paulo void *network_ctx, 161*c1d255d3SCy Schubert const u8 *pmk, size_t pmk_len, 162*c1d255d3SCy Schubert bool external_only) 163f05cddf9SRui Paulo { 164f05cddf9SRui Paulo } 165f05cddf9SRui Paulo 1665b9c547cSRui Paulo #endif /* IEEE8021X_EAPOL */ 16739beb93cSSam Leffler 16839beb93cSSam Leffler #endif /* PMKSA_CACHE_H */ 169