16d49e1aeSJan Lentfer /*
26d49e1aeSJan Lentfer * wpa_supplicant - WPA2/RSN PMKSA cache functions
33ff40c12SJohn Marino * Copyright (c) 2003-2009, 2011-2012, Jouni Malinen <j@w1.fi>
46d49e1aeSJan Lentfer *
53ff40c12SJohn Marino * This software may be distributed under the terms of the BSD license.
63ff40c12SJohn Marino * See README for more details.
76d49e1aeSJan Lentfer */
86d49e1aeSJan Lentfer
96d49e1aeSJan Lentfer #ifndef PMKSA_CACHE_H
106d49e1aeSJan Lentfer #define PMKSA_CACHE_H
116d49e1aeSJan Lentfer
126d49e1aeSJan Lentfer /**
136d49e1aeSJan Lentfer * struct rsn_pmksa_cache_entry - PMKSA cache entry
146d49e1aeSJan Lentfer */
156d49e1aeSJan Lentfer struct rsn_pmksa_cache_entry {
166d49e1aeSJan Lentfer struct rsn_pmksa_cache_entry *next;
176d49e1aeSJan Lentfer u8 pmkid[PMKID_LEN];
18*a1157835SDaniel Fojt u8 pmk[PMK_LEN_MAX];
196d49e1aeSJan Lentfer size_t pmk_len;
206d49e1aeSJan Lentfer os_time_t expiration;
216d49e1aeSJan Lentfer int akmp; /* WPA_KEY_MGMT_* */
226d49e1aeSJan Lentfer u8 aa[ETH_ALEN];
236d49e1aeSJan Lentfer
24*a1157835SDaniel Fojt /*
25*a1157835SDaniel Fojt * If FILS Cache Identifier is included (fils_cache_id_set), this PMKSA
26*a1157835SDaniel Fojt * cache entry is applicable to all BSSs (any BSSID/aa[]) that
27*a1157835SDaniel Fojt * advertise the same FILS Cache Identifier within the same ESS.
28*a1157835SDaniel Fojt */
29*a1157835SDaniel Fojt u8 fils_cache_id[2];
30*a1157835SDaniel Fojt unsigned int fils_cache_id_set:1;
31*a1157835SDaniel Fojt
326d49e1aeSJan Lentfer os_time_t reauth_time;
336d49e1aeSJan Lentfer
346d49e1aeSJan Lentfer /**
356d49e1aeSJan Lentfer * network_ctx - Network configuration context
366d49e1aeSJan Lentfer *
376d49e1aeSJan Lentfer * This field is only used to match PMKSA cache entries to a specific
386d49e1aeSJan Lentfer * network configuration (e.g., a specific SSID and security policy).
396d49e1aeSJan Lentfer * This can be a pointer to the configuration entry, but PMKSA caching
406d49e1aeSJan Lentfer * code does not dereference the value and this could be any kind of
416d49e1aeSJan Lentfer * identifier.
426d49e1aeSJan Lentfer */
436d49e1aeSJan Lentfer void *network_ctx;
446d49e1aeSJan Lentfer int opportunistic;
456d49e1aeSJan Lentfer };
466d49e1aeSJan Lentfer
476d49e1aeSJan Lentfer struct rsn_pmksa_cache;
486d49e1aeSJan Lentfer
493ff40c12SJohn Marino enum pmksa_free_reason {
503ff40c12SJohn Marino PMKSA_FREE,
513ff40c12SJohn Marino PMKSA_REPLACE,
523ff40c12SJohn Marino PMKSA_EXPIRE,
533ff40c12SJohn Marino };
543ff40c12SJohn Marino
55*a1157835SDaniel Fojt #if defined(IEEE8021X_EAPOL) && !defined(CONFIG_NO_WPA)
566d49e1aeSJan Lentfer
576d49e1aeSJan Lentfer struct rsn_pmksa_cache *
586d49e1aeSJan Lentfer pmksa_cache_init(void (*free_cb)(struct rsn_pmksa_cache_entry *entry,
593ff40c12SJohn Marino void *ctx, enum pmksa_free_reason reason),
606d49e1aeSJan Lentfer void *ctx, struct wpa_sm *sm);
616d49e1aeSJan Lentfer void pmksa_cache_deinit(struct rsn_pmksa_cache *pmksa);
626d49e1aeSJan Lentfer struct rsn_pmksa_cache_entry * pmksa_cache_get(struct rsn_pmksa_cache *pmksa,
633ff40c12SJohn Marino const u8 *aa, const u8 *pmkid,
64*a1157835SDaniel Fojt const void *network_ctx,
65*a1157835SDaniel Fojt int akmp);
663ff40c12SJohn Marino int pmksa_cache_list(struct rsn_pmksa_cache *pmksa, char *buf, size_t len);
67*a1157835SDaniel Fojt struct rsn_pmksa_cache_entry * pmksa_cache_head(struct rsn_pmksa_cache *pmksa);
686d49e1aeSJan Lentfer struct rsn_pmksa_cache_entry *
696d49e1aeSJan Lentfer pmksa_cache_add(struct rsn_pmksa_cache *pmksa, const u8 *pmk, size_t pmk_len,
70*a1157835SDaniel Fojt const u8 *pmkid, const u8 *kck, size_t kck_len,
71*a1157835SDaniel Fojt const u8 *aa, const u8 *spa, void *network_ctx, int akmp,
72*a1157835SDaniel Fojt const u8 *cache_id);
73*a1157835SDaniel Fojt struct rsn_pmksa_cache_entry *
74*a1157835SDaniel Fojt pmksa_cache_add_entry(struct rsn_pmksa_cache *pmksa,
75*a1157835SDaniel Fojt struct rsn_pmksa_cache_entry *entry);
766d49e1aeSJan Lentfer struct rsn_pmksa_cache_entry * pmksa_cache_get_current(struct wpa_sm *sm);
776d49e1aeSJan Lentfer void pmksa_cache_clear_current(struct wpa_sm *sm);
786d49e1aeSJan Lentfer int pmksa_cache_set_current(struct wpa_sm *sm, const u8 *pmkid,
796d49e1aeSJan Lentfer const u8 *bssid, void *network_ctx,
80*a1157835SDaniel Fojt int try_opportunistic, const u8 *fils_cache_id,
81*a1157835SDaniel Fojt int akmp);
826d49e1aeSJan Lentfer struct rsn_pmksa_cache_entry *
836d49e1aeSJan Lentfer pmksa_cache_get_opportunistic(struct rsn_pmksa_cache *pmksa,
84*a1157835SDaniel Fojt void *network_ctx, const u8 *aa, int akmp);
853ff40c12SJohn Marino void pmksa_cache_flush(struct rsn_pmksa_cache *pmksa, void *network_ctx,
863ff40c12SJohn Marino const u8 *pmk, size_t pmk_len);
876d49e1aeSJan Lentfer
883ff40c12SJohn Marino #else /* IEEE8021X_EAPOL */
896d49e1aeSJan Lentfer
906d49e1aeSJan Lentfer static inline struct rsn_pmksa_cache *
pmksa_cache_init(void (* free_cb)(struct rsn_pmksa_cache_entry * entry,void * ctx,enum pmksa_free_reason reason),void * ctx,struct wpa_sm * sm)916d49e1aeSJan Lentfer pmksa_cache_init(void (*free_cb)(struct rsn_pmksa_cache_entry *entry,
923ff40c12SJohn Marino void *ctx, enum pmksa_free_reason reason),
936d49e1aeSJan Lentfer void *ctx, struct wpa_sm *sm)
946d49e1aeSJan Lentfer {
956d49e1aeSJan Lentfer return (void *) -1;
966d49e1aeSJan Lentfer }
976d49e1aeSJan Lentfer
pmksa_cache_deinit(struct rsn_pmksa_cache * pmksa)986d49e1aeSJan Lentfer static inline void pmksa_cache_deinit(struct rsn_pmksa_cache *pmksa)
996d49e1aeSJan Lentfer {
1006d49e1aeSJan Lentfer }
1016d49e1aeSJan Lentfer
1026d49e1aeSJan Lentfer static inline struct rsn_pmksa_cache_entry *
pmksa_cache_get(struct rsn_pmksa_cache * pmksa,const u8 * aa,const u8 * pmkid,const void * network_ctx,int akmp)1033ff40c12SJohn Marino pmksa_cache_get(struct rsn_pmksa_cache *pmksa, const u8 *aa, const u8 *pmkid,
104*a1157835SDaniel Fojt const void *network_ctx, int akmp)
1056d49e1aeSJan Lentfer {
1066d49e1aeSJan Lentfer return NULL;
1076d49e1aeSJan Lentfer }
1086d49e1aeSJan Lentfer
1096d49e1aeSJan Lentfer static inline struct rsn_pmksa_cache_entry *
pmksa_cache_get_current(struct wpa_sm * sm)1106d49e1aeSJan Lentfer pmksa_cache_get_current(struct wpa_sm *sm)
1116d49e1aeSJan Lentfer {
1126d49e1aeSJan Lentfer return NULL;
1136d49e1aeSJan Lentfer }
1146d49e1aeSJan Lentfer
pmksa_cache_list(struct rsn_pmksa_cache * pmksa,char * buf,size_t len)1153ff40c12SJohn Marino static inline int pmksa_cache_list(struct rsn_pmksa_cache *pmksa, char *buf,
1163ff40c12SJohn Marino size_t len)
1176d49e1aeSJan Lentfer {
1186d49e1aeSJan Lentfer return -1;
1196d49e1aeSJan Lentfer }
1206d49e1aeSJan Lentfer
1216d49e1aeSJan Lentfer static inline struct rsn_pmksa_cache_entry *
pmksa_cache_head(struct rsn_pmksa_cache * pmksa)122*a1157835SDaniel Fojt pmksa_cache_head(struct rsn_pmksa_cache *pmksa)
123*a1157835SDaniel Fojt {
124*a1157835SDaniel Fojt return NULL;
125*a1157835SDaniel Fojt }
126*a1157835SDaniel Fojt
127*a1157835SDaniel Fojt static inline struct rsn_pmksa_cache_entry *
pmksa_cache_add_entry(struct rsn_pmksa_cache * pmksa,struct rsn_pmksa_cache_entry * entry)128*a1157835SDaniel Fojt pmksa_cache_add_entry(struct rsn_pmksa_cache *pmksa,
129*a1157835SDaniel Fojt struct rsn_pmksa_cache_entry *entry)
130*a1157835SDaniel Fojt {
131*a1157835SDaniel Fojt return NULL;
132*a1157835SDaniel Fojt }
133*a1157835SDaniel Fojt
134*a1157835SDaniel Fojt static inline struct rsn_pmksa_cache_entry *
pmksa_cache_add(struct rsn_pmksa_cache * pmksa,const u8 * pmk,size_t pmk_len,const u8 * pmkid,const u8 * kck,size_t kck_len,const u8 * aa,const u8 * spa,void * network_ctx,int akmp,const u8 * cache_id)1356d49e1aeSJan Lentfer pmksa_cache_add(struct rsn_pmksa_cache *pmksa, const u8 *pmk, size_t pmk_len,
136*a1157835SDaniel Fojt const u8 *pmkid, const u8 *kck, size_t kck_len,
137*a1157835SDaniel Fojt const u8 *aa, const u8 *spa, void *network_ctx, int akmp,
138*a1157835SDaniel Fojt const u8 *cache_id)
1396d49e1aeSJan Lentfer {
1406d49e1aeSJan Lentfer return NULL;
1416d49e1aeSJan Lentfer }
1426d49e1aeSJan Lentfer
pmksa_cache_clear_current(struct wpa_sm * sm)1436d49e1aeSJan Lentfer static inline void pmksa_cache_clear_current(struct wpa_sm *sm)
1446d49e1aeSJan Lentfer {
1456d49e1aeSJan Lentfer }
1466d49e1aeSJan Lentfer
pmksa_cache_set_current(struct wpa_sm * sm,const u8 * pmkid,const u8 * bssid,void * network_ctx,int try_opportunistic,const u8 * fils_cache_id,int akmp)1476d49e1aeSJan Lentfer static inline int pmksa_cache_set_current(struct wpa_sm *sm, const u8 *pmkid,
1486d49e1aeSJan Lentfer const u8 *bssid,
1496d49e1aeSJan Lentfer void *network_ctx,
150*a1157835SDaniel Fojt int try_opportunistic,
151*a1157835SDaniel Fojt const u8 *fils_cache_id,
152*a1157835SDaniel Fojt int akmp)
1536d49e1aeSJan Lentfer {
1546d49e1aeSJan Lentfer return -1;
1556d49e1aeSJan Lentfer }
1566d49e1aeSJan Lentfer
pmksa_cache_flush(struct rsn_pmksa_cache * pmksa,void * network_ctx,const u8 * pmk,size_t pmk_len)1573ff40c12SJohn Marino static inline void pmksa_cache_flush(struct rsn_pmksa_cache *pmksa,
1583ff40c12SJohn Marino void *network_ctx,
1593ff40c12SJohn Marino const u8 *pmk, size_t pmk_len)
1603ff40c12SJohn Marino {
1613ff40c12SJohn Marino }
1623ff40c12SJohn Marino
1633ff40c12SJohn Marino #endif /* IEEE8021X_EAPOL */
1646d49e1aeSJan Lentfer
1656d49e1aeSJan Lentfer #endif /* PMKSA_CACHE_H */
166