/** * Interface for the wlan network scan routines * * Driver interface functions and type declarations for the scan module * implemented in scan.c. */ #ifndef _LBS_SCAN_H #define _LBS_SCAN_H #include #include "hostcmd.h" struct lbs_adapter; /** * @brief Maximum number of channels that can be sent in a setuserscan ioctl * * @sa lbs_ioctl_user_scan_cfg */ #define LBS_IOCTL_USER_SCAN_CHAN_MAX 50 //! Infrastructure BSS scan type in lbs_scan_cmd_config #define LBS_SCAN_BSS_TYPE_BSS 1 //! Adhoc BSS scan type in lbs_scan_cmd_config #define LBS_SCAN_BSS_TYPE_IBSS 2 //! Adhoc or Infrastructure BSS scan type in lbs_scan_cmd_config, no filter #define LBS_SCAN_BSS_TYPE_ANY 3 /** * @brief Structure used internally in the wlan driver to configure a scan. * * Sent to the command processing module to configure the firmware * scan command prepared by lbs_cmd_80211_scan. * * @sa lbs_scan_networks * */ struct lbs_scan_cmd_config { /** * @brief BSS type to be sent in the firmware command * * Field can be used to restrict the types of networks returned in the * scan. valid settings are: * * - LBS_SCAN_BSS_TYPE_BSS (infrastructure) * - LBS_SCAN_BSS_TYPE_IBSS (adhoc) * - LBS_SCAN_BSS_TYPE_ANY (unrestricted, adhoc and infrastructure) */ u8 bsstype; /** * @brief Specific BSSID used to filter scan results in the firmware */ u8 bssid[ETH_ALEN]; /** * @brief length of TLVs sent in command starting at tlvBuffer */ int tlvbufferlen; /** * @brief SSID TLV(s) and ChanList TLVs to be sent in the firmware command * * @sa TLV_TYPE_CHANLIST, mrvlietypes_chanlistparamset_t * @sa TLV_TYPE_SSID, mrvlietypes_ssidparamset_t */ u8 tlvbuffer[1]; //!< SSID TLV(s) and ChanList TLVs are stored here }; /** * @brief IOCTL channel sub-structure sent in lbs_ioctl_user_scan_cfg * * Multiple instances of this structure are included in the IOCTL command * to configure a instance of a scan on the specific channel. */ struct lbs_ioctl_user_scan_chan { u8 channumber; //!< channel Number to scan u8 radiotype; //!< Radio type: 'B/G' band = 0, 'A' band = 1 u8 scantype; //!< Scan type: Active = 0, Passive = 1 u16 scantime; //!< Scan duration in milliseconds; if 0 default used }; /** * @brief IOCTL input structure to configure an immediate scan cmd to firmware * * Used in the setuserscan (LBS_SET_USER_SCAN) private ioctl. Specifies * a number of parameters to be used in general for the scan as well * as a channel list (lbs_ioctl_user_scan_chan) for each scan period * desired. * * @sa lbs_set_user_scan_ioctl */ struct lbs_ioctl_user_scan_cfg { /** * @brief BSS type to be sent in the firmware command * * Field can be used to restrict the types of networks returned in the * scan. valid settings are: * * - LBS_SCAN_BSS_TYPE_BSS (infrastructure) * - LBS_SCAN_BSS_TYPE_IBSS (adhoc) * - LBS_SCAN_BSS_TYPE_ANY (unrestricted, adhoc and infrastructure) */ u8 bsstype; /** * @brief Configure the number of probe requests for active chan scans */ u8 numprobes; /** * @brief BSSID filter sent in the firmware command to limit the results */ u8 bssid[ETH_ALEN]; /* Clear existing scan results matching this BSSID */ u8 clear_bssid; /** * @brief SSID filter sent in the firmware command to limit the results */ char ssid[IW_ESSID_MAX_SIZE]; u8 ssid_len; /* Clear existing scan results matching this SSID */ u8 clear_ssid; /** * @brief Variable number (fixed maximum) of channels to scan up */ struct lbs_ioctl_user_scan_chan chanlist[LBS_IOCTL_USER_SCAN_CHAN_MAX]; }; /** * @brief Structure used to store information for each beacon/probe response */ struct bss_descriptor { u8 bssid[ETH_ALEN]; u8 ssid[IW_ESSID_MAX_SIZE + 1]; u8 ssid_len; u16 capability; /* receive signal strength in dBm */ long rssi; u32 channel; u16 beaconperiod; u32 atimwindow; /* IW_MODE_AUTO, IW_MODE_ADHOC, IW_MODE_INFRA */ u8 mode; /* zero-terminated array of supported data rates */ u8 rates[MAX_RATES + 1]; unsigned long last_scanned; union ieeetypes_phyparamset phyparamset; union IEEEtypes_ssparamset ssparamset; struct ieeetypes_countryinfofullset countryinfo; u8 wpa_ie[MAX_WPA_IE_LEN]; size_t wpa_ie_len; u8 rsn_ie[MAX_WPA_IE_LEN]; size_t rsn_ie_len; u8 mesh; struct list_head list; }; int lbs_ssid_cmp(u8 *ssid1, u8 ssid1_len, u8 *ssid2, u8 ssid2_len); struct bss_descriptor *lbs_find_ssid_in_list(struct lbs_adapter *adapter, u8 *ssid, u8 ssid_len, u8 *bssid, u8 mode, int channel); struct bss_descriptor *lbs_find_bssid_in_list(struct lbs_adapter *adapter, u8 *bssid, u8 mode); int lbs_find_best_network_ssid(struct lbs_private *priv, u8 *out_ssid, u8 *out_ssid_len, u8 preferred_mode, u8 *out_mode); int lbs_send_specific_ssid_scan(struct lbs_private *priv, u8 *ssid, u8 ssid_len, u8 clear_ssid); int lbs_cmd_80211_scan(struct lbs_private *priv, struct cmd_ds_command *cmd, void *pdata_buf); int lbs_ret_80211_scan(struct lbs_private *priv, struct cmd_ds_command *resp); int lbs_scan_networks(struct lbs_private *priv, const struct lbs_ioctl_user_scan_cfg *puserscanin, int full_scan); struct ifreq; struct iw_point; struct iw_param; struct iw_request_info; int lbs_get_scan(struct net_device *dev, struct iw_request_info *info, struct iw_point *dwrq, char *extra); int lbs_set_scan(struct net_device *dev, struct iw_request_info *info, struct iw_param *vwrq, char *extra); void lbs_scan_worker(struct work_struct *work); #endif