bss.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /*
  2. * BSS table
  3. * Copyright (c) 2009-2010, Jouni Malinen <j@w1.fi>
  4. *
  5. * This software may be distributed under the terms of the BSD license.
  6. * See README for more details.
  7. */
  8. #ifndef BSS_H
  9. #define BSS_H
  10. struct wpa_scan_res;
  11. #define WPA_BSS_QUAL_INVALID BIT(0)
  12. #define WPA_BSS_NOISE_INVALID BIT(1)
  13. #define WPA_BSS_LEVEL_INVALID BIT(2)
  14. #define WPA_BSS_LEVEL_DBM BIT(3)
  15. #define WPA_BSS_AUTHENTICATED BIT(4)
  16. #define WPA_BSS_ASSOCIATED BIT(5)
  17. #define WPA_BSS_ANQP_FETCH_TRIED BIT(6)
  18. /**
  19. * struct wpa_bss_anqp - ANQP data for a BSS entry (struct wpa_bss)
  20. */
  21. struct wpa_bss_anqp {
  22. /** Number of BSS entries referring to this ANQP data instance */
  23. unsigned int users;
  24. #ifdef CONFIG_INTERWORKING
  25. struct wpabuf *venue_name;
  26. struct wpabuf *network_auth_type;
  27. struct wpabuf *roaming_consortium;
  28. struct wpabuf *ip_addr_type_availability;
  29. struct wpabuf *nai_realm;
  30. struct wpabuf *anqp_3gpp;
  31. struct wpabuf *domain_name;
  32. #endif /* CONFIG_INTERWORKING */
  33. #ifdef CONFIG_HS20
  34. struct wpabuf *hs20_operator_friendly_name;
  35. struct wpabuf *hs20_wan_metrics;
  36. struct wpabuf *hs20_connection_capability;
  37. struct wpabuf *hs20_operating_class;
  38. #endif /* CONFIG_HS20 */
  39. };
  40. /**
  41. * struct wpa_bss - BSS table
  42. *
  43. * This structure is used to store information about neighboring BSSes in
  44. * generic format. It is mainly updated based on scan results from the driver.
  45. */
  46. struct wpa_bss {
  47. /** List entry for struct wpa_supplicant::bss */
  48. struct dl_list list;
  49. /** List entry for struct wpa_supplicant::bss_id */
  50. struct dl_list list_id;
  51. /** Unique identifier for this BSS entry */
  52. unsigned int id;
  53. /** Number of counts without seeing this BSS */
  54. unsigned int scan_miss_count;
  55. /** Index of the last scan update */
  56. unsigned int last_update_idx;
  57. /** Information flags about the BSS/IBSS (WPA_BSS_*) */
  58. unsigned int flags;
  59. /** BSSID */
  60. u8 bssid[ETH_ALEN];
  61. /** HESSID */
  62. u8 hessid[ETH_ALEN];
  63. /** SSID */
  64. u8 ssid[32];
  65. /** Length of SSID */
  66. size_t ssid_len;
  67. /** Frequency of the channel in MHz (e.g., 2412 = channel 1) */
  68. int freq;
  69. /** Beacon interval in TUs (host byte order) */
  70. u16 beacon_int;
  71. /** Capability information field in host byte order */
  72. u16 caps;
  73. /** Signal quality */
  74. int qual;
  75. /** Noise level */
  76. int noise;
  77. /** Signal level */
  78. int level;
  79. /** Timestamp of last Beacon/Probe Response frame */
  80. u64 tsf;
  81. /** Time of the last update (i.e., Beacon or Probe Response RX) */
  82. struct os_time last_update;
  83. /** ANQP data */
  84. struct wpa_bss_anqp *anqp;
  85. /** Length of the following IE field in octets (from Probe Response) */
  86. size_t ie_len;
  87. /** Length of the following Beacon IE field in octets */
  88. size_t beacon_ie_len;
  89. /* followed by ie_len octets of IEs */
  90. /* followed by beacon_ie_len octets of IEs */
  91. };
  92. void wpa_bss_update_start(struct wpa_supplicant *wpa_s);
  93. void wpa_bss_update_scan_res(struct wpa_supplicant *wpa_s,
  94. struct wpa_scan_res *res,
  95. struct os_time *fetch_time);
  96. void wpa_bss_update_end(struct wpa_supplicant *wpa_s, struct scan_info *info,
  97. int new_scan);
  98. int wpa_bss_init(struct wpa_supplicant *wpa_s);
  99. void wpa_bss_deinit(struct wpa_supplicant *wpa_s);
  100. void wpa_bss_flush(struct wpa_supplicant *wpa_s);
  101. void wpa_bss_flush_by_age(struct wpa_supplicant *wpa_s, int age);
  102. struct wpa_bss * wpa_bss_get(struct wpa_supplicant *wpa_s, const u8 *bssid,
  103. const u8 *ssid, size_t ssid_len);
  104. struct wpa_bss * wpa_bss_get_bssid(struct wpa_supplicant *wpa_s,
  105. const u8 *bssid);
  106. struct wpa_bss * wpa_bss_get_bssid_latest(struct wpa_supplicant *wpa_s,
  107. const u8 *bssid);
  108. struct wpa_bss * wpa_bss_get_p2p_dev_addr(struct wpa_supplicant *wpa_s,
  109. const u8 *dev_addr);
  110. struct wpa_bss * wpa_bss_get_id(struct wpa_supplicant *wpa_s, unsigned int id);
  111. struct wpa_bss * wpa_bss_get_id_range(struct wpa_supplicant *wpa_s,
  112. unsigned int idf, unsigned int idl);
  113. const u8 * wpa_bss_get_ie(const struct wpa_bss *bss, u8 ie);
  114. const u8 * wpa_bss_get_vendor_ie(const struct wpa_bss *bss, u32 vendor_type);
  115. struct wpabuf * wpa_bss_get_vendor_ie_multi(const struct wpa_bss *bss,
  116. u32 vendor_type);
  117. struct wpabuf * wpa_bss_get_vendor_ie_multi_beacon(const struct wpa_bss *bss,
  118. u32 vendor_type);
  119. int wpa_bss_get_max_rate(const struct wpa_bss *bss);
  120. int wpa_bss_get_bit_rates(const struct wpa_bss *bss, u8 **rates);
  121. struct wpa_bss_anqp * wpa_bss_anqp_alloc(void);
  122. int wpa_bss_anqp_unshare_alloc(struct wpa_bss *bss);
  123. #endif /* BSS_H */