2 * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
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.
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.
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.
20 * Purpose: Provide functions to setup NIC operation mode
22 * s_vSafeResetTx - Rest Tx
23 * CARDvSetRSPINF - Set RSPINF
24 * vUpdateIFS - Update slotTime,SIFS,DIFS, and EIFS
25 * CARDvUpdateBasicTopRate - Update BasicTopRate
26 * CARDbAddBasicRate - Add to BasicRateSet
27 * CARDbSetBasicRate - Set Basic Tx Rate
28 * CARDbIsOFDMinBasicRate - Check if any OFDM rate is in BasicRateSet
29 * CARDvSetLoopbackMode - Set Loopback mode
30 * CARDbSoftwareReset - Sortware reset NIC
31 * CARDqGetTSFOffset - Caculate TSFOffset
32 * CARDbGetCurrentTSF - Read Current NIC TSF counter
33 * CARDqGetNextTBTT - Caculate Next Beacon TSF counter
34 * CARDvSetFirstNextTBTT - Set NIC Beacon time
35 * CARDvUpdateNextTBTT - Sync. NIC Beacon time
36 * CARDbRadioPowerOff - Turn Off NIC Radio Power
37 * CARDbRadioPowerOn - Turn On NIC Radio Power
38 * CARDbSetWEPMode - Set NIC Wep mode
39 * CARDbSetTxPower - Set NIC tx power
42 * 06-10-2003 Bryan YC Fan: Re-write codes to support VT3253 spec.
43 * 08-26-2003 Kyle Hsu: Modify the defination type of dwIoBase.
44 * 09-01-2003 Bryan YC Fan: Add vUpdateIFS().
60 /*--------------------- Static Definitions -------------------------*/
62 //static int msglevel =MSG_LEVEL_DEBUG;
63 static int msglevel =MSG_LEVEL_INFO;
65 #define C_SIFS_A 16 // micro sec.
68 #define C_EIFS 80 // micro sec.
71 #define C_SLOT_SHORT 9 // micro sec.
72 #define C_SLOT_LONG 20
74 #define C_CWMIN_A 15 // slot time
77 #define C_CWMAX 1023 // slot time
79 #define CARD_MAX_CHANNEL_TBL 56
81 #define WAIT_BEACON_TX_DOWN_TMO 3 // Times
83 typedef struct tagSChannelTblElement {
88 }SChannelTblElement, *PSChannelTblElement;
90 //1M, 2M, 5M, 11M, 18M, 24M, 36M, 54M
91 static BYTE abyDefaultSuppRatesG[] = {WLAN_EID_SUPP_RATES, 8, 0x02, 0x04, 0x0B, 0x16, 0x24, 0x30, 0x48, 0x6C};
93 static BYTE abyDefaultExtSuppRatesG[] = {WLAN_EID_EXTSUPP_RATES, 4, 0x0C, 0x12, 0x18, 0x60};
94 //6M, 9M, 12M, 18M, 24M, 36M, 48M, 54M
95 static BYTE abyDefaultSuppRatesA[] = {WLAN_EID_SUPP_RATES, 8, 0x0C, 0x12, 0x18, 0x24, 0x30, 0x48, 0x60, 0x6C};
97 static BYTE abyDefaultSuppRatesB[] = {WLAN_EID_SUPP_RATES, 4, 0x02, 0x04, 0x0B, 0x16};
101 /*--------------------- Static Classes ----------------------------*/
103 /*--------------------- Static Variables --------------------------*/
106 const WORD cwRXBCNTSFOff[MAX_RATE] =
107 {17, 17, 17, 17, 34, 23, 17, 11, 8, 5, 4, 3};
109 static SChannelTblElement sChannelTbl[CARD_MAX_CHANNEL_TBL+1] =
126 {183, 4915, TRUE, 0},
127 {184, 4920, TRUE, 0},
128 {185, 4925, TRUE, 0},
129 {187, 4935, TRUE, 0},
130 {188, 4940, TRUE, 0},
131 {189, 4945, TRUE, 0},
132 {192, 4960, TRUE, 0},
133 {196, 4980, TRUE, 0},
152 {100, 5500, TRUE, 0},
153 {104, 5520, TRUE, 0},
154 {108, 5540, TRUE, 0},
155 {112, 5560, TRUE, 0},
156 {116, 5580, TRUE, 0},
157 {120, 5600, TRUE, 0},
158 {124, 5620, TRUE, 0},
159 {128, 5640, TRUE, 0},
160 {132, 5660, TRUE, 0},
161 {136, 5680, TRUE, 0},
162 {140, 5700, TRUE, 0},
163 {149, 5745, TRUE, 0},
164 {153, 5765, TRUE, 0},
165 {157, 5785, TRUE, 0},
166 {161, 5805, TRUE, 0},
171 /************************************************************************
172 * The Radar regulation rules for each country
173 ************************************************************************/
174 SCountryTable ChannelRuleTab[CCODE_MAX+1] =
176 /************************************************************************
177 * This table is based on Athero driver rules
178 ************************************************************************/
179 /* Country Available channels, ended with 0 */
180 /* 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 */
181 {CCODE_FCC, {'U','S'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
182 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
183 {CCODE_TELEC, {'J','P'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
184 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 23, 0, 0, 23, 0, 23, 23, 0, 23, 0, 0, 23, 23, 23, 0, 23, 0, 23, 0, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
185 {CCODE_ETSI, {'E','U'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
186 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
187 {CCODE_RESV3, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
188 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
189 {CCODE_RESV4, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
190 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
191 {CCODE_RESV5, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
192 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
193 {CCODE_RESV6, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
194 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
195 {CCODE_RESV7, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
196 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
197 {CCODE_RESV8, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
198 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
199 {CCODE_RESV9, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
200 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
201 {CCODE_RESVa, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
202 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
203 {CCODE_RESVb, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
204 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
205 {CCODE_RESVc, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
206 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
207 {CCODE_RESVd, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
208 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
209 {CCODE_RESVe, {' ',' '}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
210 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
211 {CCODE_ALLBAND, {' ',' '}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
212 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
213 {CCODE_ALBANIA, {'A','L'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
214 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
215 {CCODE_ALGERIA, {'D','Z'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
216 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
217 {CCODE_ARGENTINA, {'A','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
218 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 17, 17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 0} },
219 {CCODE_ARMENIA, {'A','M'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
220 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 18, 18, 18, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
221 {CCODE_AUSTRALIA, {'A','U'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
222 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 0, 23, 0, 23, 0, 23, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
223 {CCODE_AUSTRIA, {'A','T'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
224 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 15, 0, 15, 0, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
225 {CCODE_AZERBAIJAN, {'A','Z'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
226 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 18, 18, 18, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
227 {CCODE_BAHRAIN, {'B','H'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
228 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
229 {CCODE_BELARUS, {'B','Y'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
230 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
231 {CCODE_BELGIUM, {'B','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
232 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
233 {CCODE_BELIZE, {'B','Z'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
234 , { 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
235 {CCODE_BOLIVIA, {'B','O'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
236 , { 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
237 {CCODE_BRAZIL, {'B','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
238 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
239 {CCODE_BRUNEI_DARUSSALAM, {'B','N'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
240 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
241 {CCODE_BULGARIA, {'B','G'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
242 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 0, 23, 0, 23, 0, 23, 23, 23, 0, 0, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 0, 0, 0, 0, 0} },
243 {CCODE_CANADA, {'C','A'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
244 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
245 {CCODE_CHILE, {'C','L'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
246 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 17, 17, 17, 17} },
247 {CCODE_CHINA, {'C','N'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
248 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
249 {CCODE_COLOMBIA, {'C','O'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
250 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
251 {CCODE_COSTA_RICA, {'C','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
252 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
253 {CCODE_CROATIA, {'H','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
254 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
255 {CCODE_CYPRUS, {'C','Y'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
256 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
257 {CCODE_CZECH, {'C','Z'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
258 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
259 {CCODE_DENMARK, {'D','K'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
260 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
261 {CCODE_DOMINICAN_REPUBLIC, {'D','O'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
262 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
263 {CCODE_ECUADOR, {'E','C'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
264 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
265 {CCODE_EGYPT, {'E','G'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
266 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
267 {CCODE_EL_SALVADOR, {'S','V'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
268 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
269 {CCODE_ESTONIA, {'E','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
270 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
271 {CCODE_FINLAND, {'F','I'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
272 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
273 {CCODE_FRANCE, {'F','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
274 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
275 {CCODE_GERMANY, {'D','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
276 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
277 {CCODE_GREECE, {'G','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
278 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
279 {CCODE_GEORGIA, {'G','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
280 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 18, 18, 18, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
281 {CCODE_GUATEMALA, {'G','T'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
282 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
283 {CCODE_HONDURAS, {'H','N'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
284 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
285 {CCODE_HONG_KONG, {'H','K'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
286 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 0, 23, 0, 23, 0, 23, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
287 {CCODE_HUNGARY, {'H','U'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
288 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
289 {CCODE_ICELAND, {'I','S'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
290 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
291 {CCODE_INDIA, {'I','N'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
292 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
293 {CCODE_INDONESIA, {'I','D'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
294 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
295 {CCODE_IRAN, {'I','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
296 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
297 {CCODE_IRELAND, {'I','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
298 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
299 {CCODE_ITALY, {'I','T'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
300 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
301 {CCODE_ISRAEL, {'I','L'}, { 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
302 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
303 {CCODE_JAPAN, {'J','P'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
304 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 0, 23, 0, 23, 0, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
305 {CCODE_JORDAN, {'J','O'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
306 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
307 {CCODE_KAZAKHSTAN, {'K','Z'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
308 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
309 {CCODE_KUWAIT, {'K','W'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
310 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
311 {CCODE_LATVIA, {'L','V'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
312 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
313 {CCODE_LEBANON, {'L','B'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
314 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
315 {CCODE_LEICHTENSTEIN, {'L','I'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
316 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
317 {CCODE_LITHUANIA, {'L','T'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
318 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
319 {CCODE_LUXEMBURG, {'L','U'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
320 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
321 {CCODE_MACAU, {'M','O'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
322 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 0, 23, 0, 23, 0, 23, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
323 {CCODE_MACEDONIA, {'M','K'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
324 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
325 {CCODE_MALTA, {'M','T'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
326 , { 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 16, 0, 16, 0, 16, 16, 16, 16, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 16, 16, 16, 0} },
327 {CCODE_MALAYSIA, {'M','Y'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
328 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
329 {CCODE_MEXICO, {'M','X'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
330 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
331 {CCODE_MONACO, {'M','C'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
332 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 18, 18, 18, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
333 {CCODE_MOROCCO, {'M','A'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
334 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
335 {CCODE_NETHERLANDS, {'N','L'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
336 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
337 {CCODE_NEW_ZEALAND, {'N','Z'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
338 , { 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 0, 23, 0, 23, 0, 23, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
339 {CCODE_NORTH_KOREA, {'K','P'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
340 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 23, 23, 23, 0} },
341 {CCODE_NORWAY, {'N','O'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
342 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
343 {CCODE_OMAN, {'O','M'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
344 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
345 {CCODE_PAKISTAN, {'P','K'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
346 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
347 {CCODE_PANAMA, {'P','A'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
348 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
349 {CCODE_PERU, {'P','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
350 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
351 {CCODE_PHILIPPINES, {'P','H'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
352 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
353 {CCODE_POLAND, {'P','L'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
354 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
355 {CCODE_PORTUGAL, {'P','T'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
356 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
357 {CCODE_PUERTO_RICO, {'P','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
358 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
359 {CCODE_QATAR, {'Q','A'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
360 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
361 {CCODE_ROMANIA, {'R','O'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
362 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
363 {CCODE_RUSSIA, {'R','U'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
364 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
365 {CCODE_SAUDI_ARABIA, {'S','A'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
366 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
367 {CCODE_SINGAPORE, {'S','G'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
368 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 20, 20, 20, 20} },
369 {CCODE_SLOVAKIA, {'S','K'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
370 , { 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 16, 0, 16, 0, 16, 16, 16, 16, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 16, 16, 16, 0} },
371 {CCODE_SLOVENIA, {'S','I'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
372 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
373 {CCODE_SOUTH_AFRICA, {'Z','A'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
374 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
375 {CCODE_SOUTH_KOREA, {'K','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
376 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 23, 23, 23, 0} },
377 {CCODE_SPAIN, {'E','S'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
378 , { 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 16, 0, 16, 0, 16, 16, 16, 16, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 16, 16, 16, 0} },
379 {CCODE_SWEDEN, {'S','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
380 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
381 {CCODE_SWITZERLAND, {'C','H'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
382 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
383 {CCODE_SYRIA, {'S','Y'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
384 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
385 {CCODE_TAIWAN, {'T','W'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
386 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 17, 17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 0} },
387 {CCODE_THAILAND, {'T','H'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
388 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 23, 23, 23, 0} },
389 {CCODE_TRINIDAD_TOBAGO, {'T','T'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
390 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 18, 0, 18, 0, 18, 0, 18, 18, 18, 18, 18, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
391 {CCODE_TUNISIA, {'T','N'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
392 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
393 {CCODE_TURKEY, {'T','R'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
394 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
395 {CCODE_UK, {'G','B'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0}
396 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 0, 20, 0, 20, 0, 20, 20, 20, 20, 20, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0} },
397 {CCODE_UKRAINE, {'U','A'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
398 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
399 {CCODE_UNITED_ARAB_EMIRATES, {'A','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
400 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
401 {CCODE_UNITED_STATES, {'U','S'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1}
402 , { 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 17, 0, 17, 0, 17, 23, 23, 23, 23, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 30, 30, 30, 30, 30} },
403 {CCODE_URUGUAY, {'U','Y'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
404 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 23, 23, 23, 0} },
405 {CCODE_UZBEKISTAN, {'U','Z'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
406 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
407 {CCODE_VENEZUELA, {'V','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0}
408 , { 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, 23, 23, 23, 0} },
409 {CCODE_VIETNAM, {'V','N'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
410 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
411 {CCODE_YEMEN, {'Y','E'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
412 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
413 {CCODE_ZIMBABWE, {'Z','W'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
414 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
415 {CCODE_JAPAN_W52_W53, {'J','J'}, { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
416 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} },
417 {CCODE_MAX, {'U','N'}, { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
418 , { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} }
419 /* 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 */
423 /*--------------------- Static Functions --------------------------*/
427 s_vCaculateOFDMRParameter(
429 CARD_PHY_TYPE ePHYType,
435 /*--------------------- Export Variables --------------------------*/
437 /*--------------------- Export Functions --------------------------*/
440 /*--------------------- Export function -------------------------*/
441 /************************************************************************
442 * Country Channel Valid
443 * Input: ChannelIndex is defined as VT3253 MAC channel:
447 * 14 = 2.4G channel 14
448 * 15 = 4.9G channel 183
449 * 16 = 4.9G channel 184
451 * Output: TRUE if the specified 5GHz band is allowed to be used.
453 // 4.9G => Ch 183, 184, 185, 187, 188, 189, 192, 196 (Value:15 ~ 22)
455 // 5G => Ch 7, 8, 9, 11, 12, 16, 34, 36, 38, 40, 42, 44, 46, 48, 52, 56, 60, 64,
456 // 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165 (Value 23 ~ 56)
457 ************************************************************************/
458 //2008-8-4 <add> by chester
460 ChannelValid(UINT ChannelIndex)
466 * If Channel Index is invalid, return invalid
468 if ((ChannelIndex > CB_MAX_CHANNEL) ||
475 bValid = sChannelTbl[ChannelIndex].bValid;
480 } /* end ChannelValid */
484 * Description: Caculate TxRate and RsvTime fields for RSPINF in OFDM mode.
489 * byPktType - Tx Packet type
491 * pbyTxRate - pointer to RSPINF TxRate field
492 * pbyRsvTime - pointer to RSPINF RsvTime field
499 s_vCaculateOFDMRParameter (
501 CARD_PHY_TYPE ePHYType,
508 if (ePHYType == PHY_TYPE_11A) {//5GHZ
519 if (ePHYType == PHY_TYPE_11A) {//5GHZ
530 if (ePHYType == PHY_TYPE_11A) {//5GHZ
541 if (ePHYType == PHY_TYPE_11A) {//5GHZ
552 if (ePHYType == PHY_TYPE_11A) {//5GHZ
563 if (ePHYType == PHY_TYPE_11A) {//5GHZ
574 if (ePHYType == PHY_TYPE_11A) {//5GHZ
586 if (ePHYType == PHY_TYPE_11A) {//5GHZ
601 * Description: Set RSPINF
605 * pDevice - The adapter to be set
609 * Return Value: None.
614 s_vSetRSPINF (PSDevice pDevice, CARD_PHY_TYPE ePHYType, void *pvSupportRateIEs, void *pvExtSupportRateIEs)
616 BYTE byServ = 0, bySignal = 0; // For CCK
618 BYTE byTxRate = 0, byRsvTime = 0; // For OFDM
621 MACvSelectPage1(pDevice->PortOffset);
624 BBvCaculateParameter(pDevice,
626 VNTWIFIbyGetACKTxRate(RATE_1M, pvSupportRateIEs, pvExtSupportRateIEs),
633 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_1, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
635 BBvCaculateParameter(pDevice,
637 VNTWIFIbyGetACKTxRate(RATE_2M, pvSupportRateIEs, pvExtSupportRateIEs),
644 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_2, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
646 BBvCaculateParameter(pDevice,
648 VNTWIFIbyGetACKTxRate(RATE_5M, pvSupportRateIEs, pvExtSupportRateIEs),
655 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_5, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
657 BBvCaculateParameter(pDevice,
659 VNTWIFIbyGetACKTxRate(RATE_11M, pvSupportRateIEs, pvExtSupportRateIEs),
666 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_11, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
668 s_vCaculateOFDMRParameter(RATE_6M,
672 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_6, MAKEWORD(byTxRate,byRsvTime));
674 s_vCaculateOFDMRParameter(RATE_9M,
678 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_9, MAKEWORD(byTxRate,byRsvTime));
680 s_vCaculateOFDMRParameter(RATE_12M,
684 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_12, MAKEWORD(byTxRate,byRsvTime));
686 s_vCaculateOFDMRParameter(RATE_18M,
690 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_18, MAKEWORD(byTxRate,byRsvTime));
692 s_vCaculateOFDMRParameter(RATE_24M,
696 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_24, MAKEWORD(byTxRate,byRsvTime));
698 s_vCaculateOFDMRParameter(
699 VNTWIFIbyGetACKTxRate(RATE_36M, pvSupportRateIEs, pvExtSupportRateIEs),
703 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_36, MAKEWORD(byTxRate,byRsvTime));
705 s_vCaculateOFDMRParameter(
706 VNTWIFIbyGetACKTxRate(RATE_48M, pvSupportRateIEs, pvExtSupportRateIEs),
710 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_48, MAKEWORD(byTxRate,byRsvTime));
712 s_vCaculateOFDMRParameter(
713 VNTWIFIbyGetACKTxRate(RATE_54M, pvSupportRateIEs, pvExtSupportRateIEs),
717 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_54, MAKEWORD(byTxRate,byRsvTime));
719 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_72, MAKEWORD(byTxRate,byRsvTime));
721 MACvSelectPage0(pDevice->PortOffset);
727 /*--------------------- Export Variables --------------------------*/
729 /*--------------------- Export Functions --------------------------*/
730 BYTE CARDbyGetChannelMapping (void *pDeviceHandler, BYTE byChannelNumber, CARD_PHY_TYPE ePhyType)
734 if ((ePhyType == PHY_TYPE_11B) || (ePhyType == PHY_TYPE_11G)) {
735 return (byChannelNumber);
738 for(ii = (CB_MAX_CHANNEL_24G + 1); ii <= CB_MAX_CHANNEL; ) {
739 if (sChannelTbl[ii].byChannelNumber == byChannelNumber) {
748 BYTE CARDbyGetChannelNumber (void *pDeviceHandler, BYTE byChannelIndex)
750 // PSDevice pDevice = (PSDevice) pDeviceHandler;
751 return(sChannelTbl[byChannelIndex].byChannelNumber);
755 * Description: Set NIC media channel
759 * pDeviceHandler - The adapter to be set
760 * uConnectionChannel - Channel to be set
764 * Return Value: TRUE if succeeded; FALSE if failed.
767 BOOL CARDbSetChannel (void *pDeviceHandler, UINT uConnectionChannel)
769 PSDevice pDevice = (PSDevice) pDeviceHandler;
773 if (pDevice->byCurrentCh == uConnectionChannel) {
777 if (sChannelTbl[uConnectionChannel].bValid == FALSE) {
781 if ((uConnectionChannel > CB_MAX_CHANNEL_24G) &&
782 (pDevice->eCurrentPHYType != PHY_TYPE_11A)) {
783 CARDbSetPhyParameter(pDevice, PHY_TYPE_11A, 0, 0, NULL, NULL);
784 } else if ((uConnectionChannel <= CB_MAX_CHANNEL_24G) &&
785 (pDevice->eCurrentPHYType == PHY_TYPE_11A)) {
786 CARDbSetPhyParameter(pDevice, PHY_TYPE_11G, 0, 0, NULL, NULL);
789 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_MACCR, MACCR_CLRNAV);
791 //{{ RobertYu: 20041202
792 //// TX_PE will reserve 3 us for MAX2829 A mode only, it is for better TX throughput
794 if ( pDevice->byRFType == RF_AIROHA7230 )
796 RFbAL7230SelectChannelPostProcess(pDevice->PortOffset, pDevice->byCurrentCh, (BYTE)uConnectionChannel);
801 pDevice->byCurrentCh = (BYTE)uConnectionChannel;
802 bResult &= RFbSelectChannel(pDevice->PortOffset, pDevice->byRFType, (BYTE)uConnectionChannel);
804 // Init Synthesizer Table
805 if (pDevice->bEnablePSMode == TRUE)
806 RFvWriteWakeProgSyn(pDevice->PortOffset, pDevice->byRFType, uConnectionChannel);
809 //DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"CARDbSetMediaChannel: %d\n", (BYTE)uConnectionChannel);
810 BBvSoftwareReset(pDevice->PortOffset);
812 if (pDevice->byLocalID > REV_ID_VT3253_B1) {
813 // set HW default power register
814 MACvSelectPage1(pDevice->PortOffset);
815 RFbSetPower(pDevice, RATE_1M, pDevice->byCurrentCh);
816 VNSvOutPortB(pDevice->PortOffset + MAC_REG_PWRCCK, pDevice->byCurPwr);
817 RFbSetPower(pDevice, RATE_6M, pDevice->byCurrentCh);
818 VNSvOutPortB(pDevice->PortOffset + MAC_REG_PWROFDM, pDevice->byCurPwr);
819 MACvSelectPage0(pDevice->PortOffset);
822 if (pDevice->eCurrentPHYType == PHY_TYPE_11B) {
824 //printk("Func:CARDbSetChannel:call RFbSetPower:11B\n");
826 RFbSetPower(pDevice, RATE_1M, pDevice->byCurrentCh);
829 //printk("Func:CARDbSetChannel:call RFbSetPower\n");
831 RFbSetPower(pDevice, RATE_6M, pDevice->byCurrentCh);
840 * Description: Card Send packet function
844 * pDeviceHandler - The adapter to be set
845 * pPacket - Packet buffer pointer
846 * ePktType - Packet type
847 * uLength - Packet length
851 * Return Value: TRUE if succeeded; FALSE if failed.
855 BOOL CARDbSendPacket (void *pDeviceHandler, void *pPacket, CARD_PKT_TYPE ePktType, UINT uLength)
857 PSDevice pDevice = (PSDevice) pDeviceHandler;
858 if (ePktType == PKT_TYPE_802_11_MNG) {
859 return TXbTD0Send(pDevice, pPacket, uLength);
860 } else if (ePktType == PKT_TYPE_802_11_BCN) {
861 return TXbBeaconSend(pDevice, pPacket, uLength);
862 } if (ePktType == PKT_TYPE_802_11_DATA) {
863 return TXbTD1Send(pDevice, pPacket, uLength);
872 * Description: Get Card short preamble option value
876 * pDevice - The adapter to be set
880 * Return Value: TRUE if short preamble; otherwise FALSE
883 BOOL CARDbIsShortPreamble (void *pDeviceHandler)
885 PSDevice pDevice = (PSDevice) pDeviceHandler;
886 if (pDevice->byPreambleType == 0) {
893 * Description: Get Card short slot time option value
897 * pDevice - The adapter to be set
901 * Return Value: TRUE if short slot time; otherwise FALSE
904 BOOL CARDbIsShorSlotTime (void *pDeviceHandler)
906 PSDevice pDevice = (PSDevice) pDeviceHandler;
907 return(pDevice->bShortSlotTime);
912 * Description: Update IFS
916 * pDevice - The adapter to be set
920 * Return Value: None.
923 BOOL CARDbSetPhyParameter (void *pDeviceHandler, CARD_PHY_TYPE ePHYType, WORD wCapInfo, BYTE byERPField, void *pvSupportRateIEs, void *pvExtSupportRateIEs)
925 PSDevice pDevice = (PSDevice) pDeviceHandler;
931 // PWLAN_IE_SUPP_RATES pRates = NULL;
932 PWLAN_IE_SUPP_RATES pSupportRates = (PWLAN_IE_SUPP_RATES) pvSupportRateIEs;
933 PWLAN_IE_SUPP_RATES pExtSupportRates = (PWLAN_IE_SUPP_RATES) pvExtSupportRateIEs;
936 //Set SIFS, DIFS, EIFS, SlotTime, CwMin
937 if (ePHYType == PHY_TYPE_11A) {
938 if (pSupportRates == NULL) {
939 pSupportRates = (PWLAN_IE_SUPP_RATES) abyDefaultSuppRatesA;
941 if (pDevice->byRFType == RF_AIROHA7230) {
942 // AL7230 use single PAPE and connect to PAPE_2.4G
943 MACvSetBBType(pDevice->PortOffset, BB_TYPE_11G);
944 pDevice->abyBBVGA[0] = 0x20;
945 pDevice->abyBBVGA[2] = 0x10;
946 pDevice->abyBBVGA[3] = 0x10;
947 BBbReadEmbeded(pDevice->PortOffset, 0xE7, &byData);
948 if (byData == 0x1C) {
949 BBbWriteEmbeded(pDevice->PortOffset, 0xE7, pDevice->abyBBVGA[0]);
951 } else if (pDevice->byRFType == RF_UW2452) {
952 MACvSetBBType(pDevice->PortOffset, BB_TYPE_11A);
953 pDevice->abyBBVGA[0] = 0x18;
954 BBbReadEmbeded(pDevice->PortOffset, 0xE7, &byData);
955 if (byData == 0x14) {
956 BBbWriteEmbeded(pDevice->PortOffset, 0xE7, pDevice->abyBBVGA[0]);
957 BBbWriteEmbeded(pDevice->PortOffset, 0xE1, 0x57);
960 MACvSetBBType(pDevice->PortOffset, BB_TYPE_11A);
962 BBbWriteEmbeded(pDevice->PortOffset, 0x88, 0x03);
963 bySlot = C_SLOT_SHORT;
965 byDIFS = C_SIFS_A + 2*C_SLOT_SHORT;
967 } else if (ePHYType == PHY_TYPE_11B) {
968 if (pSupportRates == NULL) {
969 pSupportRates = (PWLAN_IE_SUPP_RATES) abyDefaultSuppRatesB;
971 MACvSetBBType(pDevice->PortOffset, BB_TYPE_11B);
972 if (pDevice->byRFType == RF_AIROHA7230) {
973 pDevice->abyBBVGA[0] = 0x1C;
974 pDevice->abyBBVGA[2] = 0x00;
975 pDevice->abyBBVGA[3] = 0x00;
976 BBbReadEmbeded(pDevice->PortOffset, 0xE7, &byData);
977 if (byData == 0x20) {
978 BBbWriteEmbeded(pDevice->PortOffset, 0xE7, pDevice->abyBBVGA[0]);
980 } else if (pDevice->byRFType == RF_UW2452) {
981 pDevice->abyBBVGA[0] = 0x14;
982 BBbReadEmbeded(pDevice->PortOffset, 0xE7, &byData);
983 if (byData == 0x18) {
984 BBbWriteEmbeded(pDevice->PortOffset, 0xE7, pDevice->abyBBVGA[0]);
985 BBbWriteEmbeded(pDevice->PortOffset, 0xE1, 0xD3);
988 BBbWriteEmbeded(pDevice->PortOffset, 0x88, 0x02);
989 bySlot = C_SLOT_LONG;
991 byDIFS = C_SIFS_BG + 2*C_SLOT_LONG;
993 } else {// PK_TYPE_11GA & PK_TYPE_11GB
994 if (pSupportRates == NULL) {
995 pSupportRates = (PWLAN_IE_SUPP_RATES) abyDefaultSuppRatesG;
996 pExtSupportRates = (PWLAN_IE_SUPP_RATES) abyDefaultExtSuppRatesG;
998 MACvSetBBType(pDevice->PortOffset, BB_TYPE_11G);
999 if (pDevice->byRFType == RF_AIROHA7230) {
1000 pDevice->abyBBVGA[0] = 0x1C;
1001 pDevice->abyBBVGA[2] = 0x00;
1002 pDevice->abyBBVGA[3] = 0x00;
1003 BBbReadEmbeded(pDevice->PortOffset, 0xE7, &byData);
1004 if (byData == 0x20) {
1005 BBbWriteEmbeded(pDevice->PortOffset, 0xE7, pDevice->abyBBVGA[0]);
1007 } else if (pDevice->byRFType == RF_UW2452) {
1008 pDevice->abyBBVGA[0] = 0x14;
1009 BBbReadEmbeded(pDevice->PortOffset, 0xE7, &byData);
1010 if (byData == 0x18) {
1011 BBbWriteEmbeded(pDevice->PortOffset, 0xE7, pDevice->abyBBVGA[0]);
1012 BBbWriteEmbeded(pDevice->PortOffset, 0xE1, 0xD3);
1015 BBbWriteEmbeded(pDevice->PortOffset, 0x88, 0x08);
1017 if(VNTWIFIbIsShortSlotTime(wCapInfo)) {
1018 bySlot = C_SLOT_SHORT;
1019 byDIFS = C_SIFS_BG + 2*C_SLOT_SHORT;
1021 bySlot = C_SLOT_LONG;
1022 byDIFS = C_SIFS_BG + 2*C_SLOT_LONG;
1024 if (VNTWIFIbyGetMaxSupportRate(pSupportRates, pExtSupportRates) > RATE_11M) {
1029 if (pDevice->bProtectMode != VNTWIFIbIsProtectMode(byERPField)) {
1030 pDevice->bProtectMode = VNTWIFIbIsProtectMode(byERPField);
1031 if (pDevice->bProtectMode) {
1032 MACvEnableProtectMD(pDevice->PortOffset);
1034 MACvDisableProtectMD(pDevice->PortOffset);
1037 if (pDevice->bBarkerPreambleMd != VNTWIFIbIsBarkerMode(byERPField)) {
1038 pDevice->bBarkerPreambleMd = VNTWIFIbIsBarkerMode(byERPField);
1039 if (pDevice->bBarkerPreambleMd) {
1040 MACvEnableBarkerPreambleMd(pDevice->PortOffset);
1042 MACvDisableBarkerPreambleMd(pDevice->PortOffset);
1047 if (pDevice->byRFType == RF_RFMD2959) {
1048 // bcs TX_PE will reserve 3 us
1049 // hardware's processing time here is 2 us.
1052 //{{ RobertYu: 20041202
1053 //// TX_PE will reserve 3 us for MAX2829 A mode only, it is for better TX throughput
1054 //// MAC will need 2 us to process, so the SIFS, DIFS can be shorter by 2 us.
1057 if (pDevice->bySIFS != bySIFS) {
1058 pDevice->bySIFS = bySIFS;
1059 VNSvOutPortB(pDevice->PortOffset + MAC_REG_SIFS, pDevice->bySIFS);
1061 if (pDevice->byDIFS != byDIFS) {
1062 pDevice->byDIFS = byDIFS;
1063 VNSvOutPortB(pDevice->PortOffset + MAC_REG_DIFS, pDevice->byDIFS);
1065 if (pDevice->byEIFS != C_EIFS) {
1066 pDevice->byEIFS = C_EIFS;
1067 VNSvOutPortB(pDevice->PortOffset + MAC_REG_EIFS, pDevice->byEIFS);
1069 if (pDevice->bySlot != bySlot) {
1070 pDevice->bySlot = bySlot;
1071 VNSvOutPortB(pDevice->PortOffset + MAC_REG_SLOT, pDevice->bySlot);
1072 if (pDevice->bySlot == C_SLOT_SHORT) {
1073 pDevice->bShortSlotTime = TRUE;
1075 pDevice->bShortSlotTime = FALSE;
1077 BBvSetShortSlotTime(pDevice);
1079 if (pDevice->byCWMaxMin != byCWMaxMin) {
1080 pDevice->byCWMaxMin = byCWMaxMin;
1081 VNSvOutPortB(pDevice->PortOffset + MAC_REG_CWMAXMIN0, pDevice->byCWMaxMin);
1083 if (VNTWIFIbIsShortPreamble(wCapInfo)) {
1084 pDevice->byPreambleType = pDevice->byShortPreamble;
1086 pDevice->byPreambleType = 0;
1088 s_vSetRSPINF(pDevice, ePHYType, pSupportRates, pExtSupportRates);
1089 pDevice->eCurrentPHYType = ePHYType;
1090 // set for NDIS OID_802_11SUPPORTED_RATES
1095 * Description: Sync. TSF counter to BSS
1096 * Get TSF offset and write to HW
1100 * pDevice - The adapter to be sync.
1101 * byRxRate - data rate of receive beacon
1102 * qwBSSTimestamp - Rx BCN's TSF
1103 * qwLocalTSF - Local TSF
1107 * Return Value: none
1110 BOOL CARDbUpdateTSF (void *pDeviceHandler, BYTE byRxRate, QWORD qwBSSTimestamp, QWORD qwLocalTSF)
1112 PSDevice pDevice = (PSDevice) pDeviceHandler;
1115 HIDWORD(qwTSFOffset) = 0;
1116 LODWORD(qwTSFOffset) = 0;
1118 if ((HIDWORD(qwBSSTimestamp) != HIDWORD(qwLocalTSF)) ||
1119 (LODWORD(qwBSSTimestamp) != LODWORD(qwLocalTSF))) {
1120 qwTSFOffset = CARDqGetTSFOffset(byRxRate, qwBSSTimestamp, qwLocalTSF);
1122 // HW's TSF add TSF Offset reg
1123 VNSvOutPortD(pDevice->PortOffset + MAC_REG_TSFOFST, LODWORD(qwTSFOffset));
1124 VNSvOutPortD(pDevice->PortOffset + MAC_REG_TSFOFST + 4, HIDWORD(qwTSFOffset));
1125 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_TFTCTL, TFTCTL_TSFSYNCEN);
1132 * Description: Set NIC TSF counter for first Beacon time
1133 * Get NEXTTBTT from adjusted TSF and Beacon Interval
1137 * pDevice - The adapter to be set.
1138 * wBeaconInterval - Beacon Interval
1142 * Return Value: TRUE if succeed; otherwise FALSE
1145 BOOL CARDbSetBeaconPeriod (void *pDeviceHandler, WORD wBeaconInterval)
1147 PSDevice pDevice = (PSDevice) pDeviceHandler;
1148 UINT uBeaconInterval = 0;
1149 UINT uLowNextTBTT = 0;
1150 UINT uHighRemain = 0;
1151 UINT uLowRemain = 0;
1154 HIDWORD(qwNextTBTT) = 0;
1155 LODWORD(qwNextTBTT) = 0;
1156 CARDbGetCurrentTSF(pDevice->PortOffset, &qwNextTBTT); //Get Local TSF counter
1157 uBeaconInterval = wBeaconInterval * 1024;
1158 // Next TBTT = ((local_current_TSF / beacon_interval) + 1 ) * beacon_interval
1159 uLowNextTBTT = (LODWORD(qwNextTBTT) >> 10) << 10;
1160 uLowRemain = (uLowNextTBTT) % uBeaconInterval;
1161 // high dword (mod) bcn
1162 uHighRemain = (((0xffffffff % uBeaconInterval) + 1) * HIDWORD(qwNextTBTT))
1164 uLowRemain = (uHighRemain + uLowRemain) % uBeaconInterval;
1165 uLowRemain = uBeaconInterval - uLowRemain;
1167 // check if carry when add one beacon interval
1168 if ((~uLowNextTBTT) < uLowRemain) {
1169 HIDWORD(qwNextTBTT) ++ ;
1171 LODWORD(qwNextTBTT) = uLowNextTBTT + uLowRemain;
1173 // set HW beacon interval
1174 VNSvOutPortW(pDevice->PortOffset + MAC_REG_BI, wBeaconInterval);
1175 pDevice->wBeaconInterval = wBeaconInterval;
1177 VNSvOutPortD(pDevice->PortOffset + MAC_REG_NEXTTBTT, LODWORD(qwNextTBTT));
1178 VNSvOutPortD(pDevice->PortOffset + MAC_REG_NEXTTBTT + 4, HIDWORD(qwNextTBTT));
1179 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_TFTCTL, TFTCTL_TBTTSYNCEN);
1187 * Description: Card Stop Hardware Tx
1191 * pDeviceHandler - The adapter to be set
1192 * ePktType - Packet type to stop
1196 * Return Value: TRUE if all data packet complete; otherwise FALSE.
1199 BOOL CARDbStopTxPacket (void *pDeviceHandler, CARD_PKT_TYPE ePktType)
1201 PSDevice pDevice = (PSDevice) pDeviceHandler;
1204 if (ePktType == PKT_TYPE_802_11_ALL) {
1205 pDevice->bStopBeacon = TRUE;
1206 pDevice->bStopTx0Pkt = TRUE;
1207 pDevice->bStopDataPkt = TRUE;
1208 } else if (ePktType == PKT_TYPE_802_11_BCN) {
1209 pDevice->bStopBeacon = TRUE;
1210 } else if (ePktType == PKT_TYPE_802_11_MNG) {
1211 pDevice->bStopTx0Pkt = TRUE;
1212 } else if (ePktType == PKT_TYPE_802_11_DATA) {
1213 pDevice->bStopDataPkt = TRUE;
1216 if (pDevice->bStopBeacon == TRUE) {
1217 if (pDevice->bIsBeaconBufReadySet == TRUE) {
1218 if (pDevice->cbBeaconBufReadySetCnt < WAIT_BEACON_TX_DOWN_TMO) {
1219 pDevice->cbBeaconBufReadySetCnt ++;
1223 pDevice->bIsBeaconBufReadySet = FALSE;
1224 pDevice->cbBeaconBufReadySetCnt = 0;
1225 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_TCR, TCR_AUTOBCNTX);
1227 // wait all TD0 complete
1228 if (pDevice->bStopTx0Pkt == TRUE) {
1229 if (pDevice->iTDUsed[TYPE_TXDMA0] != 0){
1233 // wait all Data TD complete
1234 if (pDevice->bStopDataPkt == TRUE) {
1235 if (pDevice->iTDUsed[TYPE_AC0DMA] != 0){
1245 * Description: Card Start Hardware Tx
1249 * pDeviceHandler - The adapter to be set
1250 * ePktType - Packet type to start
1254 * Return Value: TRUE if success; FALSE if failed.
1257 BOOL CARDbStartTxPacket (void *pDeviceHandler, CARD_PKT_TYPE ePktType)
1259 PSDevice pDevice = (PSDevice) pDeviceHandler;
1262 if (ePktType == PKT_TYPE_802_11_ALL) {
1263 pDevice->bStopBeacon = FALSE;
1264 pDevice->bStopTx0Pkt = FALSE;
1265 pDevice->bStopDataPkt = FALSE;
1266 } else if (ePktType == PKT_TYPE_802_11_BCN) {
1267 pDevice->bStopBeacon = FALSE;
1268 } else if (ePktType == PKT_TYPE_802_11_MNG) {
1269 pDevice->bStopTx0Pkt = FALSE;
1270 } else if (ePktType == PKT_TYPE_802_11_DATA) {
1271 pDevice->bStopDataPkt = FALSE;
1274 if ((pDevice->bStopBeacon == FALSE) &&
1275 (pDevice->bBeaconBufReady == TRUE) &&
1276 (pDevice->eOPMode == OP_MODE_ADHOC)) {
1277 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_TCR, TCR_AUTOBCNTX);
1286 * Description: Card Set BSSID value
1290 * pDeviceHandler - The adapter to be set
1291 * pbyBSSID - pointer to BSSID field
1292 * bAdhoc - flag to indicate IBSS
1296 * Return Value: TRUE if success; FALSE if failed.
1299 BOOL CARDbSetBSSID(void *pDeviceHandler, PBYTE pbyBSSID, CARD_OP_MODE eOPMode)
1301 PSDevice pDevice = (PSDevice) pDeviceHandler;
1303 MACvWriteBSSIDAddress(pDevice->PortOffset, pbyBSSID);
1304 memcpy(pDevice->abyBSSID, pbyBSSID, WLAN_BSSID_LEN);
1305 if (eOPMode == OP_MODE_ADHOC) {
1306 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_HOSTCR, HOSTCR_ADHOC);
1308 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_HOSTCR, HOSTCR_ADHOC);
1310 if (eOPMode == OP_MODE_AP) {
1311 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_HOSTCR, HOSTCR_AP);
1313 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_HOSTCR, HOSTCR_AP);
1315 if (eOPMode == OP_MODE_UNKNOWN) {
1316 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_RCR, RCR_BSSID);
1317 pDevice->bBSSIDFilter = FALSE;
1318 pDevice->byRxMode &= ~RCR_BSSID;
1319 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "wcmd: rx_mode = %x\n", pDevice->byRxMode );
1321 if (is_zero_ether_addr(pDevice->abyBSSID) == FALSE) {
1322 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_RCR, RCR_BSSID);
1323 pDevice->bBSSIDFilter = TRUE;
1324 pDevice->byRxMode |= RCR_BSSID;
1326 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "wmgr: rx_mode = %x\n", pDevice->byRxMode );
1328 // Adopt BSS state in Adapter Device Object
1329 pDevice->eOPMode = eOPMode;
1335 * Description: Card indicate status
1339 * pDeviceHandler - The adapter to be set
1344 * Return Value: TRUE if success; FALSE if failed.
1352 * Description: Save Assoc info. contain in assoc. response frame
1356 * pDevice - The adapter to be set
1357 * wCapabilityInfo - Capability information
1358 * wStatus - Status code
1360 * uLen - Length of IEs
1361 * pbyIEs - pointer to IEs
1365 * Return Value: TRUE if succeed; otherwise FALSE
1368 BOOL CARDbSetTxDataRate(
1369 void *pDeviceHandler,
1373 PSDevice pDevice = (PSDevice) pDeviceHandler;
1375 pDevice->wCurrentRate = wDataRate;
1381 * Routine Description:
1382 * Consider to power down when no more packets to tx or rx.
1386 * pDevice - The adapter to be set
1390 * Return Value: TRUE if power down success; otherwise FALSE
1395 void *pDeviceHandler
1398 PSDevice pDevice = (PSDevice)pDeviceHandler;
1401 // check if already in Doze mode
1402 if (MACbIsRegBitsOn(pDevice->PortOffset, MAC_REG_PSCTL, PSCTL_PS))
1406 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_PSCTL, PSCTL_PSEN);
1408 // check if all TD are empty,
1410 for (uIdx = 0; uIdx < TYPE_MAXTD; uIdx ++) {
1411 if (pDevice->iTDUsed[uIdx] != 0)
1415 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_PSCTL, PSCTL_GO2DOZE);
1416 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Go to Doze ZZZZZZZZZZZZZZZ\n");
1421 * Description: Turn off Radio power
1425 * pDevice - The adapter to be turned off
1429 * Return Value: TRUE if success; otherwise FALSE
1432 BOOL CARDbRadioPowerOff (void *pDeviceHandler)
1434 PSDevice pDevice = (PSDevice) pDeviceHandler;
1435 BOOL bResult = TRUE;
1437 if (pDevice->bRadioOff == TRUE)
1441 switch (pDevice->byRFType) {
1444 MACvWordRegBitsOff(pDevice->PortOffset, MAC_REG_SOFTPWRCTL, SOFTPWRCTL_TXPEINV);
1445 MACvWordRegBitsOn(pDevice->PortOffset, MAC_REG_SOFTPWRCTL, SOFTPWRCTL_SWPE1);
1450 case RF_AIROHA7230: //RobertYu:20050104
1451 MACvWordRegBitsOff(pDevice->PortOffset, MAC_REG_SOFTPWRCTL, SOFTPWRCTL_SWPE2);
1452 MACvWordRegBitsOff(pDevice->PortOffset, MAC_REG_SOFTPWRCTL, SOFTPWRCTL_SWPE3);
1457 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_HOSTCR, HOSTCR_RXON);
1459 BBvSetDeepSleep(pDevice->PortOffset, pDevice->byLocalID);
1461 pDevice->bRadioOff = TRUE;
1462 //2007-0409-03,<Add> by chester
1463 printk("chester power off\n");
1464 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_GPIOCTL0, LED_ACTSET); //LED issue
1470 * Description: Turn on Radio power
1474 * pDevice - The adapter to be turned on
1478 * Return Value: TRUE if success; otherwise FALSE
1481 BOOL CARDbRadioPowerOn (void *pDeviceHandler)
1483 PSDevice pDevice = (PSDevice) pDeviceHandler;
1484 BOOL bResult = TRUE;
1485 printk("chester power on\n");
1486 if (pDevice->bRadioControlOff == TRUE){
1487 if (pDevice->bHWRadioOff == TRUE) printk("chester bHWRadioOff\n");
1488 if (pDevice->bRadioControlOff == TRUE) printk("chester bRadioControlOff\n");
1491 if (pDevice->bRadioOff == FALSE)
1493 printk("chester pbRadioOff\n");
1496 BBvExitDeepSleep(pDevice->PortOffset, pDevice->byLocalID);
1498 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_HOSTCR, HOSTCR_RXON);
1500 switch (pDevice->byRFType) {
1503 MACvWordRegBitsOn(pDevice->PortOffset, MAC_REG_SOFTPWRCTL, SOFTPWRCTL_TXPEINV);
1504 MACvWordRegBitsOff(pDevice->PortOffset, MAC_REG_SOFTPWRCTL, SOFTPWRCTL_SWPE1);
1509 case RF_AIROHA7230: //RobertYu:20050104
1510 MACvWordRegBitsOn(pDevice->PortOffset, MAC_REG_SOFTPWRCTL, (SOFTPWRCTL_SWPE2 |
1516 pDevice->bRadioOff = FALSE;
1517 // 2007-0409-03,<Add> by chester
1518 printk("chester power on\n");
1519 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_GPIOCTL0, LED_ACTSET); //LED issue
1525 BOOL CARDbRemoveKey (void *pDeviceHandler, PBYTE pbyBSSID)
1527 PSDevice pDevice = (PSDevice) pDeviceHandler;
1529 KeybRemoveAllKey(&(pDevice->sKey), pbyBSSID, pDevice->PortOffset);
1537 * Add BSSID in PMKID Candidate list.
1541 * hDeviceContext - device structure point
1542 * pbyBSSID - BSSID address for adding
1543 * wRSNCap - BSS's RSN capability
1547 * Return Value: none.
1551 CARDbAdd_PMKID_Candidate (
1552 void *pDeviceHandler,
1558 PSDevice pDevice = (PSDevice) pDeviceHandler;
1559 PPMKID_CANDIDATE pCandidateList;
1562 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"bAdd_PMKID_Candidate START: (%d)\n", (int)pDevice->gsPMKIDCandidate.NumCandidates);
1564 if (pDevice->gsPMKIDCandidate.NumCandidates >= MAX_PMKIDLIST) {
1565 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"vFlush_PMKID_Candidate: 3\n");
1566 memset(&pDevice->gsPMKIDCandidate, 0, sizeof(SPMKIDCandidateEvent));
1569 for (ii = 0; ii < 6; ii++) {
1570 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"%02X ", *(pbyBSSID + ii));
1572 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"\n");
1575 // Update Old Candidate
1576 for (ii = 0; ii < pDevice->gsPMKIDCandidate.NumCandidates; ii++) {
1577 pCandidateList = &pDevice->gsPMKIDCandidate.CandidateList[ii];
1578 if ( !memcmp(pCandidateList->BSSID, pbyBSSID, ETH_ALEN)) {
1579 if ((bRSNCapExist == TRUE) && (wRSNCap & BIT0)) {
1580 pCandidateList->Flags |= NDIS_802_11_PMKID_CANDIDATE_PREAUTH_ENABLED;
1582 pCandidateList->Flags &= ~(NDIS_802_11_PMKID_CANDIDATE_PREAUTH_ENABLED);
1589 pCandidateList = &pDevice->gsPMKIDCandidate.CandidateList[pDevice->gsPMKIDCandidate.NumCandidates];
1590 if ((bRSNCapExist == TRUE) && (wRSNCap & BIT0)) {
1591 pCandidateList->Flags |= NDIS_802_11_PMKID_CANDIDATE_PREAUTH_ENABLED;
1593 pCandidateList->Flags &= ~(NDIS_802_11_PMKID_CANDIDATE_PREAUTH_ENABLED);
1595 memcpy(pCandidateList->BSSID, pbyBSSID, ETH_ALEN);
1596 pDevice->gsPMKIDCandidate.NumCandidates++;
1597 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"NumCandidates:%d\n", (int)pDevice->gsPMKIDCandidate.NumCandidates);
1602 CARDpGetCurrentAddress (
1603 void *pDeviceHandler
1606 PSDevice pDevice = (PSDevice) pDeviceHandler;
1608 return (pDevice->abyCurrentNetAddr);
1613 void CARDvInitChannelTable (void *pDeviceHandler)
1615 PSDevice pDevice = (PSDevice) pDeviceHandler;
1616 BOOL bMultiBand = FALSE;
1619 for(ii=1;ii<=CARD_MAX_CHANNEL_TBL;ii++) {
1620 sChannelTbl[ii].bValid = FALSE;
1623 switch (pDevice->byRFType) {
1629 // printk("chester-false\n");
1632 case RF_AIROHA7230 :
1640 if ((pDevice->dwDiagRefCount != 0) ||
1641 (pDevice->b11hEnable == TRUE)) {
1642 if (bMultiBand == TRUE) {
1643 for(ii=0;ii<CARD_MAX_CHANNEL_TBL;ii++) {
1644 sChannelTbl[ii+1].bValid = TRUE;
1645 pDevice->abyRegPwr[ii+1] = pDevice->abyOFDMDefaultPwr[ii+1];
1646 pDevice->abyLocalPwr[ii+1] = pDevice->abyOFDMDefaultPwr[ii+1];
1648 for(ii=0;ii<CHANNEL_MAX_24G;ii++) {
1649 pDevice->abyRegPwr[ii+1] = pDevice->abyCCKDefaultPwr[ii+1];
1650 pDevice->abyLocalPwr[ii+1] = pDevice->abyCCKDefaultPwr[ii+1];
1653 for(ii=0;ii<CHANNEL_MAX_24G;ii++) {
1654 //2008-8-4 <add> by chester
1655 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] != 0) {
1656 sChannelTbl[ii+1].bValid = TRUE;
1657 pDevice->abyRegPwr[ii+1] = pDevice->abyCCKDefaultPwr[ii+1];
1658 pDevice->abyLocalPwr[ii+1] = pDevice->abyCCKDefaultPwr[ii+1];
1662 } else if (pDevice->byZoneType <= CCODE_MAX) {
1663 if (bMultiBand == TRUE) {
1664 for(ii=0;ii<CARD_MAX_CHANNEL_TBL;ii++) {
1665 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] != 0) {
1666 sChannelTbl[ii+1].bValid = TRUE;
1667 pDevice->abyRegPwr[ii+1] = ChannelRuleTab[pDevice->byZoneType].byPower[ii];
1668 pDevice->abyLocalPwr[ii+1] = ChannelRuleTab[pDevice->byZoneType].byPower[ii];
1672 for(ii=0;ii<CHANNEL_MAX_24G;ii++) {
1673 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] != 0) {
1674 sChannelTbl[ii+1].bValid = TRUE;
1675 pDevice->abyRegPwr[ii+1] = ChannelRuleTab[pDevice->byZoneType].byPower[ii];
1676 pDevice->abyLocalPwr[ii+1] = ChannelRuleTab[pDevice->byZoneType].byPower[ii];
1681 DBG_PRT(MSG_LEVEL_NOTICE, KERN_INFO"Zone=[%d][%c][%c]!!\n",pDevice->byZoneType,ChannelRuleTab[pDevice->byZoneType].chCountryCode[0],ChannelRuleTab[pDevice->byZoneType].chCountryCode[1]);
1682 for(ii=0;ii<CARD_MAX_CHANNEL_TBL;ii++) {
1683 if (pDevice->abyRegPwr[ii+1] == 0) {
1684 pDevice->abyRegPwr[ii+1] = pDevice->abyOFDMDefaultPwr[ii+1];
1686 if (pDevice->abyLocalPwr[ii+1] == 0) {
1687 pDevice->abyLocalPwr[ii+1] = pDevice->abyOFDMDefaultPwr[ii+1];
1697 * Start Spectrum Measure defined in 802.11h
1701 * hDeviceContext - device structure point
1705 * Return Value: none.
1710 void *pDeviceHandler,
1711 void *pvMeasureEIDs,
1712 UINT uNumOfMeasureEIDs
1715 PSDevice pDevice = (PSDevice) pDeviceHandler;
1716 PWLAN_IE_MEASURE_REQ pEID = (PWLAN_IE_MEASURE_REQ) pvMeasureEIDs;
1719 BOOL bExpired = TRUE;
1722 if ((pEID == NULL) ||
1723 (uNumOfMeasureEIDs == 0)) {
1726 CARDbGetCurrentTSF(pDevice->PortOffset, &qwCurrTSF);
1727 if (pDevice->bMeasureInProgress == TRUE) {
1728 pDevice->bMeasureInProgress = FALSE;
1729 VNSvOutPortB(pDevice->PortOffset + MAC_REG_RCR, pDevice->byOrgRCR);
1730 MACvSelectPage1(pDevice->PortOffset);
1731 VNSvOutPortD(pDevice->PortOffset + MAC_REG_MAR0, pDevice->dwOrgMAR0);
1732 VNSvOutPortD(pDevice->PortOffset + MAC_REG_MAR4, pDevice->dwOrgMAR4);
1733 // clear measure control
1734 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_MSRCTL, MSRCTL_EN);
1735 MACvSelectPage0(pDevice->PortOffset);
1736 CARDbSetChannel(pDevice, pDevice->byOrgChannel);
1737 MACvSelectPage1(pDevice->PortOffset);
1738 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_MSRCTL+1, MSRCTL1_TXPAUSE);
1739 MACvSelectPage0(pDevice->PortOffset);
1741 pDevice->uNumOfMeasureEIDs = uNumOfMeasureEIDs;
1744 pDevice->pCurrMeasureEID = pEID;
1746 pDevice->uNumOfMeasureEIDs--;
1748 if (pDevice->byLocalID > REV_ID_VT3253_B1) {
1749 HIDWORD(qwStartTSF) = HIDWORD(*((PQWORD) (pDevice->pCurrMeasureEID->sReq.abyStartTime)));
1750 LODWORD(qwStartTSF) = LODWORD(*((PQWORD) (pDevice->pCurrMeasureEID->sReq.abyStartTime)));
1751 wDuration = *((PWORD) (pDevice->pCurrMeasureEID->sReq.abyDuration));
1752 wDuration += 1; // 1 TU for channel switching
1754 if ((LODWORD(qwStartTSF) == 0) && (HIDWORD(qwStartTSF) == 0)) {
1755 // start imediately by setting start TSF == current TSF + 2 TU
1756 LODWORD(qwStartTSF) = LODWORD(qwCurrTSF) + 2048;
1757 HIDWORD(qwStartTSF) = HIDWORD(qwCurrTSF);
1758 if (LODWORD(qwCurrTSF) > LODWORD(qwStartTSF)) {
1759 HIDWORD(qwStartTSF)++;
1764 // start at setting start TSF - 1TU(for channel switching)
1765 if (LODWORD(qwStartTSF) < 1024) {
1766 HIDWORD(qwStartTSF)--;
1768 LODWORD(qwStartTSF) -= 1024;
1771 if ((HIDWORD(qwCurrTSF) < HIDWORD(qwStartTSF)) ||
1772 ((HIDWORD(qwCurrTSF) == HIDWORD(qwStartTSF)) &&
1773 (LODWORD(qwCurrTSF) < LODWORD(qwStartTSF)))
1778 VNTWIFIbMeasureReport( pDevice->pMgmt,
1780 pDevice->pCurrMeasureEID,
1782 pDevice->byBasicMap,
1783 pDevice->byCCAFraction,
1787 // hardware do not support measure
1788 VNTWIFIbMeasureReport( pDevice->pMgmt,
1790 pDevice->pCurrMeasureEID,
1791 MEASURE_MODE_INCAPABLE,
1792 pDevice->byBasicMap,
1793 pDevice->byCCAFraction,
1797 } while (pDevice->uNumOfMeasureEIDs != 0);
1799 if (bExpired == FALSE) {
1800 MACvSelectPage1(pDevice->PortOffset);
1801 VNSvOutPortD(pDevice->PortOffset + MAC_REG_MSRSTART, LODWORD(qwStartTSF));
1802 VNSvOutPortD(pDevice->PortOffset + MAC_REG_MSRSTART + 4, HIDWORD(qwStartTSF));
1803 VNSvOutPortW(pDevice->PortOffset + MAC_REG_MSRDURATION, wDuration);
1804 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_MSRCTL, MSRCTL_EN);
1805 MACvSelectPage0(pDevice->PortOffset);
1807 // all measure start time expired we should complete action
1808 VNTWIFIbMeasureReport( pDevice->pMgmt,
1812 pDevice->byBasicMap,
1813 pDevice->byCCAFraction,
1824 * Do Channel Switch defined in 802.11h
1828 * hDeviceContext - device structure point
1832 * Return Value: none.
1836 CARDbChannelSwitch (
1837 void *pDeviceHandler,
1843 PSDevice pDevice = (PSDevice) pDeviceHandler;
1844 BOOL bResult = TRUE;
1847 bResult = CARDbSetChannel(pDevice, byNewChannel);
1848 VNTWIFIbChannelSwitch(pDevice->pMgmt, byNewChannel);
1849 MACvSelectPage1(pDevice->PortOffset);
1850 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_MSRCTL+1, MSRCTL1_TXPAUSE);
1851 MACvSelectPage0(pDevice->PortOffset);
1854 pDevice->byChannelSwitchCount = byCount;
1855 pDevice->byNewChannel = byNewChannel;
1856 pDevice->bChannelSwitch = TRUE;
1858 bResult=CARDbStopTxPacket(pDevice, PKT_TYPE_802_11_ALL);
1867 * Handle Quiet EID defined in 802.11h
1871 * hDeviceContext - device structure point
1875 * Return Value: none.
1880 void *pDeviceHandler,
1884 WORD wQuietDuration,
1888 PSDevice pDevice = (PSDevice) pDeviceHandler;
1891 if (bResetQuiet == TRUE) {
1892 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_MSRCTL, (MSRCTL_QUIETTXCHK | MSRCTL_QUIETEN));
1893 for(ii=0;ii<MAX_QUIET_COUNT;ii++) {
1894 pDevice->sQuiet[ii].bEnable = FALSE;
1896 pDevice->uQuietEnqueue = 0;
1897 pDevice->bEnableFirstQuiet = FALSE;
1898 pDevice->bQuietEnable = FALSE;
1899 pDevice->byQuietStartCount = byQuietCount;
1901 if (pDevice->sQuiet[pDevice->uQuietEnqueue].bEnable == FALSE) {
1902 pDevice->sQuiet[pDevice->uQuietEnqueue].bEnable = TRUE;
1903 pDevice->sQuiet[pDevice->uQuietEnqueue].byPeriod = byQuietPeriod;
1904 pDevice->sQuiet[pDevice->uQuietEnqueue].wDuration = wQuietDuration;
1905 pDevice->sQuiet[pDevice->uQuietEnqueue].dwStartTime = (DWORD) byQuietCount;
1906 pDevice->sQuiet[pDevice->uQuietEnqueue].dwStartTime *= pDevice->wBeaconInterval;
1907 pDevice->sQuiet[pDevice->uQuietEnqueue].dwStartTime += wQuietOffset;
1908 pDevice->uQuietEnqueue++;
1909 pDevice->uQuietEnqueue %= MAX_QUIET_COUNT;
1910 if (pDevice->byQuietStartCount < byQuietCount) {
1911 pDevice->byQuietStartCount = byQuietCount;
1914 // we can not handle Quiet EID more
1923 * Do Quiet, It will called by either ISR (after start) or VNTWIFI (before start) so do not need SPINLOCK
1927 * hDeviceContext - device structure point
1931 * Return Value: none.
1936 void *pDeviceHandler
1939 PSDevice pDevice = (PSDevice) pDeviceHandler;
1941 DWORD dwStartTime = 0xFFFFFFFF;
1942 UINT uCurrentQuietIndex = 0;
1943 DWORD dwNextTime = 0;
1945 DWORD dwDuration = 0;
1947 for(ii=0;ii<MAX_QUIET_COUNT;ii++) {
1948 if ((pDevice->sQuiet[ii].bEnable == TRUE) &&
1949 (dwStartTime > pDevice->sQuiet[ii].dwStartTime)) {
1950 dwStartTime = pDevice->sQuiet[ii].dwStartTime;
1951 uCurrentQuietIndex = ii;
1954 if (dwStartTime == 0xFFFFFFFF) {
1956 pDevice->bQuietEnable = FALSE;
1957 MACvRegBitsOff(pDevice->PortOffset, MAC_REG_MSRCTL, (MSRCTL_QUIETTXCHK | MSRCTL_QUIETEN));
1959 if (pDevice->bQuietEnable == FALSE) {
1961 pDevice->byQuietStartCount--;
1962 dwNextTime = pDevice->sQuiet[uCurrentQuietIndex].dwStartTime;
1963 dwNextTime %= pDevice->wBeaconInterval;
1964 MACvSelectPage1(pDevice->PortOffset);
1965 VNSvOutPortW(pDevice->PortOffset + MAC_REG_QUIETINIT, (WORD) dwNextTime);
1966 VNSvOutPortW(pDevice->PortOffset + MAC_REG_QUIETDUR, (WORD) pDevice->sQuiet[uCurrentQuietIndex].wDuration);
1967 if (pDevice->byQuietStartCount == 0) {
1968 pDevice->bEnableFirstQuiet = FALSE;
1969 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_MSRCTL, (MSRCTL_QUIETTXCHK | MSRCTL_QUIETEN));
1971 pDevice->bEnableFirstQuiet = TRUE;
1973 MACvSelectPage0(pDevice->PortOffset);
1975 if (pDevice->dwCurrentQuietEndTime > pDevice->sQuiet[uCurrentQuietIndex].dwStartTime) {
1976 // overlap with previous Quiet
1977 dwGap = pDevice->dwCurrentQuietEndTime - pDevice->sQuiet[uCurrentQuietIndex].dwStartTime;
1978 if (dwGap >= pDevice->sQuiet[uCurrentQuietIndex].wDuration) {
1979 // return FALSE to indicate next quiet expired, should call this function again
1982 dwDuration = pDevice->sQuiet[uCurrentQuietIndex].wDuration - dwGap;
1985 dwGap = pDevice->sQuiet[uCurrentQuietIndex].dwStartTime - pDevice->dwCurrentQuietEndTime;
1986 dwDuration = pDevice->sQuiet[uCurrentQuietIndex].wDuration;
1988 // set GAP and Next duration
1989 MACvSelectPage1(pDevice->PortOffset);
1990 VNSvOutPortW(pDevice->PortOffset + MAC_REG_QUIETGAP, (WORD) dwGap);
1991 VNSvOutPortW(pDevice->PortOffset + MAC_REG_QUIETDUR, (WORD) dwDuration);
1992 MACvRegBitsOn(pDevice->PortOffset, MAC_REG_MSRCTL, MSRCTL_QUIETRPT);
1993 MACvSelectPage0(pDevice->PortOffset);
1995 pDevice->bQuietEnable = TRUE;
1996 pDevice->dwCurrentQuietEndTime = pDevice->sQuiet[uCurrentQuietIndex].dwStartTime;
1997 pDevice->dwCurrentQuietEndTime += pDevice->sQuiet[uCurrentQuietIndex].wDuration;
1998 if (pDevice->sQuiet[uCurrentQuietIndex].byPeriod == 0) {
1999 // not period disable current quiet element
2000 pDevice->sQuiet[uCurrentQuietIndex].bEnable = FALSE;
2002 // set next period start time
2003 dwNextTime = (DWORD) pDevice->sQuiet[uCurrentQuietIndex].byPeriod;
2004 dwNextTime *= pDevice->wBeaconInterval;
2005 pDevice->sQuiet[uCurrentQuietIndex].dwStartTime = dwNextTime;
2007 if (pDevice->dwCurrentQuietEndTime > 0x80010000) {
2008 // decreament all time to avoid wrap around
2009 for(ii=0;ii<MAX_QUIET_COUNT;ii++) {
2010 if (pDevice->sQuiet[ii].bEnable == TRUE) {
2011 pDevice->sQuiet[ii].dwStartTime -= 0x80000000;
2014 pDevice->dwCurrentQuietEndTime -= 0x80000000;
2024 * Set Channel Info of Country
2028 * hDeviceContext - device structure point
2032 * Return Value: none.
2036 CARDvSetCountryInfo (
2037 void *pDeviceHandler,
2038 CARD_PHY_TYPE ePHYType,
2042 PSDevice pDevice = (PSDevice) pDeviceHandler;
2046 UINT uNumOfCountryInfo = 0;
2048 PWLAN_IE_COUNTRY pIE_Country = (PWLAN_IE_COUNTRY) pIE;
2051 uNumOfCountryInfo = (pIE_Country->len - 3);
2052 uNumOfCountryInfo /= 3;
2054 if (ePHYType == PHY_TYPE_11A) {
2055 pDevice->bCountryInfo5G = TRUE;
2056 for(ii=CB_MAX_CHANNEL_24G+1;ii<=CARD_MAX_CHANNEL_TBL;ii++) {
2057 sChannelTbl[ii].bValid = FALSE;
2061 pDevice->bCountryInfo24G = TRUE;
2062 for(ii=1;ii<=CB_MAX_CHANNEL_24G;ii++) {
2063 sChannelTbl[ii].bValid = FALSE;
2067 pDevice->abyCountryCode[0] = pIE_Country->abyCountryString[0];
2068 pDevice->abyCountryCode[1] = pIE_Country->abyCountryString[1];
2069 pDevice->abyCountryCode[2] = pIE_Country->abyCountryString[2];
2071 for(ii=0;ii<uNumOfCountryInfo;ii++) {
2072 for(uu=0;uu<pIE_Country->abyCountryInfo[ii*3+1];uu++) {
2073 byCh = CARDbyGetChannelMapping(pDevice, (BYTE)(pIE_Country->abyCountryInfo[ii*3]+step*uu), ePHYType);
2074 sChannelTbl[byCh].bValid = TRUE;
2075 pDevice->abyRegPwr[byCh] = pIE_Country->abyCountryInfo[ii*3+2];
2083 * Set Local Power Constraint
2087 * hDeviceContext - device structure point
2091 * Return Value: none.
2095 CARDvSetPowerConstraint (
2096 void *pDeviceHandler,
2101 PSDevice pDevice = (PSDevice) pDeviceHandler;
2103 if (byChannel > CB_MAX_CHANNEL_24G) {
2104 if (pDevice->bCountryInfo5G == TRUE) {
2105 pDevice->abyLocalPwr[byChannel] = pDevice->abyRegPwr[byChannel] - byPower;
2108 if (pDevice->bCountryInfo24G == TRUE) {
2109 pDevice->abyLocalPwr[byChannel] = pDevice->abyRegPwr[byChannel] - byPower;
2118 * Set Local Power Constraint
2122 * hDeviceContext - device structure point
2126 * Return Value: none.
2130 CARDvGetPowerCapability (
2131 void *pDeviceHandler,
2136 PSDevice pDevice = (PSDevice) pDeviceHandler;
2139 *pbyMaxPower = pDevice->abyOFDMDefaultPwr[pDevice->byCurrentCh];
2140 byDec = pDevice->abyOFDMPwrTbl[pDevice->byCurrentCh];
2141 if (pDevice->byRFType == RF_UW2452) {
2147 *pbyMinPower = pDevice->abyOFDMDefaultPwr[pDevice->byCurrentCh] - byDec;
2154 * Set Support Channels IE defined in 802.11h
2158 * hDeviceContext - device structure point
2162 * Return Value: none.
2166 CARDbySetSupportChannels (
2167 void *pDeviceHandler,
2171 PSDevice pDevice = (PSDevice) pDeviceHandler;
2174 PWLAN_IE_SUPP_CH pIE = (PWLAN_IE_SUPP_CH) pbyIEs;
2179 pIE->byElementID = WLAN_EID_SUPP_CH;
2181 pbyChTupple = pIE->abyChannelTuple;
2185 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[28] == TRUE) {
2186 for (ii=28;ii<36;ii+=2) {
2187 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] == TRUE) {
2191 *pbyChTupple++ = 34;
2192 *pbyChTupple++ = byCount;
2194 } else if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[29] == TRUE) {
2195 for (ii=29;ii<36;ii+=2) {
2196 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] == TRUE) {
2200 *pbyChTupple++ = 36;
2201 *pbyChTupple++ = byCount;
2206 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[36] == TRUE) {
2207 for (ii=36;ii<40;ii++) {
2208 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] == TRUE) {
2212 *pbyChTupple++ = 52;
2213 *pbyChTupple++ = byCount;
2218 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[40] == TRUE) {
2219 for (ii=40;ii<51;ii++) {
2220 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] == TRUE) {
2224 *pbyChTupple++ = 100;
2225 *pbyChTupple++ = byCount;
2227 } else if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[51] == TRUE) {
2228 for (ii=51;ii<56;ii++) {
2229 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] == TRUE) {
2233 *pbyChTupple++ = 149;
2234 *pbyChTupple++ = byCount;
2237 pIE->len += (byLen - 2);
2245 * Get Current Tx Power
2249 * hDeviceContext - device structure point
2253 * Return Value: none.
2257 CARDbyGetTransmitPower (
2258 void *pDeviceHandler
2261 PSDevice pDevice = (PSDevice) pDeviceHandler;
2263 return (pDevice->byCurPwrdBm);
2268 CARDbChannelGetList (
2269 UINT uCountryCodeIdx,
2270 PBYTE pbyChannelTable
2273 if (uCountryCodeIdx >= CCODE_MAX) {
2276 memcpy(pbyChannelTable, ChannelRuleTab[uCountryCodeIdx].bChannelIdxList, CB_MAX_CHANNEL);
2283 void *pDeviceHandler,
2287 PSDevice pDevice = (PSDevice) pDeviceHandler;
2289 PWLAN_IE_COUNTRY pIECountry = (PWLAN_IE_COUNTRY) pIE;
2291 pIECountry->byElementID = WLAN_EID_COUNTRY;
2292 pIECountry->len = 0;
2293 pIECountry->abyCountryString[0] = ChannelRuleTab[pDevice->byZoneType].chCountryCode[0];
2294 pIECountry->abyCountryString[1] = ChannelRuleTab[pDevice->byZoneType].chCountryCode[1];
2295 pIECountry->abyCountryString[2] = ' ';
2296 for (ii = CB_MAX_CHANNEL_24G; ii < CB_MAX_CHANNEL; ii++ ) {
2297 if (ChannelRuleTab[pDevice->byZoneType].bChannelIdxList[ii] != 0) {
2298 pIECountry->abyCountryInfo[pIECountry->len++] = sChannelTbl[ii+1].byChannelNumber;
2299 pIECountry->abyCountryInfo[pIECountry->len++] = 1;
2300 pIECountry->abyCountryInfo[pIECountry->len++] = ChannelRuleTab[pDevice->byZoneType].byPower[ii];
2303 pIECountry->len += 3;
2308 CARDbGetChannelMapInfo(
2309 void *pDeviceHandler,
2311 PBYTE pbyChannelNumber,
2315 // PSDevice pDevice = (PSDevice) pDeviceHandler;
2317 if (uChannelIndex > CB_MAX_CHANNEL) {
2320 *pbyChannelNumber = sChannelTbl[uChannelIndex].byChannelNumber;
2321 *pbyMap = sChannelTbl[uChannelIndex].byMAP;
2322 return sChannelTbl[uChannelIndex].bValid;
2327 CARDvSetChannelMapInfo(
2328 void *pDeviceHandler,
2333 // PSDevice pDevice = (PSDevice) pDeviceHandler;
2335 if (uChannelIndex > CB_MAX_CHANNEL) {
2338 sChannelTbl[uChannelIndex].byMAP |= byMap;
2343 CARDvClearChannelMapInfo(
2344 void *pDeviceHandler
2347 // PSDevice pDevice = (PSDevice) pDeviceHandler;
2350 for (ii = 1; ii <= CB_MAX_CHANNEL; ii++) {
2351 sChannelTbl[ii].byMAP = 0;
2357 CARDbyAutoChannelSelect(
2358 void *pDeviceHandler,
2359 CARD_PHY_TYPE ePHYType
2362 // PSDevice pDevice = (PSDevice) pDeviceHandler;
2364 BYTE byOptionChannel = 0;
2365 INT aiWeight[CB_MAX_CHANNEL_24G+1] = {-1000,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
2367 if (ePHYType == PHY_TYPE_11A) {
2368 for(ii=CB_MAX_CHANNEL_24G+1;ii<=CB_MAX_CHANNEL;ii++) {
2369 if (sChannelTbl[ii].bValid == TRUE) {
2370 if (byOptionChannel == 0) {
2371 byOptionChannel = (BYTE) ii;
2373 if (sChannelTbl[ii].byMAP == 0) {
2375 } else if ( !(sChannelTbl[ii].byMAP & 0x08)) {
2376 byOptionChannel = (BYTE) ii;
2381 byOptionChannel = 0;
2382 for(ii=1;ii<=CB_MAX_CHANNEL_24G;ii++) {
2383 if (sChannelTbl[ii].bValid == TRUE) {
2384 if (sChannelTbl[ii].byMAP == 0) {
2385 aiWeight[ii] += 100;
2386 } else if (sChannelTbl[ii].byMAP & 0x01) {
2388 aiWeight[ii-3] -= 10;
2391 aiWeight[ii-2] -= 20;
2394 aiWeight[ii-1] -= 40;
2397 if (ii < CB_MAX_CHANNEL_24G) {
2398 aiWeight[ii+1] -= 40;
2400 if (ii < (CB_MAX_CHANNEL_24G - 1)) {
2401 aiWeight[ii+2] -= 20;
2403 if (ii < (CB_MAX_CHANNEL_24G - 2)) {
2404 aiWeight[ii+3] -= 10;
2409 for(ii=1;ii<=CB_MAX_CHANNEL_24G;ii++) {
2410 if ((sChannelTbl[ii].bValid == TRUE) &&
2411 (aiWeight[ii] > aiWeight[byOptionChannel])) {
2412 byOptionChannel = (BYTE) ii;
2416 return (byOptionChannel);
2424 void *pDeviceHandler
2427 PSDevice pDevice = (PSDevice) pDeviceHandler;
2431 // initialize TD index
2432 pDevice->apTailTD[0] = pDevice->apCurrTD[0] = &(pDevice->apTD0Rings[0]);
2433 pDevice->apTailTD[1] = pDevice->apCurrTD[1] = &(pDevice->apTD1Rings[0]);
2435 for (uu = 0; uu < TYPE_MAXTD; uu ++)
2436 pDevice->iTDUsed[uu] = 0;
2438 for (uu = 0; uu < pDevice->sOpts.nTxDescs[0]; uu++) {
2439 pCurrTD = &(pDevice->apTD0Rings[uu]);
2440 pCurrTD->m_td0TD0.f1Owner = OWNED_BY_HOST;
2441 // init all Tx Packet pointer to NULL
2443 for (uu = 0; uu < pDevice->sOpts.nTxDescs[1]; uu++) {
2444 pCurrTD = &(pDevice->apTD1Rings[uu]);
2445 pCurrTD->m_td0TD0.f1Owner = OWNED_BY_HOST;
2446 // init all Tx Packet pointer to NULL
2449 // set MAC TD pointer
2450 MACvSetCurrTXDescAddr(TYPE_TXDMA0, pDevice->PortOffset,
2451 (pDevice->td0_pool_dma));
2453 MACvSetCurrTXDescAddr(TYPE_AC0DMA, pDevice->PortOffset,
2454 (pDevice->td1_pool_dma));
2456 // set MAC Beacon TX pointer
2457 MACvSetCurrBCNTxDescAddr(pDevice->PortOffset,
2458 (pDevice->tx_beacon_dma));
2471 * pDevice - Pointer to the adapter
2475 * Return Value: none
2480 void *pDeviceHandler
2483 PSDevice pDevice = (PSDevice) pDeviceHandler;
2489 // initialize RD index
2490 pDevice->pCurrRD[0]=&(pDevice->aRD0Ring[0]);
2491 pDevice->pCurrRD[1]=&(pDevice->aRD1Ring[0]);
2493 // init state, all RD is chip's
2494 for (uu = 0; uu < pDevice->sOpts.nRxDescs0; uu++) {
2495 pDesc =&(pDevice->aRD0Ring[uu]);
2496 pDesc->m_rd0RD0.wResCount = (WORD)(pDevice->rx_buf_sz);
2497 pDesc->m_rd0RD0.f1Owner=OWNED_BY_NIC;
2498 pDesc->m_rd1RD1.wReqCount = (WORD)(pDevice->rx_buf_sz);
2501 // init state, all RD is chip's
2502 for (uu = 0; uu < pDevice->sOpts.nRxDescs1; uu++) {
2503 pDesc =&(pDevice->aRD1Ring[uu]);
2504 pDesc->m_rd0RD0.wResCount = (WORD)(pDevice->rx_buf_sz);
2505 pDesc->m_rd0RD0.f1Owner=OWNED_BY_NIC;
2506 pDesc->m_rd1RD1.wReqCount = (WORD)(pDevice->rx_buf_sz);
2509 pDevice->cbDFCB = CB_MAX_RX_FRAG;
2510 pDevice->cbFreeDFCB = pDevice->cbDFCB;
2513 MACvRx0PerPktMode(pDevice->PortOffset);
2514 MACvRx1PerPktMode(pDevice->PortOffset);
2515 // set MAC RD pointer
2516 MACvSetCurrRx0DescAddr(pDevice->PortOffset,
2517 pDevice->rd0_pool_dma);
2519 MACvSetCurrRx1DescAddr(pDevice->PortOffset,
2520 pDevice->rd1_pool_dma);
2527 * Description: Get response Control frame rate in CCK mode
2531 * pDevice - The adapter to be set
2532 * wRateIdx - Receiving data rate
2536 * Return Value: response Control frame rate
2539 WORD CARDwGetCCKControlRate(void *pDeviceHandler, WORD wRateIdx)
2541 PSDevice pDevice = (PSDevice) pDeviceHandler;
2542 UINT ui = (UINT)wRateIdx;
2544 while (ui > RATE_1M) {
2545 if (pDevice->wBasicRate & ((WORD)1 << ui)) {
2550 return (WORD)RATE_1M;
2554 * Description: Get response Control frame rate in OFDM mode
2558 * pDevice - The adapter to be set
2559 * wRateIdx - Receiving data rate
2563 * Return Value: response Control frame rate
2566 WORD CARDwGetOFDMControlRate (void *pDeviceHandler, WORD wRateIdx)
2568 PSDevice pDevice = (PSDevice) pDeviceHandler;
2569 UINT ui = (UINT)wRateIdx;
2571 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"BASIC RATE: %X\n", pDevice->wBasicRate);
2573 if (!CARDbIsOFDMinBasicRate((void *)pDevice)) {
2574 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"CARDwGetOFDMControlRate:(NO OFDM) %d\n", wRateIdx);
2575 if (wRateIdx > RATE_24M)
2576 wRateIdx = RATE_24M;
2579 while (ui > RATE_11M) {
2580 if (pDevice->wBasicRate & ((WORD)1 << ui)) {
2581 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"CARDwGetOFDMControlRate : %d\n", ui);
2586 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"CARDwGetOFDMControlRate: 6M\n");
2587 return (WORD)RATE_24M;
2592 * Description: Set RSPINF
2596 * pDevice - The adapter to be set
2600 * Return Value: None.
2603 void CARDvSetRSPINF (void *pDeviceHandler, CARD_PHY_TYPE ePHYType)
2605 PSDevice pDevice = (PSDevice) pDeviceHandler;
2606 BYTE byServ = 0x00, bySignal = 0x00; //For CCK
2608 BYTE byTxRate, byRsvTime; //For OFDM
2611 MACvSelectPage1(pDevice->PortOffset);
2614 BBvCaculateParameter(pDevice,
2616 CARDwGetCCKControlRate((void *)pDevice, RATE_1M),
2623 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_1, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
2625 BBvCaculateParameter(pDevice,
2627 CARDwGetCCKControlRate((void *)pDevice, RATE_2M),
2634 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_2, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
2636 BBvCaculateParameter(pDevice,
2638 CARDwGetCCKControlRate((void *)pDevice, RATE_5M),
2645 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_5, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
2647 BBvCaculateParameter(pDevice,
2649 CARDwGetCCKControlRate((void *)pDevice, RATE_11M),
2656 VNSvOutPortD(pDevice->PortOffset + MAC_REG_RSPINF_B_11, MAKEDWORD(wLen,MAKEWORD(bySignal,byServ)));
2658 s_vCaculateOFDMRParameter(RATE_6M,
2662 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_6, MAKEWORD(byTxRate,byRsvTime));
2664 s_vCaculateOFDMRParameter(RATE_9M,
2668 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_9, MAKEWORD(byTxRate,byRsvTime));
2670 s_vCaculateOFDMRParameter(RATE_12M,
2674 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_12, MAKEWORD(byTxRate,byRsvTime));
2676 s_vCaculateOFDMRParameter(RATE_18M,
2680 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_18, MAKEWORD(byTxRate,byRsvTime));
2682 s_vCaculateOFDMRParameter(RATE_24M,
2686 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_24, MAKEWORD(byTxRate,byRsvTime));
2688 s_vCaculateOFDMRParameter(CARDwGetOFDMControlRate((void *)pDevice, RATE_36M),
2692 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_36, MAKEWORD(byTxRate,byRsvTime));
2694 s_vCaculateOFDMRParameter(CARDwGetOFDMControlRate((void *)pDevice, RATE_48M),
2698 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_48, MAKEWORD(byTxRate,byRsvTime));
2700 s_vCaculateOFDMRParameter(CARDwGetOFDMControlRate((void *)pDevice, RATE_54M),
2704 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_54, MAKEWORD(byTxRate,byRsvTime));
2707 s_vCaculateOFDMRParameter(CARDwGetOFDMControlRate((void *)pDevice, RATE_54M),
2711 VNSvOutPortW(pDevice->PortOffset + MAC_REG_RSPINF_A_72, MAKEWORD(byTxRate,byRsvTime));
2713 MACvSelectPage0(pDevice->PortOffset);
2717 * Description: Update IFS
2721 * pDevice - The adapter to be set
2725 * Return Value: None.
2728 void vUpdateIFS (void *pDeviceHandler)
2730 //Set SIFS, DIFS, EIFS, SlotTime, CwMin
2731 PSDevice pDevice = (PSDevice) pDeviceHandler;
2734 if (pDevice->byPacketType==PK_TYPE_11A) {//0000 0000 0000 0000,11a
2735 pDevice->uSlot = C_SLOT_SHORT;
2736 pDevice->uSIFS = C_SIFS_A;
2737 pDevice->uDIFS = C_SIFS_A + 2*C_SLOT_SHORT;
2738 pDevice->uCwMin = C_CWMIN_A;
2741 else if (pDevice->byPacketType==PK_TYPE_11B) {//0000 0001 0000 0000,11b
2742 pDevice->uSlot = C_SLOT_LONG;
2743 pDevice->uSIFS = C_SIFS_BG;
2744 pDevice->uDIFS = C_SIFS_BG + 2*C_SLOT_LONG;
2745 pDevice->uCwMin = C_CWMIN_B;
2748 else { // PK_TYPE_11GA & PK_TYPE_11GB
2749 pDevice->uSIFS = C_SIFS_BG;
2750 if (pDevice->bShortSlotTime) {
2751 pDevice->uSlot = C_SLOT_SHORT;
2753 pDevice->uSlot = C_SLOT_LONG;
2755 pDevice->uDIFS = C_SIFS_BG + 2*pDevice->uSlot;
2756 if (pDevice->wBasicRate & 0x0150) { //0000 0001 0101 0000,24M,12M,6M
2757 pDevice->uCwMin = C_CWMIN_A;
2761 pDevice->uCwMin = C_CWMIN_B;
2766 pDevice->uCwMax = C_CWMAX;
2767 pDevice->uEIFS = C_EIFS;
2768 if (pDevice->byRFType == RF_RFMD2959) {
2769 // bcs TX_PE will reserve 3 us
2770 VNSvOutPortB(pDevice->PortOffset + MAC_REG_SIFS, (BYTE)(pDevice->uSIFS - 3));
2771 VNSvOutPortB(pDevice->PortOffset + MAC_REG_DIFS, (BYTE)(pDevice->uDIFS - 3));
2773 VNSvOutPortB(pDevice->PortOffset + MAC_REG_SIFS, (BYTE)pDevice->uSIFS);
2774 VNSvOutPortB(pDevice->PortOffset + MAC_REG_DIFS, (BYTE)pDevice->uDIFS);
2776 VNSvOutPortB(pDevice->PortOffset + MAC_REG_EIFS, (BYTE)pDevice->uEIFS);
2777 VNSvOutPortB(pDevice->PortOffset + MAC_REG_SLOT, (BYTE)pDevice->uSlot);
2778 byMaxMin |= 0xA0;//1010 1111,C_CWMAX = 1023
2779 VNSvOutPortB(pDevice->PortOffset + MAC_REG_CWMAXMIN0, (BYTE)byMaxMin);
2782 void CARDvUpdateBasicTopRate (void *pDeviceHandler)
2784 PSDevice pDevice = (PSDevice) pDeviceHandler;
2785 BYTE byTopOFDM = RATE_24M, byTopCCK = RATE_1M;
2788 //Determines the highest basic rate.
2789 for (ii = RATE_54M; ii >= RATE_6M; ii --) {
2790 if ( (pDevice->wBasicRate) & ((WORD)(1<<ii)) ) {
2795 pDevice->byTopOFDMBasicRate = byTopOFDM;
2797 for (ii = RATE_11M;; ii --) {
2798 if ( (pDevice->wBasicRate) & ((WORD)(1<<ii)) ) {
2805 pDevice->byTopCCKBasicRate = byTopCCK;
2810 * Description: Set NIC Tx Basic Rate
2814 * pDevice - The adapter to be set
2815 * wBasicRate - Basic Rate to be set
2819 * Return Value: TRUE if succeeded; FALSE if failed.
2822 BOOL CARDbAddBasicRate (void *pDeviceHandler, WORD wRateIdx)
2824 PSDevice pDevice = (PSDevice) pDeviceHandler;
2825 WORD wRate = (WORD)(1<<wRateIdx);
2827 pDevice->wBasicRate |= wRate;
2829 //Determines the highest basic rate.
2830 CARDvUpdateBasicTopRate((void *)pDevice);
2835 BOOL CARDbIsOFDMinBasicRate (void *pDeviceHandler)
2837 PSDevice pDevice = (PSDevice) pDeviceHandler;
2840 for (ii = RATE_54M; ii >= RATE_6M; ii --) {
2841 if ((pDevice->wBasicRate) & ((WORD)(1<<ii)))
2847 BYTE CARDbyGetPktType (void *pDeviceHandler)
2849 PSDevice pDevice = (PSDevice) pDeviceHandler;
2851 if (pDevice->byBBType == BB_TYPE_11A || pDevice->byBBType == BB_TYPE_11B) {
2852 return (BYTE)pDevice->byBBType;
2854 else if (CARDbIsOFDMinBasicRate((void *)pDevice)) {
2855 return PK_TYPE_11GA;
2858 return PK_TYPE_11GB;
2863 * Description: Set NIC Loopback mode
2867 * pDevice - The adapter to be set
2868 * wLoopbackMode - Loopback mode to be set
2872 * Return Value: none
2875 void CARDvSetLoopbackMode (DWORD_PTR dwIoBase, WORD wLoopbackMode)
2877 switch(wLoopbackMode) {
2887 MACvSetLoopbackMode(dwIoBase, LOBYTE(wLoopbackMode));
2888 // set Baseband loopback
2893 * Description: Software Reset NIC
2897 * pDevice - The adapter to be reset
2901 * Return Value: none
2904 BOOL CARDbSoftwareReset (void *pDeviceHandler)
2906 PSDevice pDevice = (PSDevice) pDeviceHandler;
2909 if (!MACbSafeSoftwareReset(pDevice->PortOffset))
2917 * Description: Caculate TSF offset of two TSF input
2918 * Get TSF Offset from RxBCN's TSF and local TSF
2922 * pDevice - The adapter to be sync.
2923 * qwTSF1 - Rx BCN's TSF
2924 * qwTSF2 - Local TSF
2928 * Return Value: TSF Offset value
2931 QWORD CARDqGetTSFOffset (BYTE byRxRate, QWORD qwTSF1, QWORD qwTSF2)
2934 WORD wRxBcnTSFOffst= 0;;
2936 HIDWORD(qwTSFOffset) = 0;
2937 LODWORD(qwTSFOffset) = 0;
2938 wRxBcnTSFOffst = cwRXBCNTSFOff[byRxRate%MAX_RATE];
2939 (qwTSF2).u.dwLowDword += (DWORD)(wRxBcnTSFOffst);
2940 if ((qwTSF2).u.dwLowDword < (DWORD)(wRxBcnTSFOffst)) {
2941 (qwTSF2).u.dwHighDword++;
2943 LODWORD(qwTSFOffset) = LODWORD(qwTSF1) - LODWORD(qwTSF2);
2944 if (LODWORD(qwTSF1) < LODWORD(qwTSF2)) {
2946 HIDWORD(qwTSFOffset) = HIDWORD(qwTSF1) - HIDWORD(qwTSF2) - 1 ;
2949 HIDWORD(qwTSFOffset) = HIDWORD(qwTSF1) - HIDWORD(qwTSF2);
2951 return (qwTSFOffset);
2956 * Description: Read NIC TSF counter
2957 * Get local TSF counter
2961 * pDevice - The adapter to be read
2963 * qwCurrTSF - Current TSF counter
2965 * Return Value: TRUE if success; otherwise FALSE
2968 BOOL CARDbGetCurrentTSF (DWORD_PTR dwIoBase, PQWORD pqwCurrTSF)
2973 MACvRegBitsOn(dwIoBase, MAC_REG_TFTCTL, TFTCTL_TSFCNTRRD);
2974 for (ww = 0; ww < W_MAX_TIMEOUT; ww++) {
2975 VNSvInPortB(dwIoBase + MAC_REG_TFTCTL, &byData);
2976 if ( !(byData & TFTCTL_TSFCNTRRD))
2979 if (ww == W_MAX_TIMEOUT)
2981 VNSvInPortD(dwIoBase + MAC_REG_TSFCNTR, &LODWORD(*pqwCurrTSF));
2982 VNSvInPortD(dwIoBase + MAC_REG_TSFCNTR + 4, &HIDWORD(*pqwCurrTSF));
2989 * Description: Read NIC TSF counter
2990 * Get NEXTTBTT from adjusted TSF and Beacon Interval
2994 * qwTSF - Current TSF counter
2995 * wbeaconInterval - Beacon Interval
2997 * qwCurrTSF - Current TSF counter
2999 * Return Value: TSF value of next Beacon
3002 QWORD CARDqGetNextTBTT (QWORD qwTSF, WORD wBeaconInterval)
3006 UINT uHighRemain, uLowRemain;
3007 UINT uBeaconInterval;
3009 uBeaconInterval = wBeaconInterval * 1024;
3010 // Next TBTT = ((local_current_TSF / beacon_interval) + 1 ) * beacon_interval
3011 uLowNextTBTT = (LODWORD(qwTSF) >> 10) << 10;
3012 // low dword (mod) bcn
3013 uLowRemain = (uLowNextTBTT) % uBeaconInterval;
3014 // uHighRemain = ((0x80000000 % uBeaconInterval)* 2 * HIDWORD(qwTSF))
3015 // % uBeaconInterval;
3016 // high dword (mod) bcn
3017 uHighRemain = (((0xffffffff % uBeaconInterval) + 1) * HIDWORD(qwTSF))
3019 uLowRemain = (uHighRemain + uLowRemain) % uBeaconInterval;
3020 uLowRemain = uBeaconInterval - uLowRemain;
3022 // check if carry when add one beacon interval
3023 if ((~uLowNextTBTT) < uLowRemain)
3026 LODWORD(qwTSF) = uLowNextTBTT + uLowRemain;
3033 * Description: Set NIC TSF counter for first Beacon time
3034 * Get NEXTTBTT from adjusted TSF and Beacon Interval
3038 * dwIoBase - IO Base
3039 * wBeaconInterval - Beacon Interval
3043 * Return Value: none
3046 void CARDvSetFirstNextTBTT (DWORD_PTR dwIoBase, WORD wBeaconInterval)
3051 HIDWORD(qwNextTBTT) = 0;
3052 LODWORD(qwNextTBTT) = 0;
3053 CARDbGetCurrentTSF(dwIoBase, &qwNextTBTT); //Get Local TSF counter
3054 qwNextTBTT = CARDqGetNextTBTT(qwNextTBTT, wBeaconInterval);
3056 VNSvOutPortD(dwIoBase + MAC_REG_NEXTTBTT, LODWORD(qwNextTBTT));
3057 VNSvOutPortD(dwIoBase + MAC_REG_NEXTTBTT + 4, HIDWORD(qwNextTBTT));
3058 MACvRegBitsOn(dwIoBase, MAC_REG_TFTCTL, TFTCTL_TBTTSYNCEN);
3059 //DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Card:First Next TBTT[%8xh:%8xh] \n", HIDWORD(qwNextTBTT), LODWORD(qwNextTBTT));
3065 * Description: Sync NIC TSF counter for Beacon time
3066 * Get NEXTTBTT and write to HW
3070 * pDevice - The adapter to be set
3071 * qwTSF - Current TSF counter
3072 * wBeaconInterval - Beacon Interval
3076 * Return Value: none
3079 void CARDvUpdateNextTBTT (DWORD_PTR dwIoBase, QWORD qwTSF, WORD wBeaconInterval)
3082 qwTSF = CARDqGetNextTBTT(qwTSF, wBeaconInterval);
3084 VNSvOutPortD(dwIoBase + MAC_REG_NEXTTBTT, LODWORD(qwTSF));
3085 VNSvOutPortD(dwIoBase + MAC_REG_NEXTTBTT + 4, HIDWORD(qwTSF));
3086 MACvRegBitsOn(dwIoBase, MAC_REG_TFTCTL, TFTCTL_TBTTSYNCEN);
3087 DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Card:Update Next TBTT[%8xh:%8xh] \n",(UINT)HIDWORD(qwTSF), (UINT)LODWORD(qwTSF));