• Home
  • History
  • Annotate
  • Line#
  • Navigate
  • Raw
  • Download
  • only in /netgear-R7000-V1.0.7.12_1.2.5/components/opensource/linux/linux-2.6.36/drivers/staging/vt6655/
1/*
2 * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
3 * All rights reserved.
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 *
20 * File: wmgr.h
21 *
22 * Purpose:
23 *
24 * Author: lyndon chen
25 *
26 * Date: Jan 2, 2003
27 *
28 * Functions:
29 *
30 * Revision History:
31 *
32 */
33
34#ifndef __WMGR_H__
35#define __WMGR_H__
36
37#include "ttype.h"
38#include "80211mgr.h"
39#include "80211hdr.h"
40#include "wcmd.h"
41#include "bssdb.h"
42#include "wpa2.h"
43#include "vntwifi.h"
44#include "card.h"
45
46/*---------------------  Export Definitions -------------------------*/
47
48
49
50// Scan time
51#define PROBE_DELAY                  100  // (us)
52#define SWITCH_CHANNEL_DELAY         200 // (us)
53#define WLAN_SCAN_MINITIME           25   // (ms)
54#define WLAN_SCAN_MAXTIME            100  // (ms)
55#define TRIVIAL_SYNC_DIFFERENCE      0    // (us)
56#define DEFAULT_IBSS_BI              100  // (ms)
57
58#define WCMD_ACTIVE_SCAN_TIME   50 //(ms)
59#define WCMD_PASSIVE_SCAN_TIME  100 //(ms)
60
61
62#define DEFAULT_MSDU_LIFETIME           512  // ms
63#define DEFAULT_MSDU_LIFETIME_RES_64us  8000 // 64us
64
65#define DEFAULT_MGN_LIFETIME            8    // ms
66#define DEFAULT_MGN_LIFETIME_RES_64us   125  // 64us
67
68#define MAKE_BEACON_RESERVED            10  //(us)
69
70
71#define TIM_MULTICAST_MASK           0x01
72#define TIM_BITMAPOFFSET_MASK        0xFE
73#define DEFAULT_DTIM_PERIOD             1
74
75#define AP_LONG_RETRY_LIMIT             4
76
77#define DEFAULT_IBSS_CHANNEL            6  //2.4G
78
79
80/*---------------------  Export Classes  ----------------------------*/
81
82/*---------------------  Export Variables  --------------------------*/
83
84/*---------------------  Export Types  ------------------------------*/
85#define timer_expire(timer,next_tick)   mod_timer(&timer, RUN_AT(next_tick))
86typedef void (*TimerFunction)(unsigned long);
87
88
89//+++ NDIS related
90
91typedef unsigned char NDIS_802_11_MAC_ADDRESS[6];
92typedef struct _NDIS_802_11_AI_REQFI
93{
94    unsigned short Capabilities;
95    unsigned short ListenInterval;
96    NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;
97} NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;
98
99typedef struct _NDIS_802_11_AI_RESFI
100{
101    unsigned short Capabilities;
102    unsigned short StatusCode;
103    unsigned short AssociationId;
104} NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;
105
106typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION
107{
108    unsigned long Length;
109    unsigned short          AvailableRequestFixedIEs;
110    NDIS_802_11_AI_REQFI    RequestFixedIEs;
111    unsigned long RequestIELength;
112    unsigned long OffsetRequestIEs;
113    unsigned short          AvailableResponseFixedIEs;
114    NDIS_802_11_AI_RESFI    ResponseFixedIEs;
115    unsigned long ResponseIELength;
116    unsigned long OffsetResponseIEs;
117} NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;
118
119
120
121typedef struct tagSAssocInfo {
122    NDIS_802_11_ASSOCIATION_INFORMATION     AssocInfo;
123    unsigned char abyIEs[WLAN_BEACON_FR_MAXLEN+WLAN_BEACON_FR_MAXLEN];
124    // store ReqIEs set by OID_802_11_ASSOCIATION_INFORMATION
125    unsigned long RequestIELength;
126    unsigned char abyReqIEs[WLAN_BEACON_FR_MAXLEN];
127} SAssocInfo, *PSAssocInfo;
128//---
129
130
131/*
132typedef enum tagWMAC_AUTHENTICATION_MODE {
133
134
135    WMAC_AUTH_OPEN,
136    WMAC_AUTH_SHAREKEY,
137    WMAC_AUTH_AUTO,
138    WMAC_AUTH_WPA,
139    WMAC_AUTH_WPAPSK,
140    WMAC_AUTH_WPANONE,
141    WMAC_AUTH_WPA2,
142    WMAC_AUTH_WPA2PSK,
143    WMAC_AUTH_MAX       // Not a real mode, defined as upper bound
144
145
146} WMAC_AUTHENTICATION_MODE, *PWMAC_AUTHENTICATION_MODE;
147*/
148
149
150// Pre-configured Mode (from XP)
151/*
152typedef enum tagWMAC_CONFIG_MODE {
153    WMAC_CONFIG_ESS_STA,
154    WMAC_CONFIG_IBSS_STA,
155    WMAC_CONFIG_AUTO,
156    WMAC_CONFIG_AP
157
158} WMAC_CONFIG_MODE, *PWMAC_CONFIG_MODE;
159*/
160
161typedef enum tagWMAC_SCAN_TYPE {
162
163    WMAC_SCAN_ACTIVE,
164    WMAC_SCAN_PASSIVE,
165    WMAC_SCAN_HYBRID
166
167} WMAC_SCAN_TYPE, *PWMAC_SCAN_TYPE;
168
169
170typedef enum tagWMAC_SCAN_STATE {
171
172    WMAC_NO_SCANNING,
173    WMAC_IS_SCANNING,
174    WMAC_IS_PROBEPENDING
175
176} WMAC_SCAN_STATE, *PWMAC_SCAN_STATE;
177
178
179
180// Notes:
181// Basic Service Set state explained as following:
182// WMAC_STATE_IDLE          : no BSS is selected (Adhoc or Infra)
183// WMAC_STATE_STARTED       : no BSS is selected, start own IBSS (Adhoc only)
184// WMAC_STATE_JOINTED       : BSS is selected and synchronized (Adhoc or Infra)
185// WMAC_STATE_AUTHPENDING   : Authentication pending (Infra)
186// WMAC_STATE_AUTH          : Authenticated (Infra)
187// WMAC_STATE_ASSOCPENDING  : Association pending (Infra)
188// WMAC_STATE_ASSOC         : Associated (Infra)
189
190typedef enum tagWMAC_BSS_STATE {
191
192    WMAC_STATE_IDLE,
193    WMAC_STATE_STARTED,
194    WMAC_STATE_JOINTED,
195    WMAC_STATE_AUTHPENDING,
196    WMAC_STATE_AUTH,
197    WMAC_STATE_ASSOCPENDING,
198    WMAC_STATE_ASSOC
199
200} WMAC_BSS_STATE, *PWMAC_BSS_STATE;
201
202// WMAC selected running mode
203typedef enum tagWMAC_CURRENT_MODE {
204
205    WMAC_MODE_STANDBY,
206    WMAC_MODE_ESS_STA,
207    WMAC_MODE_IBSS_STA,
208    WMAC_MODE_ESS_AP
209
210} WMAC_CURRENT_MODE, *PWMAC_CURRENT_MODE;
211
212/*
213typedef enum tagWMAC_POWER_MODE {
214
215    WMAC_POWER_CAM,
216    WMAC_POWER_FAST,
217    WMAC_POWER_MAX
218
219} WMAC_POWER_MODE, *PWMAC_POWER_MODE;
220*/
221
222
223// Tx Managment Packet descriptor
224typedef struct tagSTxMgmtPacket {
225
226    PUWLAN_80211HDR     p80211Header;
227    unsigned int cbMPDULen;
228    unsigned int cbPayloadLen;
229
230} STxMgmtPacket, *PSTxMgmtPacket;
231
232
233// Rx Managment Packet descriptor
234typedef struct tagSRxMgmtPacket {
235
236    PUWLAN_80211HDR     p80211Header;
237    QWORD               qwLocalTSF;
238    unsigned int cbMPDULen;
239    unsigned int cbPayloadLen;
240    unsigned int uRSSI;
241    unsigned char bySQ;
242    unsigned char byRxRate;
243    unsigned char byRxChannel;
244
245} SRxMgmtPacket, *PSRxMgmtPacket;
246
247
248
249typedef struct tagSMgmtObject
250{
251
252    void *                   pAdapter;
253    // MAC address
254    unsigned char abyMACAddr[WLAN_ADDR_LEN];
255
256    // Configuration Mode
257    WMAC_CONFIG_MODE        eConfigMode; // MAC pre-configed mode
258    CARD_PHY_TYPE           eCurrentPHYMode;
259    CARD_PHY_TYPE           eConfigPHYMode;
260
261
262    // Operation state variables
263    WMAC_CURRENT_MODE       eCurrMode;   // MAC current connection mode
264    WMAC_BSS_STATE          eCurrState;  // MAC current BSS state
265
266    PKnownBSS               pCurrBSS;
267    unsigned char byCSSGK;
268    unsigned char byCSSPK;
269
270//    unsigned char abyNewSuppRates[WLAN_IEHDR_LEN + WLAN_RATES_MAXLEN];
271//    unsigned char abyNewExtSuppRates[WLAN_IEHDR_LEN + WLAN_RATES_MAXLEN];
272
273    // Current state vars
274    unsigned int	uCurrChannel;
275    unsigned char abyCurrSuppRates[WLAN_IEHDR_LEN + WLAN_RATES_MAXLEN + 1];
276    unsigned char abyCurrExtSuppRates[WLAN_IEHDR_LEN + WLAN_RATES_MAXLEN + 1];
277    unsigned char abyCurrSSID[WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1];
278    unsigned char abyCurrBSSID[WLAN_BSSID_LEN];
279    unsigned short wCurrCapInfo;
280    unsigned short wCurrAID;
281    unsigned short wCurrATIMWindow;
282    unsigned short wCurrBeaconPeriod;
283    bool bIsDS;
284    unsigned char byERPContext;
285
286    CMD_STATE               eCommandState;
287    unsigned int	uScanChannel;
288
289    // Desire joinning BSS vars
290    unsigned char abyDesireSSID[WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1];
291    unsigned char abyDesireBSSID[WLAN_BSSID_LEN];
292
293    // Adhoc or AP configuration vars
294  //unsigned char abyAdHocSSID[WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1];
295    unsigned short wIBSSBeaconPeriod;
296    unsigned short wIBSSATIMWindow;
297    unsigned int	uIBSSChannel;
298    unsigned char abyIBSSSuppRates[WLAN_IEHDR_LEN + WLAN_RATES_MAXLEN + 1];
299    unsigned char byAPBBType;
300    unsigned char abyWPAIE[MAX_WPA_IE_LEN];
301    unsigned short wWPAIELen;
302
303    unsigned int	uAssocCount;
304    bool bMoreData;
305
306    // Scan state vars
307    WMAC_SCAN_STATE         eScanState;
308    WMAC_SCAN_TYPE          eScanType;
309    unsigned int	uScanStartCh;
310    unsigned int	uScanEndCh;
311    unsigned short wScanSteps;
312    unsigned int	uScanBSSType;
313    // Desire scannig vars
314    unsigned char abyScanSSID[WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1];
315    unsigned char abyScanBSSID[WLAN_BSSID_LEN];
316
317    // Privacy
318    WMAC_AUTHENTICATION_MODE eAuthenMode;
319    WMAC_ENCRYPTION_MODE    eEncryptionMode;
320    bool bShareKeyAlgorithm;
321    unsigned char abyChallenge[WLAN_CHALLENGE_LEN];
322    bool bPrivacyInvoked;
323
324    // Received beacon state vars
325    bool bInTIM;
326    bool bMulticastTIM;
327    unsigned char byDTIMCount;
328    unsigned char byDTIMPeriod;
329
330    // Power saving state vars
331    WMAC_POWER_MODE         ePSMode;
332    unsigned short wListenInterval;
333    unsigned short wCountToWakeUp;
334    bool bInTIMWake;
335    unsigned char *pbyPSPacketPool;
336    unsigned char byPSPacketPool[sizeof(STxMgmtPacket) + WLAN_NULLDATA_FR_MAXLEN];
337    bool bRxBeaconInTBTTWake;
338    unsigned char abyPSTxMap[MAX_NODE_NUM + 1];
339
340    // management command related
341    unsigned int	uCmdBusy;
342    unsigned int	uCmdHostAPBusy;
343
344    // management packet pool
345    unsigned char *pbyMgmtPacketPool;
346    unsigned char byMgmtPacketPool[sizeof(STxMgmtPacket) + WLAN_A3FR_MAXLEN];
347
348
349    // One second callback timer
350    struct timer_list	    sTimerSecondCallback;
351
352    // Temporarily Rx Mgmt Packet Descriptor
353    SRxMgmtPacket           sRxPacket;
354
355    // link list of known bss's (scan results)
356    KnownBSS                sBSSList[MAX_BSS_NUM];
357
358
359
360    // table list of known node
361    // sNodeDBList[0] is reserved for AP under Infra mode
362    // sNodeDBList[0] is reserved for Multicast under adhoc/AP mode
363    KnownNodeDB             sNodeDBTable[MAX_NODE_NUM + 1];
364
365
366
367    // WPA2 PMKID Cache
368    SPMKIDCache             gsPMKIDCache;
369    bool bRoaming;
370
371    // rate fall back vars
372
373
374
375    // associate info
376    SAssocInfo              sAssocInfo;
377
378
379    // for 802.11h
380    bool b11hEnable;
381    bool bSwitchChannel;
382    unsigned char byNewChannel;
383    PWLAN_IE_MEASURE_REP    pCurrMeasureEIDRep;
384    unsigned int	uLengthOfRepEIDs;
385    unsigned char abyCurrentMSRReq[sizeof(STxMgmtPacket) + WLAN_A3FR_MAXLEN];
386    unsigned char abyCurrentMSRRep[sizeof(STxMgmtPacket) + WLAN_A3FR_MAXLEN];
387    unsigned char abyIECountry[WLAN_A3FR_MAXLEN];
388    unsigned char abyIBSSDFSOwner[6];
389    unsigned char byIBSSDFSRecovery;
390
391    struct sk_buff  skb;
392
393} SMgmtObject, *PSMgmtObject;
394
395
396/*---------------------  Export Macros ------------------------------*/
397
398
399/*---------------------  Export Functions  --------------------------*/
400
401
402void
403vMgrObjectInit(
404    void *hDeviceContext
405    );
406
407void
408vMgrTimerInit(
409    void *hDeviceContext
410    );
411
412void
413vMgrObjectReset(
414    void *hDeviceContext
415    );
416
417void
418vMgrAssocBeginSta(
419    void *hDeviceContext,
420    PSMgmtObject pMgmt,
421    PCMD_STATUS pStatus
422    );
423
424void
425vMgrReAssocBeginSta(
426    void *hDeviceContext,
427    PSMgmtObject pMgmt,
428    PCMD_STATUS pStatus
429    );
430
431void
432vMgrDisassocBeginSta(
433    void *hDeviceContext,
434    PSMgmtObject pMgmt,
435    unsigned char *abyDestAddress,
436    unsigned short wReason,
437    PCMD_STATUS pStatus
438    );
439
440void
441vMgrAuthenBeginSta(
442    void *hDeviceContext,
443    PSMgmtObject pMgmt,
444    PCMD_STATUS pStatus
445    );
446
447void
448vMgrCreateOwnIBSS(
449    void *hDeviceContext,
450    PCMD_STATUS pStatus
451    );
452
453void
454vMgrJoinBSSBegin(
455    void *hDeviceContext,
456    PCMD_STATUS pStatus
457    );
458
459void
460vMgrRxManagePacket(
461    void *hDeviceContext,
462    PSMgmtObject pMgmt,
463    PSRxMgmtPacket pRxPacket
464    );
465
466/*
467void
468vMgrScanBegin(
469    void *hDeviceContext,
470    PCMD_STATUS pStatus
471    );
472*/
473
474void
475vMgrDeAuthenBeginSta(
476    void *hDeviceContext,
477    PSMgmtObject  pMgmt,
478    unsigned char *abyDestAddress,
479    unsigned short wReason,
480    PCMD_STATUS pStatus
481    );
482
483bool
484bMgrPrepareBeaconToSend(
485    void *hDeviceContext,
486    PSMgmtObject pMgmt
487    );
488
489
490bool
491bAdd_PMKID_Candidate (
492    void *hDeviceContext,
493    unsigned char *pbyBSSID,
494    PSRSNCapObject psRSNCapObj
495    );
496
497void
498vFlush_PMKID_Candidate (
499    void *hDeviceContext
500    );
501
502#endif // __WMGR_H__
503