blob: c9ce2cecf8aeaacb8cb27409c8228504b062d16c [file] [log] [blame]
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07001/*
2 * WPA Supplicant - Scanning
Dmitry Shmidtfb79edc2014-01-10 10:45:54 -08003 * Copyright (c) 2003-2014, 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 SCAN_H
10#define SCAN_H
11
Hai Shalomfdcde762020-04-02 11:19:20 -070012/*
13 * Noise floor values to use when we have signal strength
14 * measurements, but no noise floor measurements. These values were
15 * measured in an office environment with many APs.
16 */
17#define DEFAULT_NOISE_FLOOR_2GHZ (-89)
18#define DEFAULT_NOISE_FLOOR_5GHZ (-92)
19
20/*
21 * Channels with a great SNR can operate at full rate. What is a great SNR?
22 * This doc https://supportforums.cisco.com/docs/DOC-12954 says, "the general
23 * rule of thumb is that any SNR above 20 is good." This one
24 * http://www.cisco.com/en/US/tech/tk722/tk809/technologies_q_and_a_item09186a00805e9a96.shtml#qa23
25 * recommends 25 as a minimum SNR for 54 Mbps data rate. The estimates used in
26 * scan_est_throughput() allow even smaller SNR values for the maximum rates
27 * (21 for 54 Mbps, 22 for VHT80 MCS9, 24 for HT40 and HT20 MCS7). Use 25 as a
28 * somewhat conservative value here.
29 */
30#define GREAT_SNR 25
31
32#define IS_5GHZ(n) (n > 4000)
33
Dmitry Shmidt04949592012-07-19 12:16:46 -070034int wpa_supplicant_enabled_networks(struct wpa_supplicant *wpa_s);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070035void wpa_supplicant_req_scan(struct wpa_supplicant *wpa_s, int sec, int usec);
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080036int wpa_supplicant_delayed_sched_scan(struct wpa_supplicant *wpa_s,
37 int sec, int usec);
38int wpa_supplicant_req_sched_scan(struct wpa_supplicant *wpa_s);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070039void wpa_supplicant_cancel_scan(struct wpa_supplicant *wpa_s);
Dmitry Shmidtc2ebb4b2013-07-24 12:57:51 -070040void wpa_supplicant_cancel_delayed_sched_scan(struct wpa_supplicant *wpa_s);
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080041void wpa_supplicant_cancel_sched_scan(struct wpa_supplicant *wpa_s);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070042void wpa_supplicant_notify_scanning(struct wpa_supplicant *wpa_s,
43 int scanning);
44struct wpa_driver_scan_params;
45int wpa_supplicant_trigger_scan(struct wpa_supplicant *wpa_s,
46 struct wpa_driver_scan_params *params);
47struct wpa_scan_results *
48wpa_supplicant_get_scan_results(struct wpa_supplicant *wpa_s,
49 struct scan_info *info, int new_scan);
50int wpa_supplicant_update_scan_results(struct wpa_supplicant *wpa_s);
51const u8 * wpa_scan_get_ie(const struct wpa_scan_res *res, u8 ie);
52const u8 * wpa_scan_get_vendor_ie(const struct wpa_scan_res *res,
53 u32 vendor_type);
Dmitry Shmidt96571392013-10-14 12:54:46 -070054const u8 * wpa_scan_get_vendor_ie_beacon(const struct wpa_scan_res *res,
55 u32 vendor_type);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070056struct wpabuf * wpa_scan_get_vendor_ie_multi(const struct wpa_scan_res *res,
57 u32 vendor_type);
Dmitry Shmidt04949592012-07-19 12:16:46 -070058int wpa_supplicant_filter_bssid_match(struct wpa_supplicant *wpa_s,
59 const u8 *bssid);
Dmitry Shmidt4b9d52f2013-02-05 17:44:43 -080060void wpa_supplicant_update_scan_int(struct wpa_supplicant *wpa_s, int sec);
Dmitry Shmidt3a787e62013-01-17 10:32:35 -080061void scan_only_handler(struct wpa_supplicant *wpa_s,
62 struct wpa_scan_results *scan_res);
Dmitry Shmidt37d4d6a2013-03-18 13:09:42 -070063int wpas_scan_scheduled(struct wpa_supplicant *wpa_s);
Dmitry Shmidtfb79edc2014-01-10 10:45:54 -080064struct wpa_driver_scan_params *
65wpa_scan_clone_params(const struct wpa_driver_scan_params *src);
66void wpa_scan_free_params(struct wpa_driver_scan_params *params);
Dmitry Shmidt98660862014-03-11 17:26:21 -070067int wpas_start_pno(struct wpa_supplicant *wpa_s);
68int wpas_stop_pno(struct wpa_supplicant *wpa_s);
Dmitry Shmidtaca489e2016-09-28 15:44:14 -070069void wpas_scan_reset_sched_scan(struct wpa_supplicant *wpa_s);
70void wpas_scan_restart_sched_scan(struct wpa_supplicant *wpa_s);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070071
Dmitry Shmidtfb45fd52015-01-05 13:08:17 -080072void wpas_mac_addr_rand_scan_clear(struct wpa_supplicant *wpa_s,
73 unsigned int type);
74int wpas_mac_addr_rand_scan_set(struct wpa_supplicant *wpa_s,
75 unsigned int type, const u8 *addr,
76 const u8 *mask);
Hai Shalomc3565922019-10-28 11:58:20 -070077int wpas_mac_addr_rand_scan_get_mask(struct wpa_supplicant *wpa_s,
78 unsigned int type, u8 *mask);
Dmitry Shmidtd7ff03d2015-12-04 14:49:35 -080079int wpas_abort_ongoing_scan(struct wpa_supplicant *wpa_s);
Dmitry Shmidt849734c2016-05-27 09:59:01 -070080void filter_scan_res(struct wpa_supplicant *wpa_s,
81 struct wpa_scan_results *res);
82void scan_snr(struct wpa_scan_res *res);
83void scan_est_throughput(struct wpa_supplicant *wpa_s,
84 struct wpa_scan_res *res);
Hai Shalomfdcde762020-04-02 11:19:20 -070085unsigned int wpas_get_est_tpt(const struct wpa_supplicant *wpa_s,
86 const u8 *ies, size_t ies_len, int rate,
87 int snr);
Dmitry Shmidt7f2c7532016-08-15 09:48:12 -070088void wpa_supplicant_set_default_scan_ies(struct wpa_supplicant *wpa_s);
Dmitry Shmidtfb45fd52015-01-05 13:08:17 -080089
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070090#endif /* SCAN_H */