blob: adb3728d78d020eebb5b7ed85f3092443765982b [file] [log] [blame]
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07001/*
2 * hostapd / Initialization and configuration
Dmitry Shmidtcce06662013-11-04 18:44:24 -08003 * Copyright (c) 2002-2013, Jouni Malinen <j@w1.fi>
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07004 *
Dmitry Shmidtc5ec7f52012-03-06 16:33:24 -08005 * This software may be distributed under the terms of the BSD license.
6 * See README for more details.
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07007 */
8
9#ifndef HOSTAPD_H
10#define HOSTAPD_H
11
12#include "common/defs.h"
Dmitry Shmidtd5e49232012-12-03 15:08:10 -080013#include "ap_config.h"
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070014
15struct wpa_driver_ops;
16struct wpa_ctrl_dst;
17struct radius_server_data;
18struct upnp_wps_device_sm;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070019struct hostapd_data;
20struct sta_info;
21struct hostap_sta_driver_data;
22struct ieee80211_ht_capabilities;
23struct full_dynamic_vlan;
24enum wps_event;
25union wps_event_data;
26
Dmitry Shmidt61d9df32012-08-29 16:22:06 -070027struct hostapd_iface;
Dmitry Shmidt34af3062013-07-11 10:46:32 -070028struct hostapd_dynamic_iface;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -070029
Dmitry Shmidt04949592012-07-19 12:16:46 -070030struct hapd_interfaces {
Dmitry Shmidt61d9df32012-08-29 16:22:06 -070031 int (*reload_config)(struct hostapd_iface *iface);
32 struct hostapd_config * (*config_read_cb)(const char *config_fname);
33 int (*ctrl_iface_init)(struct hostapd_data *hapd);
34 void (*ctrl_iface_deinit)(struct hostapd_data *hapd);
35 int (*for_each_interface)(struct hapd_interfaces *interfaces,
36 int (*cb)(struct hostapd_iface *iface,
37 void *ctx), void *ctx);
38 int (*driver_init)(struct hostapd_iface *iface);
39
Dmitry Shmidt04949592012-07-19 12:16:46 -070040 size_t count;
Dmitry Shmidt34af3062013-07-11 10:46:32 -070041 size_t count_dynamic;
Dmitry Shmidt61d9df32012-08-29 16:22:06 -070042 int global_ctrl_sock;
43 char *global_iface_path;
44 char *global_iface_name;
Dmitry Shmidt0ccb66e2013-03-29 16:41:28 -070045 gid_t ctrl_iface_group;
Dmitry Shmidt04949592012-07-19 12:16:46 -070046 struct hostapd_iface **iface;
Dmitry Shmidt34af3062013-07-11 10:46:32 -070047 struct hostapd_dynamic_iface **dynamic_iface;
Dmitry Shmidtb96dad42013-11-05 10:07:29 -080048
49 size_t terminate_on_error;
Dmitry Shmidt04949592012-07-19 12:16:46 -070050};
51
Dmitry Shmidtb7b4d0e2013-08-26 12:09:05 -070052enum hostapd_chan_status {
53 HOSTAPD_CHAN_VALID = 0, /* channel is ready */
54 HOSTAPD_CHAN_INVALID = 1, /* no usable channel found */
55 HOSTAPD_CHAN_ACS = 2, /* ACS work being performed */
56};
Dmitry Shmidt04949592012-07-19 12:16:46 -070057
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070058struct hostapd_probereq_cb {
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080059 int (*cb)(void *ctx, const u8 *sa, const u8 *da, const u8 *bssid,
Dmitry Shmidt04949592012-07-19 12:16:46 -070060 const u8 *ie, size_t ie_len, int ssi_signal);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070061 void *ctx;
62};
63
64#define HOSTAPD_RATE_BASIC 0x00000001
65
66struct hostapd_rate_data {
67 int rate; /* rate in 100 kbps */
68 int flags; /* HOSTAPD_RATE_ flags */
69};
70
71struct hostapd_frame_info {
72 u32 channel;
73 u32 datarate;
Dmitry Shmidt04949592012-07-19 12:16:46 -070074 int ssi_signal; /* dBm */
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070075};
76
Dmitry Shmidtb7b4d0e2013-08-26 12:09:05 -070077enum wps_status {
78 WPS_STATUS_SUCCESS = 1,
79 WPS_STATUS_FAILURE
80};
81
82enum pbc_status {
83 WPS_PBC_STATUS_DISABLE,
84 WPS_PBC_STATUS_ACTIVE,
85 WPS_PBC_STATUS_TIMEOUT,
86 WPS_PBC_STATUS_OVERLAP
87};
88
89struct wps_stat {
90 enum wps_status status;
91 enum wps_error_indication failure_reason;
92 enum pbc_status pbc_status;
93 u8 peer_addr[ETH_ALEN];
94};
95
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070096
97/**
98 * struct hostapd_data - hostapd per-BSS data structure
99 */
100struct hostapd_data {
101 struct hostapd_iface *iface;
102 struct hostapd_config *iconf;
103 struct hostapd_bss_config *conf;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700104
105 u8 own_addr[ETH_ALEN];
106
107 int num_sta; /* number of entries in sta_list */
108 struct sta_info *sta_list; /* STA info list head */
109#define STA_HASH_SIZE 256
110#define STA_HASH(sta) (sta[5])
111 struct sta_info *sta_hash[STA_HASH_SIZE];
112
113 /*
114 * Bitfield for indicating which AIDs are allocated. Only AID values
115 * 1-2007 are used and as such, the bit at index 0 corresponds to AID
116 * 1.
117 */
118#define AID_WORDS ((2008 + 31) / 32)
119 u32 sta_aid[AID_WORDS];
120
121 const struct wpa_driver_ops *driver;
122 void *drv_priv;
123
124 void (*new_assoc_sta_cb)(struct hostapd_data *hapd,
125 struct sta_info *sta, int reassoc);
126
127 void *msg_ctx; /* ctx for wpa_msg() calls */
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800128 void *msg_ctx_parent; /* parent interface ctx for wpa_msg() calls */
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700129
130 struct radius_client_data *radius;
131 u32 acct_session_id_hi, acct_session_id_lo;
Dmitry Shmidt04949592012-07-19 12:16:46 -0700132 struct radius_das_data *radius_das;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700133
134 struct iapp_data *iapp;
135
136 struct hostapd_cached_radius_acl *acl_cache;
137 struct hostapd_acl_query_data *acl_queries;
138
139 struct wpa_authenticator *wpa_auth;
140 struct eapol_authenticator *eapol_auth;
141
142 struct rsn_preauth_interface *preauth_iface;
143 time_t michael_mic_failure;
144 int michael_mic_failures;
145 int tkip_countermeasures;
146
147 int ctrl_sock;
148 struct wpa_ctrl_dst *ctrl_dst;
149
150 void *ssl_ctx;
151 void *eap_sim_db_priv;
152 struct radius_server_data *radius_srv;
153
154 int parameter_set_count;
155
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800156 /* Time Advertisement */
157 u8 time_update_counter;
158 struct wpabuf *time_adv;
159
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700160#ifdef CONFIG_FULL_DYNAMIC_VLAN
161 struct full_dynamic_vlan *full_dynamic_vlan;
162#endif /* CONFIG_FULL_DYNAMIC_VLAN */
163
164 struct l2_packet_data *l2;
165 struct wps_context *wps;
166
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800167 int beacon_set_done;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700168 struct wpabuf *wps_beacon_ie;
169 struct wpabuf *wps_probe_resp_ie;
170#ifdef CONFIG_WPS
171 unsigned int ap_pin_failures;
Dmitry Shmidtc5ec7f52012-03-06 16:33:24 -0800172 unsigned int ap_pin_failures_consecutive;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700173 struct upnp_wps_device_sm *wps_upnp;
174 unsigned int ap_pin_lockout_time;
Dmitry Shmidtb7b4d0e2013-08-26 12:09:05 -0700175
176 struct wps_stat wps_stats;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700177#endif /* CONFIG_WPS */
178
179 struct hostapd_probereq_cb *probereq_cb;
180 size_t num_probereq_cb;
181
182 void (*public_action_cb)(void *ctx, const u8 *buf, size_t len,
183 int freq);
184 void *public_action_cb_ctx;
Dmitry Shmidt4b9d52f2013-02-05 17:44:43 -0800185 void (*public_action_cb2)(void *ctx, const u8 *buf, size_t len,
186 int freq);
187 void *public_action_cb2_ctx;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700188
189 int (*vendor_action_cb)(void *ctx, const u8 *buf, size_t len,
190 int freq);
191 void *vendor_action_cb_ctx;
192
193 void (*wps_reg_success_cb)(void *ctx, const u8 *mac_addr,
194 const u8 *uuid_e);
195 void *wps_reg_success_cb_ctx;
196
197 void (*wps_event_cb)(void *ctx, enum wps_event event,
198 union wps_event_data *data);
199 void *wps_event_cb_ctx;
200
201 void (*sta_authorized_cb)(void *ctx, const u8 *mac_addr,
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800202 int authorized, const u8 *p2p_dev_addr);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700203 void *sta_authorized_cb_ctx;
204
205 void (*setup_complete_cb)(void *ctx);
206 void *setup_complete_cb_ctx;
207
Dmitry Shmidt391c59f2013-09-03 12:16:28 -0700208 void (*new_psk_cb)(void *ctx, const u8 *mac_addr,
209 const u8 *p2p_dev_addr, const u8 *psk,
210 size_t psk_len);
211 void *new_psk_cb_ctx;
212
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700213#ifdef CONFIG_P2P
214 struct p2p_data *p2p;
215 struct p2p_group *p2p_group;
216 struct wpabuf *p2p_beacon_ie;
217 struct wpabuf *p2p_probe_resp_ie;
218
219 /* Number of non-P2P association stations */
220 int num_sta_no_p2p;
221
222 /* Periodic NoA (used only when no non-P2P clients in the group) */
223 int noa_enabled;
224 int noa_start;
225 int noa_duration;
226#endif /* CONFIG_P2P */
Dmitry Shmidt04949592012-07-19 12:16:46 -0700227#ifdef CONFIG_INTERWORKING
228 size_t gas_frag_limit;
229#endif /* CONFIG_INTERWORKING */
Dmitry Shmidtd5e49232012-12-03 15:08:10 -0800230
231#ifdef CONFIG_SQLITE
232 struct hostapd_eap_user tmp_eap_user;
233#endif /* CONFIG_SQLITE */
Dmitry Shmidta54fa5f2013-01-15 13:53:35 -0800234
235#ifdef CONFIG_SAE
236 /** Key used for generating SAE anti-clogging tokens */
237 u8 sae_token_key[8];
238 os_time_t last_sae_token_key_update;
239#endif /* CONFIG_SAE */
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700240};
241
242
243/**
244 * struct hostapd_iface - hostapd per-interface data structure
245 */
246struct hostapd_iface {
247 struct hapd_interfaces *interfaces;
248 void *owner;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700249 char *config_fname;
250 struct hostapd_config *conf;
Dmitry Shmidtcce06662013-11-04 18:44:24 -0800251 char phy[16]; /* Name of the PHY (radio) */
252
253 enum hostapd_iface_state {
254 HAPD_IFACE_UNINITIALIZED,
255 HAPD_IFACE_DISABLED,
256 HAPD_IFACE_COUNTRY_UPDATE,
257 HAPD_IFACE_ACS,
258 HAPD_IFACE_HT_SCAN,
259 HAPD_IFACE_DFS,
260 HAPD_IFACE_ENABLED
261 } state;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700262
263 size_t num_bss;
264 struct hostapd_data **bss;
265
Dmitry Shmidtcce06662013-11-04 18:44:24 -0800266 unsigned int wait_channel_update:1;
267 unsigned int cac_started:1;
268
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700269 int num_ap; /* number of entries in ap_list */
270 struct ap_info *ap_list; /* AP info list head */
271 struct ap_info *ap_hash[STA_HASH_SIZE];
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700272
273 unsigned int drv_flags;
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800274
275 /*
276 * A bitmap of supported protocols for probe response offload. See
277 * struct wpa_driver_capa in driver.h
278 */
279 unsigned int probe_resp_offloads;
280
Dmitry Shmidt444d5672013-04-01 13:08:44 -0700281 /* extended capabilities supported by the driver */
282 const u8 *extended_capa, *extended_capa_mask;
283 unsigned int extended_capa_len;
284
Dmitry Shmidt8bae4132013-06-06 11:25:10 -0700285 unsigned int drv_max_acl_mac_addrs;
286
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700287 struct hostapd_hw_modes *hw_features;
288 int num_hw_features;
289 struct hostapd_hw_modes *current_mode;
290 /* Rates that are currently used (i.e., filtered copy of
291 * current_mode->channels */
292 int num_rates;
293 struct hostapd_rate_data *current_rates;
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800294 int *basic_rates;
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700295 int freq;
296
297 u16 hw_flags;
298
299 /* Number of associated Non-ERP stations (i.e., stations using 802.11b
300 * in 802.11g BSS) */
301 int num_sta_non_erp;
302
303 /* Number of associated stations that do not support Short Slot Time */
304 int num_sta_no_short_slot_time;
305
306 /* Number of associated stations that do not support Short Preamble */
307 int num_sta_no_short_preamble;
308
309 int olbc; /* Overlapping Legacy BSS Condition */
310
311 /* Number of HT associated stations that do not support greenfield */
312 int num_sta_ht_no_gf;
313
314 /* Number of associated non-HT stations */
315 int num_sta_no_ht;
316
317 /* Number of HT associated stations 20 MHz */
318 int num_sta_ht_20mhz;
319
320 /* Overlapping BSS information */
321 int olbc_ht;
322
323 u16 ht_op_mode;
Dmitry Shmidtb7b4d0e2013-08-26 12:09:05 -0700324
325 /* surveying helpers */
326
327 /* number of channels surveyed */
328 unsigned int chans_surveyed;
329
330 /* lowest observed noise floor in dBm */
331 s8 lowest_nf;
332
Dmitry Shmidt391c59f2013-09-03 12:16:28 -0700333#ifdef CONFIG_ACS
334 unsigned int acs_num_completed_scans;
335#endif /* CONFIG_ACS */
336
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700337 void (*scan_cb)(struct hostapd_iface *iface);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700338};
339
Dmitry Shmidt34af3062013-07-11 10:46:32 -0700340/**
341 * struct hostapd_dynamic_iface - hostapd per dynamically allocated
342 * or added interface data structure
343 */
344struct hostapd_dynamic_iface {
345 char parent[IFNAMSIZ + 1];
346 char iface[IFNAMSIZ + 1];
347 unsigned int usage;
348};
349
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700350/* hostapd.c */
Dmitry Shmidt04949592012-07-19 12:16:46 -0700351int hostapd_for_each_interface(struct hapd_interfaces *interfaces,
352 int (*cb)(struct hostapd_iface *iface,
353 void *ctx), void *ctx);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700354int hostapd_reload_config(struct hostapd_iface *iface);
355struct hostapd_data *
356hostapd_alloc_bss_data(struct hostapd_iface *hapd_iface,
357 struct hostapd_config *conf,
358 struct hostapd_bss_config *bss);
359int hostapd_setup_interface(struct hostapd_iface *iface);
360int hostapd_setup_interface_complete(struct hostapd_iface *iface, int err);
361void hostapd_interface_deinit(struct hostapd_iface *iface);
362void hostapd_interface_free(struct hostapd_iface *iface);
Dmitry Shmidtcce06662013-11-04 18:44:24 -0800363struct hostapd_iface * hostapd_init(struct hapd_interfaces *interfaces,
364 const char *config_file);
365struct hostapd_iface *
366hostapd_interface_init_bss(struct hapd_interfaces *interfaces, const char *phy,
367 const char *config_fname, int debug);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700368void hostapd_new_assoc_sta(struct hostapd_data *hapd, struct sta_info *sta,
369 int reassoc);
Dmitry Shmidt61d9df32012-08-29 16:22:06 -0700370void hostapd_interface_deinit_free(struct hostapd_iface *iface);
371int hostapd_enable_iface(struct hostapd_iface *hapd_iface);
372int hostapd_reload_iface(struct hostapd_iface *hapd_iface);
373int hostapd_disable_iface(struct hostapd_iface *hapd_iface);
374int hostapd_add_iface(struct hapd_interfaces *ifaces, char *buf);
375int hostapd_remove_iface(struct hapd_interfaces *ifaces, char *buf);
Dmitry Shmidtcce06662013-11-04 18:44:24 -0800376void hostapd_channel_list_updated(struct hostapd_iface *iface);
377void hostapd_set_state(struct hostapd_iface *iface, enum hostapd_iface_state s);
378const char * hostapd_state_text(enum hostapd_iface_state s);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700379
380/* utils.c */
381int hostapd_register_probereq_cb(struct hostapd_data *hapd,
382 int (*cb)(void *ctx, const u8 *sa,
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800383 const u8 *da, const u8 *bssid,
Dmitry Shmidt04949592012-07-19 12:16:46 -0700384 const u8 *ie, size_t ie_len,
385 int ssi_signal),
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700386 void *ctx);
387void hostapd_prune_associations(struct hostapd_data *hapd, const u8 *addr);
388
389/* drv_callbacks.c (TODO: move to somewhere else?) */
390int hostapd_notif_assoc(struct hostapd_data *hapd, const u8 *addr,
391 const u8 *ie, size_t ielen, int reassoc);
392void hostapd_notif_disassoc(struct hostapd_data *hapd, const u8 *addr);
393void hostapd_event_sta_low_ack(struct hostapd_data *hapd, const u8 *addr);
Dmitry Shmidtf8623282013-02-20 14:34:59 -0800394void hostapd_event_connect_failed_reason(struct hostapd_data *hapd,
395 const u8 *addr, int reason_code);
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -0800396int hostapd_probe_req_rx(struct hostapd_data *hapd, const u8 *sa, const u8 *da,
Dmitry Shmidt04949592012-07-19 12:16:46 -0700397 const u8 *bssid, const u8 *ie, size_t ie_len,
398 int ssi_signal);
399void hostapd_event_ch_switch(struct hostapd_data *hapd, int freq, int ht,
400 int offset);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700401
Dmitry Shmidtd5e49232012-12-03 15:08:10 -0800402const struct hostapd_eap_user *
403hostapd_get_eap_user(struct hostapd_data *hapd, const u8 *identity,
404 size_t identity_len, int phase2);
405
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -0700406#endif /* HOSTAPD_H */