Commit | Line | Data |
---|---|---|
876c9d3a MT |
1 | /** |
2 | * This header file contains global constant/enum definitions, | |
3 | * global variable declaration. | |
4 | */ | |
10078321 HS |
5 | #ifndef _LBS_DEFS_H_ |
6 | #define _LBS_DEFS_H_ | |
876c9d3a MT |
7 | |
8 | #include <linux/spinlock.h> | |
9 | ||
3a8b9a4a DW |
10 | #ifdef CONFIG_LIBERTAS_DEBUG |
11 | #define DEBUG | |
12 | #define PROC_DEBUG | |
13 | #endif | |
14 | ||
ec3eef28 HS |
15 | #ifndef DRV_NAME |
16 | #define DRV_NAME "libertas" | |
17 | #endif | |
9012b28a HS |
18 | |
19 | ||
a46c6410 HS |
20 | #define LBS_DEB_ENTER 0x00000001 |
21 | #define LBS_DEB_LEAVE 0x00000002 | |
22 | #define LBS_DEB_MAIN 0x00000004 | |
23 | #define LBS_DEB_NET 0x00000008 | |
24 | #define LBS_DEB_MESH 0x00000010 | |
25 | #define LBS_DEB_WEXT 0x00000020 | |
26 | #define LBS_DEB_IOCTL 0x00000040 | |
27 | #define LBS_DEB_SCAN 0x00000080 | |
28 | #define LBS_DEB_ASSOC 0x00000100 | |
29 | #define LBS_DEB_JOIN 0x00000200 | |
30 | #define LBS_DEB_11D 0x00000400 | |
31 | #define LBS_DEB_DEBUGFS 0x00000800 | |
32 | #define LBS_DEB_ETHTOOL 0x00001000 | |
33 | #define LBS_DEB_HOST 0x00002000 | |
34 | #define LBS_DEB_CMD 0x00004000 | |
35 | #define LBS_DEB_RX 0x00008000 | |
36 | #define LBS_DEB_TX 0x00010000 | |
37 | #define LBS_DEB_USB 0x00020000 | |
38 | #define LBS_DEB_CS 0x00040000 | |
39 | #define LBS_DEB_FW 0x00080000 | |
40 | #define LBS_DEB_THREAD 0x00100000 | |
41 | #define LBS_DEB_HEX 0x00200000 | |
727c26ed | 42 | #define LBS_DEB_SDIO 0x00400000 |
15dbaac0 | 43 | #define LBS_DEB_SYSFS 0x00800000 |
d2b21f19 | 44 | #define LBS_DEB_SPI 0x01000000 |
a46c6410 | 45 | |
10078321 | 46 | extern unsigned int lbs_debug; |
9012b28a HS |
47 | |
48 | #ifdef DEBUG | |
ece56191 | 49 | #define LBS_DEB_LL(grp, grpnam, fmt, args...) \ |
10078321 | 50 | do { if ((lbs_debug & (grp)) == (grp)) \ |
ece56191 | 51 | printk(KERN_DEBUG DRV_NAME grpnam "%s: " fmt, \ |
9012b28a HS |
52 | in_interrupt() ? " (INT)" : "", ## args); } while (0) |
53 | #else | |
ece56191 | 54 | #define LBS_DEB_LL(grp, grpnam, fmt, args...) do {} while (0) |
9012b28a HS |
55 | #endif |
56 | ||
57 | #define lbs_deb_enter(grp) \ | |
e5225b39 | 58 | LBS_DEB_LL(grp | LBS_DEB_ENTER, " enter", "%s()\n", __func__); |
9012b28a | 59 | #define lbs_deb_enter_args(grp, fmt, args...) \ |
e5225b39 | 60 | LBS_DEB_LL(grp | LBS_DEB_ENTER, " enter", "%s(" fmt ")\n", __func__, ## args); |
9012b28a | 61 | #define lbs_deb_leave(grp) \ |
e5225b39 | 62 | LBS_DEB_LL(grp | LBS_DEB_LEAVE, " leave", "%s()\n", __func__); |
9012b28a | 63 | #define lbs_deb_leave_args(grp, fmt, args...) \ |
e5225b39 HS |
64 | LBS_DEB_LL(grp | LBS_DEB_LEAVE, " leave", "%s(), " fmt "\n", \ |
65 | __func__, ##args); | |
ece56191 HS |
66 | #define lbs_deb_main(fmt, args...) LBS_DEB_LL(LBS_DEB_MAIN, " main", fmt, ##args) |
67 | #define lbs_deb_net(fmt, args...) LBS_DEB_LL(LBS_DEB_NET, " net", fmt, ##args) | |
68 | #define lbs_deb_mesh(fmt, args...) LBS_DEB_LL(LBS_DEB_MESH, " mesh", fmt, ##args) | |
69 | #define lbs_deb_wext(fmt, args...) LBS_DEB_LL(LBS_DEB_WEXT, " wext", fmt, ##args) | |
70 | #define lbs_deb_ioctl(fmt, args...) LBS_DEB_LL(LBS_DEB_IOCTL, " ioctl", fmt, ##args) | |
71 | #define lbs_deb_scan(fmt, args...) LBS_DEB_LL(LBS_DEB_SCAN, " scan", fmt, ##args) | |
72 | #define lbs_deb_assoc(fmt, args...) LBS_DEB_LL(LBS_DEB_ASSOC, " assoc", fmt, ##args) | |
73 | #define lbs_deb_join(fmt, args...) LBS_DEB_LL(LBS_DEB_JOIN, " join", fmt, ##args) | |
74 | #define lbs_deb_11d(fmt, args...) LBS_DEB_LL(LBS_DEB_11D, " 11d", fmt, ##args) | |
75 | #define lbs_deb_debugfs(fmt, args...) LBS_DEB_LL(LBS_DEB_DEBUGFS, " debugfs", fmt, ##args) | |
76 | #define lbs_deb_ethtool(fmt, args...) LBS_DEB_LL(LBS_DEB_ETHTOOL, " ethtool", fmt, ##args) | |
77 | #define lbs_deb_host(fmt, args...) LBS_DEB_LL(LBS_DEB_HOST, " host", fmt, ##args) | |
78 | #define lbs_deb_cmd(fmt, args...) LBS_DEB_LL(LBS_DEB_CMD, " cmd", fmt, ##args) | |
79 | #define lbs_deb_rx(fmt, args...) LBS_DEB_LL(LBS_DEB_RX, " rx", fmt, ##args) | |
80 | #define lbs_deb_tx(fmt, args...) LBS_DEB_LL(LBS_DEB_TX, " tx", fmt, ##args) | |
81 | #define lbs_deb_fw(fmt, args...) LBS_DEB_LL(LBS_DEB_FW, " fw", fmt, ##args) | |
82 | #define lbs_deb_usb(fmt, args...) LBS_DEB_LL(LBS_DEB_USB, " usb", fmt, ##args) | |
fb28ad35 | 83 | #define lbs_deb_usbd(dev, fmt, args...) LBS_DEB_LL(LBS_DEB_USB, " usbd", "%s:" fmt, dev_name(dev), ##args) |
ece56191 HS |
84 | #define lbs_deb_cs(fmt, args...) LBS_DEB_LL(LBS_DEB_CS, " cs", fmt, ##args) |
85 | #define lbs_deb_thread(fmt, args...) LBS_DEB_LL(LBS_DEB_THREAD, " thread", fmt, ##args) | |
15dbaac0 JC |
86 | #define lbs_deb_sdio(fmt, args...) LBS_DEB_LL(LBS_DEB_SDIO, " sdio", fmt, ##args) |
87 | #define lbs_deb_sysfs(fmt, args...) LBS_DEB_LL(LBS_DEB_SYSFS, " sysfs", fmt, ##args) | |
d2b21f19 | 88 | #define lbs_deb_spi(fmt, args...) LBS_DEB_LL(LBS_DEB_SPI, " spi", fmt, ##args) |
876c9d3a MT |
89 | |
90 | #define lbs_pr_info(format, args...) \ | |
91 | printk(KERN_INFO DRV_NAME": " format, ## args) | |
92 | #define lbs_pr_err(format, args...) \ | |
93 | printk(KERN_ERR DRV_NAME": " format, ## args) | |
94 | #define lbs_pr_alert(format, args...) \ | |
95 | printk(KERN_ALERT DRV_NAME": " format, ## args) | |
96 | ||
97 | #ifdef DEBUG | |
ece56191 | 98 | static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, int len) |
876c9d3a MT |
99 | { |
100 | int i = 0; | |
101 | ||
ece56191 | 102 | if (len && |
10078321 HS |
103 | (lbs_debug & LBS_DEB_HEX) && |
104 | (lbs_debug & grp)) | |
ece56191 HS |
105 | { |
106 | for (i = 1; i <= len; i++) { | |
107 | if ((i & 0xf) == 1) { | |
108 | if (i != 1) | |
109 | printk("\n"); | |
110 | printk(DRV_NAME " %s: ", prompt); | |
111 | } | |
112 | printk("%02x ", (u8) * buf); | |
113 | buf++; | |
114 | } | |
115 | printk("\n"); | |
876c9d3a | 116 | } |
876c9d3a MT |
117 | } |
118 | #else | |
ece56191 | 119 | #define lbs_deb_hex(grp,prompt,buf,len) do {} while (0) |
876c9d3a MT |
120 | #endif |
121 | ||
9012b28a | 122 | |
876c9d3a MT |
123 | |
124 | /** Buffer Constants */ | |
125 | ||
126 | /* The size of SQ memory PPA, DPA are 8 DWORDs, that keep the physical | |
127 | * addresses of TxPD buffers. Station has only 8 TxPD available, Whereas | |
128 | * driver has more local TxPDs. Each TxPD on the host memory is associated | |
129 | * with a Tx control node. The driver maintains 8 RxPD descriptors for | |
130 | * station firmware to store Rx packet information. | |
131 | * | |
132 | * Current version of MAC has a 32x6 multicast address buffer. | |
133 | * | |
134 | * 802.11b can have up to 14 channels, the driver keeps the | |
135 | * BSSID(MAC address) of each APs or Ad hoc stations it has sensed. | |
136 | */ | |
137 | ||
138 | #define MRVDRV_MAX_MULTICAST_LIST_SIZE 32 | |
ddac4526 DW |
139 | #define LBS_NUM_CMD_BUFFERS 10 |
140 | #define LBS_CMD_BUFFER_SIZE (2 * 1024) | |
876c9d3a | 141 | #define MRVDRV_MAX_CHANNEL_SIZE 14 |
876c9d3a MT |
142 | #define MRVDRV_ASSOCIATION_TIME_OUT 255 |
143 | #define MRVDRV_SNAP_HEADER_LEN 8 | |
144 | ||
10078321 | 145 | #define LBS_UPLD_SIZE 2312 |
876c9d3a MT |
146 | #define DEV_NAME_LEN 32 |
147 | ||
6ce4fd2a DW |
148 | /* Wake criteria for HOST_SLEEP_CFG command */ |
149 | #define EHS_WAKE_ON_BROADCAST_DATA 0x0001 | |
150 | #define EHS_WAKE_ON_UNICAST_DATA 0x0002 | |
151 | #define EHS_WAKE_ON_MAC_EVENT 0x0004 | |
152 | #define EHS_WAKE_ON_MULTICAST_DATA 0x0008 | |
153 | #define EHS_REMOVE_WAKEUP 0xFFFFFFFF | |
582c1b53 AN |
154 | /* Wake rules for Host_Sleep_CFG command */ |
155 | #define WOL_RULE_NET_TYPE_INFRA_OR_IBSS 0x00 | |
156 | #define WOL_RULE_NET_TYPE_MESH 0x10 | |
157 | #define WOL_RULE_ADDR_TYPE_BCAST 0x01 | |
158 | #define WOL_RULE_ADDR_TYPE_MCAST 0x08 | |
159 | #define WOL_RULE_ADDR_TYPE_UCAST 0x02 | |
160 | #define WOL_RULE_OP_AND 0x01 | |
161 | #define WOL_RULE_OP_OR 0x02 | |
162 | #define WOL_RULE_OP_INVALID 0xFF | |
163 | #define WOL_RESULT_VALID_CMD 0 | |
164 | #define WOL_RESULT_NOSPC_ERR 1 | |
165 | #define WOL_RESULT_EEXIST_ERR 2 | |
6ce4fd2a | 166 | |
876c9d3a MT |
167 | /** Misc constants */ |
168 | /* This section defines 802.11 specific contants */ | |
169 | ||
170 | #define MRVDRV_MAX_BSS_DESCRIPTS 16 | |
171 | #define MRVDRV_MAX_REGION_CODE 6 | |
172 | ||
173 | #define MRVDRV_IGNORE_MULTIPLE_DTIM 0xfffe | |
174 | #define MRVDRV_MIN_MULTIPLE_DTIM 1 | |
175 | #define MRVDRV_MAX_MULTIPLE_DTIM 5 | |
176 | #define MRVDRV_DEFAULT_MULTIPLE_DTIM 1 | |
177 | ||
178 | #define MRVDRV_DEFAULT_LISTEN_INTERVAL 10 | |
179 | ||
180 | #define MRVDRV_CHANNELS_PER_SCAN 4 | |
181 | #define MRVDRV_MAX_CHANNELS_PER_SCAN 14 | |
182 | ||
876c9d3a MT |
183 | #define MRVDRV_MIN_BEACON_INTERVAL 20 |
184 | #define MRVDRV_MAX_BEACON_INTERVAL 1000 | |
185 | #define MRVDRV_BEACON_INTERVAL 100 | |
186 | ||
1e838bf3 LCC |
187 | #define MARVELL_MESH_IE_LENGTH 9 |
188 | ||
edaea5ce JC |
189 | /* Values used to populate the struct mrvl_mesh_ie. The only time you need this |
190 | * is when enabling the mesh using CMD_MESH_CONFIG. | |
191 | */ | |
192 | #define MARVELL_MESH_IE_TYPE 4 | |
193 | #define MARVELL_MESH_IE_SUBTYPE 0 | |
194 | #define MARVELL_MESH_IE_VERSION 0 | |
195 | #define MARVELL_MESH_PROTO_ID_HWMP 0 | |
196 | #define MARVELL_MESH_METRIC_ID 0 | |
197 | #define MARVELL_MESH_CAPABILITY 0 | |
198 | ||
208fdd2f | 199 | /** INT status Bit Definition*/ |
c95c7f93 HS |
200 | #define MRVDRV_TX_DNLD_RDY 0x0001 |
201 | #define MRVDRV_RX_UPLD_RDY 0x0002 | |
202 | #define MRVDRV_CMD_DNLD_RDY 0x0004 | |
203 | #define MRVDRV_CMD_UPLD_RDY 0x0008 | |
204 | #define MRVDRV_CARDEVENT 0x0010 | |
208fdd2f | 205 | |
0112c9e9 AN |
206 | /* Automatic TX control default levels */ |
207 | #define POW_ADAPT_DEFAULT_P0 13 | |
208 | #define POW_ADAPT_DEFAULT_P1 15 | |
209 | #define POW_ADAPT_DEFAULT_P2 18 | |
210 | #define TPC_DEFAULT_P0 5 | |
211 | #define TPC_DEFAULT_P1 10 | |
212 | #define TPC_DEFAULT_P2 13 | |
213 | ||
876c9d3a MT |
214 | /** TxPD status */ |
215 | ||
216 | /* Station firmware use TxPD status field to report final Tx transmit | |
217 | * result, Bit masks are used to present combined situations. | |
218 | */ | |
219 | ||
220 | #define MRVDRV_TxPD_POWER_MGMT_NULL_PACKET 0x01 | |
221 | #define MRVDRV_TxPD_POWER_MGMT_LAST_PACKET 0x08 | |
222 | ||
223 | /** Tx mesh flag */ | |
224 | /* Currently we are using normal WDS flag as mesh flag. | |
225 | * TODO: change to proper mesh flag when MAC understands it. | |
226 | */ | |
227 | #define TxPD_CONTROL_WDS_FRAME (1<<17) | |
228 | #define TxPD_MESH_FRAME TxPD_CONTROL_WDS_FRAME | |
229 | ||
684d6b36 BZ |
230 | /** Mesh interface ID */ |
231 | #define MESH_IFACE_ID 0x0001 | |
232 | /** Mesh id should be in bits 14-13-12 */ | |
233 | #define MESH_IFACE_BIT_OFFSET 0x000c | |
234 | /** Mesh enable bit in FW capability */ | |
235 | #define MESH_CAPINFO_ENABLE_MASK (1<<16) | |
236 | ||
237 | /** FW definition from Marvell v5 */ | |
238 | #define MRVL_FW_V5 (0x05) | |
239 | /** FW definition from Marvell v10 */ | |
240 | #define MRVL_FW_V10 (0x0a) | |
241 | /** FW major revision definition */ | |
242 | #define MRVL_FW_MAJOR_REV(x) ((x)>>24) | |
243 | ||
876c9d3a MT |
244 | /** RxPD status */ |
245 | ||
246 | #define MRVDRV_RXPD_STATUS_OK 0x0001 | |
247 | ||
248 | /** RxPD status - Received packet types */ | |
249 | /** Rx mesh flag */ | |
250 | /* Currently we are using normal WDS flag as mesh flag. | |
251 | * TODO: change to proper mesh flag when MAC understands it. | |
252 | */ | |
253 | #define RxPD_CONTROL_WDS_FRAME (0x40) | |
254 | #define RxPD_MESH_FRAME RxPD_CONTROL_WDS_FRAME | |
255 | ||
256 | /** RSSI-related defines */ | |
257 | /* RSSI constants are used to implement 802.11 RSSI threshold | |
258 | * indication. if the Rx packet signal got too weak for 5 consecutive | |
259 | * times, miniport driver (driver) will report this event to wrapper | |
260 | */ | |
261 | ||
262 | #define MRVDRV_NF_DEFAULT_SCAN_VALUE (-96) | |
263 | ||
264 | /** RTS/FRAG related defines */ | |
265 | #define MRVDRV_RTS_MIN_VALUE 0 | |
266 | #define MRVDRV_RTS_MAX_VALUE 2347 | |
267 | #define MRVDRV_FRAG_MIN_VALUE 256 | |
268 | #define MRVDRV_FRAG_MAX_VALUE 2346 | |
269 | ||
270 | /* This is for firmware specific length */ | |
271 | #define EXTRA_LEN 36 | |
272 | ||
273 | #define MRVDRV_ETH_TX_PACKET_BUFFER_SIZE \ | |
274 | (ETH_FRAME_LEN + sizeof(struct txpd) + EXTRA_LEN) | |
275 | ||
276 | #define MRVDRV_ETH_RX_PACKET_BUFFER_SIZE \ | |
277 | (ETH_FRAME_LEN + sizeof(struct rxpd) \ | |
278 | + MRVDRV_SNAP_HEADER_LEN + EXTRA_LEN) | |
279 | ||
280 | #define CMD_F_HOSTCMD (1 << 0) | |
281 | #define FW_CAPINFO_WPA (1 << 0) | |
f5ac2b9e | 282 | #define FW_CAPINFO_PS (1 << 1) |
1556c0f2 BC |
283 | #define FW_CAPINFO_FIRMWARE_UPGRADE (1 << 13) |
284 | #define FW_CAPINFO_BOOT2_UPGRADE (1<<14) | |
285 | #define FW_CAPINFO_PERSISTENT_CONFIG (1<<15) | |
876c9d3a | 286 | |
876c9d3a MT |
287 | #define KEY_LEN_WPA_AES 16 |
288 | #define KEY_LEN_WPA_TKIP 32 | |
289 | #define KEY_LEN_WEP_104 13 | |
290 | #define KEY_LEN_WEP_40 5 | |
291 | ||
292 | #define RF_ANTENNA_1 0x1 | |
293 | #define RF_ANTENNA_2 0x2 | |
294 | #define RF_ANTENNA_AUTO 0xFFFF | |
295 | ||
296 | #define BAND_B (0x01) | |
297 | #define BAND_G (0x02) | |
298 | #define ALL_802_11_BANDS (BAND_B | BAND_G) | |
299 | ||
300 | /** MACRO DEFINITIONS */ | |
301 | #define CAL_NF(NF) ((s32)(-(s32)(NF))) | |
302 | #define CAL_RSSI(SNR, NF) ((s32)((s32)(SNR) + CAL_NF(NF))) | |
303 | #define SCAN_RSSI(RSSI) (0x100 - ((u8)(RSSI))) | |
304 | ||
305 | #define DEFAULT_BCN_AVG_FACTOR 8 | |
306 | #define DEFAULT_DATA_AVG_FACTOR 8 | |
307 | #define AVG_SCALE 100 | |
308 | #define CAL_AVG_SNR_NF(AVG, SNRNF, N) \ | |
309 | (((AVG) == 0) ? ((u16)(SNRNF) * AVG_SCALE) : \ | |
310 | ((((int)(AVG) * (N -1)) + ((u16)(SNRNF) * \ | |
311 | AVG_SCALE)) / N)) | |
312 | ||
8c512765 | 313 | #define MAX_RATES 14 |
876c9d3a MT |
314 | |
315 | #define MAX_LEDS 8 | |
316 | ||
876c9d3a | 317 | /** Global Variable Declaration */ |
10078321 HS |
318 | extern const char lbs_driver_version[]; |
319 | extern u16 lbs_region_code_to_index[MRVDRV_MAX_REGION_CODE]; | |
876c9d3a | 320 | |
10078321 | 321 | extern u8 lbs_bg_rates[MAX_RATES]; |
876c9d3a MT |
322 | |
323 | /** ENUM definition*/ | |
324 | /** SNRNF_TYPE */ | |
325 | enum SNRNF_TYPE { | |
326 | TYPE_BEACON = 0, | |
327 | TYPE_RXPD, | |
328 | MAX_TYPE_B | |
329 | }; | |
330 | ||
331 | /** SNRNF_DATA*/ | |
332 | enum SNRNF_DATA { | |
333 | TYPE_NOAVG = 0, | |
334 | TYPE_AVG, | |
335 | MAX_TYPE_AVG | |
336 | }; | |
337 | ||
10078321 HS |
338 | /** LBS_802_11_POWER_MODE */ |
339 | enum LBS_802_11_POWER_MODE { | |
340 | LBS802_11POWERMODECAM, | |
341 | LBS802_11POWERMODEMAX_PSP, | |
342 | LBS802_11POWERMODEFAST_PSP, | |
876c9d3a | 343 | /*not a real mode, defined as an upper bound */ |
10078321 | 344 | LBS802_11POWEMODEMAX |
876c9d3a MT |
345 | }; |
346 | ||
347 | /** PS_STATE */ | |
348 | enum PS_STATE { | |
349 | PS_STATE_FULL_POWER, | |
350 | PS_STATE_AWAKE, | |
351 | PS_STATE_PRE_SLEEP, | |
352 | PS_STATE_SLEEP | |
353 | }; | |
354 | ||
355 | /** DNLD_STATE */ | |
356 | enum DNLD_STATE { | |
357 | DNLD_RES_RECEIVED, | |
358 | DNLD_DATA_SENT, | |
1556c0f2 BC |
359 | DNLD_CMD_SENT, |
360 | DNLD_BOOTCMD_SENT, | |
876c9d3a MT |
361 | }; |
362 | ||
10078321 HS |
363 | /** LBS_MEDIA_STATE */ |
364 | enum LBS_MEDIA_STATE { | |
365 | LBS_CONNECTED, | |
366 | LBS_DISCONNECTED | |
876c9d3a MT |
367 | }; |
368 | ||
10078321 HS |
369 | /** LBS_802_11_PRIVACY_FILTER */ |
370 | enum LBS_802_11_PRIVACY_FILTER { | |
371 | LBS802_11PRIVFILTERACCEPTALL, | |
372 | LBS802_11PRIVFILTER8021XWEP | |
876c9d3a MT |
373 | }; |
374 | ||
375 | /** mv_ms_type */ | |
376 | enum mv_ms_type { | |
377 | MVMS_DAT = 0, | |
378 | MVMS_CMD = 1, | |
379 | MVMS_TXDONE = 2, | |
380 | MVMS_EVENT | |
381 | }; | |
876c9d3a | 382 | |
876c9d3a MT |
383 | /** KEY_TYPE_ID */ |
384 | enum KEY_TYPE_ID { | |
385 | KEY_TYPE_ID_WEP = 0, | |
386 | KEY_TYPE_ID_TKIP, | |
387 | KEY_TYPE_ID_AES | |
388 | }; | |
389 | ||
390 | /** KEY_INFO_WPA (applies to both TKIP and AES/CCMP) */ | |
391 | enum KEY_INFO_WPA { | |
392 | KEY_INFO_WPA_MCAST = 0x01, | |
393 | KEY_INFO_WPA_UNICAST = 0x02, | |
394 | KEY_INFO_WPA_ENABLED = 0x04 | |
395 | }; | |
396 | ||
684d6b36 BZ |
397 | /** mesh_fw_ver */ |
398 | enum _mesh_fw_ver { | |
399 | MESH_NONE = 0, /* MESH is not supported */ | |
400 | MESH_FW_OLD, /* MESH is supported in FW V5 */ | |
401 | MESH_FW_NEW, /* MESH is supported in FW V10 and newer */ | |
402 | }; | |
403 | ||
876c9d3a MT |
404 | /* Default values for fwt commands. */ |
405 | #define FWT_DEFAULT_METRIC 0 | |
406 | #define FWT_DEFAULT_DIR 1 | |
90e8eafc LCC |
407 | /* Default Rate, 11Mbps */ |
408 | #define FWT_DEFAULT_RATE 3 | |
876c9d3a MT |
409 | #define FWT_DEFAULT_SSN 0xffffffff |
410 | #define FWT_DEFAULT_DSN 0 | |
411 | #define FWT_DEFAULT_HOPCOUNT 0 | |
412 | #define FWT_DEFAULT_TTL 0 | |
413 | #define FWT_DEFAULT_EXPIRATION 0 | |
414 | #define FWT_DEFAULT_SLEEPMODE 0 | |
415 | #define FWT_DEFAULT_SNR 0 | |
416 | ||
10078321 | 417 | #endif |