ath5k: move rx and tx status structures out of hardware descriptor
[linux-2.6] / drivers / net / wireless / libertas / scan.h
1 /**
2   * Interface for the wlan network scan routines
3   *
4   * Driver interface functions and type declarations for the scan module
5   * implemented in scan.c.
6   */
7 #ifndef _LBS_SCAN_H
8 #define _LBS_SCAN_H
9
10 #include <net/ieee80211.h>
11 #include "hostcmd.h"
12
13 /**
14  *  @brief Maximum number of channels that can be sent in a setuserscan ioctl
15  *
16  *  @sa lbs_ioctl_user_scan_cfg
17  */
18 #define LBS_IOCTL_USER_SCAN_CHAN_MAX  50
19
20 //! Infrastructure BSS scan type in cmd_ds_802_11_scan
21 #define LBS_SCAN_BSS_TYPE_BSS         1
22
23 //! Adhoc BSS scan type in cmd_ds_802_11_scan
24 #define LBS_SCAN_BSS_TYPE_IBSS        2
25
26 //! Adhoc or Infrastructure BSS scan type in cmd_ds_802_11_scan, no filter
27 #define LBS_SCAN_BSS_TYPE_ANY         3
28
29 /**
30  *  @brief IOCTL channel sub-structure sent in lbs_ioctl_user_scan_cfg
31  *
32  *  Multiple instances of this structure are included in the IOCTL command
33  *   to configure a instance of a scan on the specific channel.
34  */
35 struct lbs_ioctl_user_scan_chan {
36         u8 channumber;          //!< channel Number to scan
37         u8 radiotype;           //!< Radio type: 'B/G' band = 0, 'A' band = 1
38         u8 scantype;            //!< Scan type: Active = 0, Passive = 1
39         u16 scantime;           //!< Scan duration in milliseconds; if 0 default used
40 };
41
42 /**
43  *  @brief IOCTL input structure to configure an immediate scan cmd to firmware
44  *
45  *  Used in the setuserscan (LBS_SET_USER_SCAN) private ioctl.  Specifies
46  *   a number of parameters to be used in general for the scan as well
47  *   as a channel list (lbs_ioctl_user_scan_chan) for each scan period
48  *   desired.
49  *
50  *  @sa lbs_set_user_scan_ioctl
51  */
52 struct lbs_ioctl_user_scan_cfg {
53     /**
54      *  @brief BSS type to be sent in the firmware command
55      *
56      *  Field can be used to restrict the types of networks returned in the
57      *    scan.  valid settings are:
58      *
59      *   - LBS_SCAN_BSS_TYPE_BSS  (infrastructure)
60      *   - LBS_SCAN_BSS_TYPE_IBSS (adhoc)
61      *   - LBS_SCAN_BSS_TYPE_ANY  (unrestricted, adhoc and infrastructure)
62      */
63         u8 bsstype;
64
65         /**
66          *  @brief BSSID filter sent in the firmware command to limit the results
67          */
68         u8 bssid[ETH_ALEN];
69
70         /* Clear existing scan results matching this BSSID */
71         u8 clear_bssid;
72
73         /**
74          *  @brief SSID filter sent in the firmware command to limit the results
75          */
76         char ssid[IW_ESSID_MAX_SIZE];
77         u8 ssid_len;
78
79         /* Clear existing scan results matching this SSID */
80         u8 clear_ssid;
81 };
82
83 /**
84  *  @brief Structure used to store information for each beacon/probe response
85  */
86 struct bss_descriptor {
87         u8 bssid[ETH_ALEN];
88
89         u8 ssid[IW_ESSID_MAX_SIZE + 1];
90         u8 ssid_len;
91
92         u16 capability;
93
94         /* receive signal strength in dBm */
95         long rssi;
96
97         u32 channel;
98
99         u16 beaconperiod;
100
101         u32 atimwindow;
102
103         /* IW_MODE_AUTO, IW_MODE_ADHOC, IW_MODE_INFRA */
104         u8 mode;
105
106         /* zero-terminated array of supported data rates */
107         u8 rates[MAX_RATES + 1];
108
109         unsigned long last_scanned;
110
111         union ieeetypes_phyparamset phyparamset;
112         union IEEEtypes_ssparamset ssparamset;
113
114         struct ieeetypes_countryinfofullset countryinfo;
115
116         u8 wpa_ie[MAX_WPA_IE_LEN];
117         size_t wpa_ie_len;
118         u8 rsn_ie[MAX_WPA_IE_LEN];
119         size_t rsn_ie_len;
120
121         u8 mesh;
122
123         struct list_head list;
124 };
125
126 int lbs_ssid_cmp(u8 *ssid1, u8 ssid1_len, u8 *ssid2, u8 ssid2_len);
127
128 struct bss_descriptor *lbs_find_ssid_in_list(struct lbs_private *priv,
129                 u8 *ssid, u8 ssid_len, u8 *bssid, u8 mode,
130                 int channel);
131
132 struct bss_descriptor *lbs_find_bssid_in_list(struct lbs_private *priv,
133         u8 *bssid, u8 mode);
134
135 int lbs_find_best_network_ssid(struct lbs_private *priv, u8 *out_ssid,
136                         u8 *out_ssid_len, u8 preferred_mode, u8 *out_mode);
137
138 int lbs_send_specific_ssid_scan(struct lbs_private *priv, u8 *ssid,
139                                 u8 ssid_len, u8 clear_ssid);
140
141 int lbs_scan_networks(struct lbs_private *priv,
142         const struct lbs_ioctl_user_scan_cfg *puserscanin,
143                 int full_scan);
144
145 struct ifreq;
146
147 struct iw_point;
148 struct iw_param;
149 struct iw_request_info;
150 int lbs_get_scan(struct net_device *dev, struct iw_request_info *info,
151                          struct iw_point *dwrq, char *extra);
152 int lbs_set_scan(struct net_device *dev, struct iw_request_info *info,
153                          struct iw_param *vwrq, char *extra);
154
155 void lbs_scan_worker(struct work_struct *work);
156
157 #endif