1 /******************************************************************************
2 * Copyright(c) 2008 - 2010 Realtek Corporation. All rights reserved.
4 * This program is distributed in the hope that it will be useful, but WITHOUT
5 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
9 * You should have received a copy of the GNU General Public License along with
10 * this program; if not, write to the Free Software Foundation, Inc.,
11 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
13 * The full GNU General Public License is included in this distribution in the
14 * file called LICENSE.
16 * Contact Information:
17 * wlanfae <wlanfae@realtek.com>
18 ******************************************************************************/
20 #include "rtl819x_HT.h"
21 u8 MCS_FILTER_ALL[16] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x1f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
23 u8 MCS_FILTER_1SS[16] = {0xff, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
25 u16 MCS_DATA_RATE[2][2][77] =
26 { { {13, 26, 39, 52, 78, 104, 117, 130, 26, 52, 78 ,104, 156, 208, 234, 260,
27 39, 78, 117, 234, 312, 351, 390, 52, 104, 156, 208, 312, 416, 468, 520,
28 0, 78, 104, 130, 117, 156, 195, 104, 130, 130, 156, 182, 182, 208, 156, 195,
29 195, 234, 273, 273, 312, 130, 156, 181, 156, 181, 208, 234, 208, 234, 260, 260,
30 286, 195, 234, 273, 234, 273, 312, 351, 312, 351, 390, 390, 429},
31 {14, 29, 43, 58, 87, 116, 130, 144, 29, 58, 87, 116, 173, 231, 260, 289,
32 43, 87, 130, 173, 260, 347, 390, 433, 58, 116, 173, 231, 347, 462, 520, 578,
33 0, 87, 116, 144, 130, 173, 217, 116, 144, 144, 173, 202, 202, 231, 173, 217,
34 217, 260, 303, 303, 347, 144, 173, 202, 173, 202, 231, 260, 231, 260, 289, 289,
35 318, 217, 260, 303, 260, 303, 347, 390, 347, 390, 433, 433, 477} },
36 { {27, 54, 81, 108, 162, 216, 243, 270, 54, 108, 162, 216, 324, 432, 486, 540,
37 81, 162, 243, 324, 486, 648, 729, 810, 108, 216, 324, 432, 648, 864, 972, 1080,
38 12, 162, 216, 270, 243, 324, 405, 216, 270, 270, 324, 378, 378, 432, 324, 405,
39 405, 486, 567, 567, 648, 270, 324, 378, 324, 378, 432, 486, 432, 486, 540, 540,
40 594, 405, 486, 567, 486, 567, 648, 729, 648, 729, 810, 810, 891},
41 {30, 60, 90, 120, 180, 240, 270, 300, 60, 120, 180, 240, 360, 480, 540, 600,
42 90, 180, 270, 360, 540, 720, 810, 900, 120, 240, 360, 480, 720, 960, 1080, 1200,
43 13, 180, 240, 300, 270, 360, 450, 240, 300, 300, 360, 420, 420, 480, 360, 450,
44 450, 540, 630, 630, 720, 300, 360, 420, 360, 420, 480, 540, 480, 540, 600, 600,
45 660, 450, 540, 630, 540, 630, 720, 810, 720, 810, 900, 900, 990} }
48 static u8 UNKNOWN_BORADCOM[3] = {0x00, 0x14, 0xbf};
49 static u8 LINKSYSWRT330_LINKSYSWRT300_BROADCOM[3] = {0x00, 0x1a, 0x70};
50 static u8 LINKSYSWRT350_LINKSYSWRT150_BROADCOM[3] = {0x00, 0x1d, 0x7e};
51 static u8 BELKINF5D8233V1_RALINK[3] = {0x00, 0x17, 0x3f};
52 static u8 BELKINF5D82334V3_RALINK[3] = {0x00, 0x1c, 0xdf};
53 static u8 PCI_RALINK[3] = {0x00, 0x90, 0xcc};
54 static u8 EDIMAX_RALINK[3] = {0x00, 0x0e, 0x2e};
55 static u8 AIRLINK_RALINK[3] = {0x00, 0x18, 0x02};
56 static u8 DLINK_ATHEROS_1[3] = {0x00, 0x1c, 0xf0};
57 static u8 DLINK_ATHEROS_2[3] = {0x00, 0x21, 0x91};
58 static u8 CISCO_BROADCOM[3] = {0x00, 0x17, 0x94};
59 #if defined(RTL8192SU)
60 static u8 NETGEAR_BROADCOM[3] = {0x00, 0x1f, 0x33};
62 static u8 LINKSYS_MARVELL_4400N[3] = {0x00, 0x14, 0xa4};
63 void HTUpdateDefaultSetting(struct rtllib_device* ieee)
65 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
68 pHTInfo->bRDGEnable = 0;
71 pHTInfo->bRegShortGI20MHz= 1;
72 pHTInfo->bRegShortGI40MHz= 1;
74 pHTInfo->bRegBW40MHz = 1;
76 if(pHTInfo->bRegBW40MHz)
77 pHTInfo->bRegSuppCCK = 1;
79 pHTInfo->bRegSuppCCK = true;
81 pHTInfo->nAMSDU_MaxSize = 7935UL;
82 pHTInfo->bAMSDU_Support = 0;
84 pHTInfo->bAMPDUEnable = 1;
85 pHTInfo->AMPDU_Factor = 2;
86 pHTInfo->MPDU_Density = 0;
88 pHTInfo->SelfMimoPs = 3;
89 if(pHTInfo->SelfMimoPs == 2)
90 pHTInfo->SelfMimoPs = 3;
91 ieee->bTxDisableRateFallBack = 0;
92 ieee->bTxUseDriverAssingedRate = 0;
94 ieee->bTxEnableFwCalcDur = 1;
96 pHTInfo->bRegRT2RTAggregation = 1;
98 pHTInfo->bRegRxReorderEnable = 1;
99 pHTInfo->RxReorderWinSize = 64;
100 pHTInfo->RxReorderPendingTime = 30;
102 #ifdef USB_TX_DRIVER_AGGREGATION_ENABLE
103 pHTInfo->UsbTxAggrNum = 4;
105 #ifdef USB_RX_AGGREGATION_SUPPORT
107 pHTInfo->UsbRxFwAggrEn = 1;
108 pHTInfo->UsbRxFwAggrPageNum = 48;
109 pHTInfo->UsbRxFwAggrPacketNum = 8;
110 pHTInfo->UsbRxFwAggrTimeout = 4;
111 pHTInfo->UsbRxPageSize= 128;
113 pHTInfo->UsbRxFwAggrEn = 1;
114 pHTInfo->UsbRxFwAggrPageNum = 24;
115 pHTInfo->UsbRxFwAggrPacketNum = 8;
116 pHTInfo->UsbRxFwAggrTimeout = 8;
122 void HTDebugHTCapability(u8* CapIE, u8* TitleString )
125 static u8 EWC11NHTCap[] = {0x00, 0x90, 0x4c, 0x33};
126 PHT_CAPABILITY_ELE pCapELE;
128 if(!memcmp(CapIE, EWC11NHTCap, sizeof(EWC11NHTCap)))
130 RTLLIB_DEBUG(RTLLIB_DL_HT, "EWC IE in %s()\n", __FUNCTION__);
131 pCapELE = (PHT_CAPABILITY_ELE)(&CapIE[4]);
133 pCapELE = (PHT_CAPABILITY_ELE)(&CapIE[0]);
135 RTLLIB_DEBUG(RTLLIB_DL_HT, "<Log HT Capability>. Called by %s\n", TitleString );
137 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tSupported Channel Width = %s\n", (pCapELE->ChlWidth)?"20MHz": "20/40MHz");
138 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tSupport Short GI for 20M = %s\n", (pCapELE->ShortGI20Mhz)?"YES": "NO");
139 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tSupport Short GI for 40M = %s\n", (pCapELE->ShortGI40Mhz)?"YES": "NO");
140 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tSupport TX STBC = %s\n", (pCapELE->TxSTBC)?"YES": "NO");
141 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tMax AMSDU Size = %s\n", (pCapELE->MaxAMSDUSize)?"3839": "7935");
142 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tSupport CCK in 20/40 mode = %s\n", (pCapELE->DssCCk)?"YES": "NO");
143 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tMax AMPDU Factor = %d\n", pCapELE->MaxRxAMPDUFactor);
144 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tMPDU Density = %d\n", pCapELE->MPDUDensity);
145 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tMCS Rate Set = [%x][%x][%x][%x][%x]\n", pCapELE->MCS[0],\
146 pCapELE->MCS[1], pCapELE->MCS[2], pCapELE->MCS[3], pCapELE->MCS[4]);
150 void HTDebugHTInfo(u8* InfoIE, u8* TitleString)
153 static u8 EWC11NHTInfo[] = {0x00, 0x90, 0x4c, 0x34};
154 PHT_INFORMATION_ELE pHTInfoEle;
156 if(!memcmp(InfoIE, EWC11NHTInfo, sizeof(EWC11NHTInfo)))
158 RTLLIB_DEBUG(RTLLIB_DL_HT, "EWC IE in %s()\n", __FUNCTION__);
159 pHTInfoEle = (PHT_INFORMATION_ELE)(&InfoIE[4]);
161 pHTInfoEle = (PHT_INFORMATION_ELE)(&InfoIE[0]);
164 RTLLIB_DEBUG(RTLLIB_DL_HT, "<Log HT Information Element>. Called by %s\n", TitleString);
166 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tPrimary channel = %d\n", pHTInfoEle->ControlChl);
167 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tSenondary channel =");
168 switch(pHTInfoEle->ExtChlOffset)
171 RTLLIB_DEBUG(RTLLIB_DL_HT, "Not Present\n");
174 RTLLIB_DEBUG(RTLLIB_DL_HT, "Upper channel\n");
177 RTLLIB_DEBUG(RTLLIB_DL_HT, "Reserved. Eooro!!!\n");
180 RTLLIB_DEBUG(RTLLIB_DL_HT, "Lower Channel\n");
183 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tRecommended channel width = %s\n", (pHTInfoEle->RecommemdedTxWidth)?"20Mhz": "40Mhz");
185 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tOperation mode for protection = ");
186 switch(pHTInfoEle->OptMode)
189 RTLLIB_DEBUG(RTLLIB_DL_HT, "No Protection\n");
192 RTLLIB_DEBUG(RTLLIB_DL_HT, "HT non-member protection mode\n");
195 RTLLIB_DEBUG(RTLLIB_DL_HT, "Suggest to open protection\n");
198 RTLLIB_DEBUG(RTLLIB_DL_HT, "HT mixed mode\n");
202 RTLLIB_DEBUG(RTLLIB_DL_HT, "\tBasic MCS Rate Set = [%x][%x][%x][%x][%x]\n", pHTInfoEle->BasicMSC[0],\
203 pHTInfoEle->BasicMSC[1], pHTInfoEle->BasicMSC[2], pHTInfoEle->BasicMSC[3], pHTInfoEle->BasicMSC[4]);
207 bool IsHTHalfNmode40Bandwidth(struct rtllib_device* ieee)
209 bool retValue = false;
210 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
212 if(pHTInfo->bCurrentHTSupport == false )
214 else if(pHTInfo->bRegBW40MHz == false)
216 else if(!ieee->GetHalfNmodeSupportByAPsHandler(ieee->dev))
218 else if(((PHT_CAPABILITY_ELE)(pHTInfo->PeerHTCapBuf))->ChlWidth)
226 bool IsHTHalfNmodeSGI(struct rtllib_device* ieee, bool is40MHz)
228 bool retValue = false;
229 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
231 if(pHTInfo->bCurrentHTSupport == false )
233 else if(!ieee->GetHalfNmodeSupportByAPsHandler(ieee->dev))
237 if(((PHT_CAPABILITY_ELE)(pHTInfo->PeerHTCapBuf))->ShortGI40Mhz)
244 if(((PHT_CAPABILITY_ELE)(pHTInfo->PeerHTCapBuf))->ShortGI20Mhz)
253 u16 HTHalfMcsToDataRate(struct rtllib_device* ieee, u8 nMcsRate)
259 is40MHz = (IsHTHalfNmode40Bandwidth(ieee))?1:0;
260 isShortGI = (IsHTHalfNmodeSGI(ieee, is40MHz))? 1:0;
262 return MCS_DATA_RATE[is40MHz][isShortGI][(nMcsRate&0x7f)];
266 u16 HTMcsToDataRate( struct rtllib_device* ieee, u8 nMcsRate)
268 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
270 u8 is40MHz = (pHTInfo->bCurBW40MHz)?1:0;
271 u8 isShortGI = (pHTInfo->bCurBW40MHz)?
272 ((pHTInfo->bCurShortGI40MHz)?1:0):
273 ((pHTInfo->bCurShortGI20MHz)?1:0);
274 return MCS_DATA_RATE[is40MHz][isShortGI][(nMcsRate&0x7f)];
277 u16 TxCountToDataRate( struct rtllib_device* ieee, u8 nDataRate)
279 u16 CCKOFDMRate[12] = {0x02 , 0x04 , 0x0b , 0x16 , 0x0c , 0x12 , 0x18 , 0x24 , 0x30 , 0x48 , 0x60 , 0x6c};
285 return CCKOFDMRate[nDataRate];
289 if (nDataRate >= 0x10 && nDataRate <= 0x1f)
295 else if(nDataRate >=0x20 && nDataRate <= 0x2f )
301 else if(nDataRate >= 0x30 && nDataRate <= 0x3f )
307 else if(nDataRate >= 0x40 && nDataRate <= 0x4f )
313 return MCS_DATA_RATE[is40MHz][isShortGI][nDataRate&0xf];
319 bool IsHTHalfNmodeAPs(struct rtllib_device* ieee)
321 bool retValue = false;
322 struct rtllib_network* net = &ieee->current_network;
324 if(ieee->bHalfNMode == false)
328 if((memcmp(net->bssid, BELKINF5D8233V1_RALINK, 3)==0) ||
329 (memcmp(net->bssid, BELKINF5D82334V3_RALINK, 3)==0) ||
330 (memcmp(net->bssid, PCI_RALINK, 3)==0) ||
331 (memcmp(net->bssid, EDIMAX_RALINK, 3)==0) ||
332 (memcmp(net->bssid, AIRLINK_RALINK, 3)==0) ||
333 (net->ralink_cap_exist))
335 else if((memcmp(net->bssid, UNKNOWN_BORADCOM, 3)==0) ||
336 (memcmp(net->bssid, LINKSYSWRT330_LINKSYSWRT300_BROADCOM, 3)==0)||
337 (memcmp(net->bssid, LINKSYSWRT350_LINKSYSWRT150_BROADCOM, 3)==0)||
338 (net->broadcom_cap_exist))
340 else if(net->bssht.bdRT2RTAggregation)
348 void HTIOTPeerDetermine(struct rtllib_device* ieee)
350 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
351 struct rtllib_network* net = &ieee->current_network;
352 if(net->bssht.bdRT2RTAggregation){
353 pHTInfo->IOTPeer = HT_IOT_PEER_REALTEK;
354 if(net->bssht.RT2RT_HT_Mode & RT_HT_CAP_USE_92SE){
355 pHTInfo->IOTPeer = HT_IOT_PEER_REALTEK_92SE;
357 if(net->bssht.RT2RT_HT_Mode & RT_HT_CAP_USE_SOFTAP){
358 pHTInfo->IOTPeer = HT_IOT_PEER_92U_SOFTAP;
361 else if(net->broadcom_cap_exist)
362 pHTInfo->IOTPeer = HT_IOT_PEER_BROADCOM;
363 else if((memcmp(net->bssid, UNKNOWN_BORADCOM, 3)==0) ||
364 (memcmp(net->bssid, LINKSYSWRT330_LINKSYSWRT300_BROADCOM, 3)==0)||
365 (memcmp(net->bssid, LINKSYSWRT350_LINKSYSWRT150_BROADCOM, 3)==0)/*||
366 (memcmp(net->bssid, NETGEAR834Bv2_BROADCOM, 3)==0) */)
367 pHTInfo->IOTPeer = HT_IOT_PEER_BROADCOM;
368 else if((memcmp(net->bssid, BELKINF5D8233V1_RALINK, 3)==0) ||
369 (memcmp(net->bssid, BELKINF5D82334V3_RALINK, 3)==0) ||
370 (memcmp(net->bssid, PCI_RALINK, 3)==0) ||
371 (memcmp(net->bssid, EDIMAX_RALINK, 3)==0) ||
372 (memcmp(net->bssid, AIRLINK_RALINK, 3)==0) ||
373 net->ralink_cap_exist)
374 pHTInfo->IOTPeer = HT_IOT_PEER_RALINK;
375 else if((net->atheros_cap_exist )||
376 (memcmp(net->bssid, DLINK_ATHEROS_1, 3) == 0)||
377 (memcmp(net->bssid, DLINK_ATHEROS_2, 3) == 0))
378 pHTInfo->IOTPeer = HT_IOT_PEER_ATHEROS;
379 else if((memcmp(net->bssid, CISCO_BROADCOM, 3)==0)||net->cisco_cap_exist)
380 pHTInfo->IOTPeer = HT_IOT_PEER_CISCO;
381 else if ((memcmp(net->bssid, LINKSYS_MARVELL_4400N, 3) == 0) ||
382 net->marvell_cap_exist)
383 pHTInfo->IOTPeer = HT_IOT_PEER_MARVELL;
385 pHTInfo->IOTPeer = HT_IOT_PEER_UNKNOWN;
387 RTLLIB_DEBUG(RTLLIB_DL_IOT, "Joseph debug!! IOTPEER: %x\n", pHTInfo->IOTPeer);
390 u8 HTIOTActIsDisableMCS14(struct rtllib_device* ieee, u8* PeerMacAddr)
394 #if (HAL_CODE_BASE==RTL8192 && DEV_BUS_TYPE==USB_INTERFACE)
395 if((memcmp(PeerMacAddr, UNKNOWN_BORADCOM, 3)==0) ||
396 (memcmp(PeerMacAddr, LINKSYSWRT330_LINKSYSWRT300_BROADCOM, 3)==0)
403 if(pHTInfo->bCurrentRT2RTAggregation)
413 bool HTIOTActIsDisableMCS15(struct rtllib_device* ieee)
415 bool retValue = false;
417 #if defined(RTL8192U)
418 if(ieee->current_network.bssht.bdBandWidth == HT_CHANNEL_WIDTH_20_40)
428 bool HTIOTActIsDisableMCSTwoSpatialStream(struct rtllib_device* ieee)
430 bool retValue = false;
432 struct rtllib_network* net = &ieee->current_network;
434 if((ieee->pHTInfo->bCurrentHTSupport == true) && (ieee->pairwise_key_type == KEY_TYPE_CCMP))
436 if((memcmp(net->bssid, BELKINF5D8233V1_RALINK, 3)==0) ||
437 (memcmp(net->bssid, PCI_RALINK, 3)==0) ||
438 (memcmp(net->bssid, EDIMAX_RALINK, 3)==0))
444 #if defined(RTL8192SU) || defined RTL8192CE
445 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
446 if (ieee->rtllib_ap_sec_type &&
447 (ieee->rtllib_ap_sec_type(ieee)&(SEC_ALG_WEP|SEC_ALG_TKIP)))
449 if( (pHTInfo->IOTPeer != HT_IOT_PEER_ATHEROS) &&
450 (pHTInfo->IOTPeer != HT_IOT_PEER_UNKNOWN) &&
451 (pHTInfo->IOTPeer != HT_IOT_PEER_MARVELL) &&
452 (pHTInfo->IOTPeer != HT_IOT_PEER_REALTEK_92SE) &&
453 (pHTInfo->IOTPeer != HT_IOT_PEER_RALINK) )
456 #elif defined(RTL8192SE)
457 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
458 if (ieee->rtllib_ap_sec_type &&
459 (ieee->rtllib_ap_sec_type(ieee)&SEC_ALG_TKIP)) {
460 if(pHTInfo->IOTPeer == HT_IOT_PEER_RALINK){
468 u8 HTIOTActIsDisableEDCATurbo(struct rtllib_device* ieee, u8* PeerMacAddr)
474 if((memcmp(PeerMacAddr, UNKNOWN_BORADCOM, 3)==0)||
475 (memcmp(PeerMacAddr, LINKSYSWRT330_LINKSYSWRT300_BROADCOM, 3)==0)||
476 (memcmp(PeerMacAddr, LINKSYSWRT350_LINKSYSWRT150_BROADCOM, 3)==0))
487 bool HTIOTActIsEnableBETxOPLimit(struct rtllib_device* ieee)
489 bool retValue = false;
491 #if defined RTL8192SU
492 if(ieee->mode == IEEE_G)
494 #elif defined RTL8192CE
495 if(ieee->mode == IEEE_G ||
496 (ieee->rtllib_ap_sec_type(ieee)&(SEC_ALG_WEP|SEC_ALG_TKIP)))
504 u8 HTIOTActIsMgntUseCCK6M(struct rtllib_device* ieee,struct rtllib_network *network)
509 #if (defined RTL8192U || defined RTL8192E || defined RTL8190P)
511 if(ieee->pHTInfo->IOTPeer == HT_IOT_PEER_BROADCOM)
522 HTIOTActWAIOTBroadcom(struct rtllib_device* ieee)
524 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
528 pHTInfo->bWAIotBroadcom = false;
529 if(ieee->pHTInfo->IOTPeer == HT_IOT_PEER_BROADCOM)
531 if(ieee->current_network.bssht.bdBandWidth == HT_CHANNEL_WIDTH_20_40)
533 if(!(pHTInfo->bCurBW40MHz))
535 if(ieee->current_network.mode != WIRELESS_MODE_B)
537 pHTInfo->bWAIotBroadcom = true;
539 if(ieee->b_customer_lenovo_id == true)
542 if( ieee->current_network.RSSI >= boundary)
553 u8 HTIOTActIsForcedCTS2Self(struct rtllib_device *ieee, struct rtllib_network *network)
556 #if (defined RTL8192SE || defined RTL8192SU || defined RTL8192CE)
557 if((ieee->pHTInfo->IOTPeer == HT_IOT_PEER_MARVELL) ||(ieee->pHTInfo->IOTPeer == HT_IOT_PEER_ATHEROS) )
559 if(ieee->pHTInfo->IOTPeer == HT_IOT_PEER_MARVELL)
568 u8 HTIOTActIsForcedRTSCTS(struct rtllib_device *ieee, struct rtllib_network *network)
571 #if defined(RTL8192SE) || defined(RTL8192SU)
572 if(ieee->pHTInfo->bCurrentHTSupport)
574 if((ieee->pHTInfo->IOTPeer != HT_IOT_PEER_REALTEK)&&
575 (ieee->pHTInfo->IOTPeer != HT_IOT_PEER_REALTEK_92SE))
577 if((ieee->pHTInfo->IOTAction & HT_IOT_ACT_TX_NO_AGGREGATION) == 0)
586 HTIOTActIsForcedAMSDU8K(struct rtllib_device *ieee, struct rtllib_network *network)
593 u8 HTIOTActIsCCDFsync(struct rtllib_device *ieee)
596 #if (defined RTL8190P || defined RTL8192E || defined RTL8192U ||defined RTL8192SE)
597 if(ieee->pHTInfo->IOTPeer == HT_IOT_PEER_BROADCOM)
606 HTIOCActRejcectADDBARequest(struct rtllib_network *network)
609 #if (defined RTL8192SE || defined RTL8192SU || defined RTL8192CE)
621 HTIOTActIsEDCABiasRx(struct rtllib_device* ieee,struct rtllib_network *network)
625 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
627 if(pHTInfo->IOTPeer==HT_IOT_PEER_ATHEROS ||
628 pHTInfo->IOTPeer==HT_IOT_PEER_BROADCOM ||
629 pHTInfo->IOTPeer==HT_IOT_PEER_RALINK)
633 #elif defined RTL8192CE
634 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
636 if(pHTInfo->IOTPeer==HT_IOT_PEER_ATHEROS ||
637 pHTInfo->IOTPeer==HT_IOT_PEER_RALINK)
641 #elif defined RTL8192SE
642 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
644 if(ieee->rtllib_ap_sec_type != NULL)
645 if(ieee->rtllib_ap_sec_type(ieee) == SEC_ALG_CCMP)
646 if(pHTInfo->IOTPeer==HT_IOT_PEER_RALINK){
656 HTIOTActDisableShortGI(struct rtllib_device* ieee,struct rtllib_network *network)
659 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
661 if(pHTInfo->IOTPeer==HT_IOT_PEER_RALINK)
670 HTIOTActDisableHighPower(struct rtllib_device* ieee,struct rtllib_network *network)
673 #if (defined RTL8192SE || defined RTL8192SU || defined RTL8192CE)
674 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
678 if(pHTInfo->IOTPeer==HT_IOT_PEER_RALINK ||
679 pHTInfo->IOTPeer==HT_IOT_PEER_REALTEK ||
680 pHTInfo->IOTPeer==HT_IOT_PEER_REALTEK_92SE)
684 #elif defined RTL8192SE || defined RTL8192CE
685 if(pHTInfo->IOTPeer==HT_IOT_PEER_RALINK ||
686 pHTInfo->IOTPeer==HT_IOT_PEER_REALTEK )
695 HTIOTActDetermineRaFunc(struct rtllib_device* ieee, bool bPeerRx2ss)
697 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
698 pHTInfo->IOTRaFunc &= HT_IOT_RAFUNC_DISABLE_ALL;
700 if(pHTInfo->IOTPeer == HT_IOT_PEER_RALINK && !bPeerRx2ss)
701 pHTInfo->IOTRaFunc |= HT_IOT_RAFUNC_PEER_1R;
703 if(pHTInfo->IOTAction & HT_IOT_ACT_AMSDU_ENABLE)
704 pHTInfo->IOTRaFunc |= HT_IOT_RAFUNC_TX_AMSDU;
710 HTIOTActIsDisableTx40MHz(struct rtllib_device* ieee,struct rtllib_network *network)
714 #if (defined RTL8192SU || defined RTL8192SE || defined RTL8192CE)
715 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
716 if( (KEY_TYPE_WEP104 == ieee->pairwise_key_type) ||
717 (KEY_TYPE_WEP40 == ieee->pairwise_key_type) ||
718 (KEY_TYPE_WEP104 == ieee->group_key_type) ||
719 (KEY_TYPE_WEP40 == ieee->group_key_type) ||
720 (KEY_TYPE_TKIP == ieee->pairwise_key_type) )
722 if((pHTInfo->IOTPeer==HT_IOT_PEER_REALTEK) && (network->bssht.bdSupportHT))
731 HTIOTActIsTxNoAggregation(struct rtllib_device* ieee,struct rtllib_network *network)
735 #if (defined RTL8192SU || defined RTL8192SE || defined RTL8192CE)
736 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
737 if( (KEY_TYPE_WEP104 == ieee->pairwise_key_type) ||
738 (KEY_TYPE_WEP40 == ieee->pairwise_key_type) ||
739 (KEY_TYPE_WEP104 == ieee->group_key_type) ||
740 (KEY_TYPE_WEP40 == ieee->group_key_type) ||
741 (KEY_TYPE_TKIP == ieee->pairwise_key_type) )
743 if(pHTInfo->IOTPeer==HT_IOT_PEER_REALTEK)
753 HTIOTActIsDisableTx2SS(struct rtllib_device* ieee,struct rtllib_network *network)
757 #if (defined RTL8192SU || defined RTL8192SE || defined RTL8192CE)
758 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
759 if( (KEY_TYPE_WEP104 == ieee->pairwise_key_type) ||
760 (KEY_TYPE_WEP40 == ieee->pairwise_key_type) ||
761 (KEY_TYPE_WEP104 == ieee->group_key_type) ||
762 (KEY_TYPE_WEP40 == ieee->group_key_type) ||
763 (KEY_TYPE_TKIP == ieee->pairwise_key_type) )
765 if((pHTInfo->IOTPeer==HT_IOT_PEER_REALTEK) && (network->bssht.bdSupportHT))
774 bool HTIOCActIsDisableCckRate(struct rtllib_device* ieee,struct rtllib_network *network)
776 bool retValue = false;
777 #if defined(RTL8192SU)
778 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
779 if(pHTInfo->IOTPeer == HT_IOT_PEER_BROADCOM)
781 if((memcmp(network->bssid, NETGEAR_BROADCOM, 3)==0)
782 && (network->bssht.bdBandWidth == HT_CHANNEL_WIDTH_20_40))
790 bool HTIOCActAllowPeerAggOnePacket(struct rtllib_device* ieee,struct rtllib_network *network)
792 bool retValue = false;
793 #if defined(RTL8192SE) || defined(RTL8192SU)
794 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
796 if(ieee->VersionID<2)
797 if(pHTInfo->IOTPeer == HT_IOT_PEER_MARVELL)
806 HTIOTActIsNullDataPowerSaving(struct rtllib_device* ieee,struct rtllib_network *network)
808 bool retValue = false;
809 #if defined(RTL8192SE) || defined(RTL8192SU)
810 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
812 if(pHTInfo->IOTPeer == HT_IOT_PEER_BROADCOM)
820 void HTResetIOTSetting(
821 PRT_HIGH_THROUGHPUT pHTInfo
824 pHTInfo->IOTAction = 0;
825 pHTInfo->IOTPeer = HT_IOT_PEER_UNKNOWN;
826 pHTInfo->IOTRaFunc = 0;
830 #ifdef _RTL8192_EXT_PATCH_
831 void HTConstructCapabilityElement(struct rtllib_device* ieee, u8* posHTCap, u8* len, u8 IsEncrypt, u8 bIsBcn)
833 void HTConstructCapabilityElement(struct rtllib_device* ieee, u8* posHTCap, u8* len, u8 IsEncrypt)
836 PRT_HIGH_THROUGHPUT pHT = ieee->pHTInfo;
837 PHT_CAPABILITY_ELE pCapELE = NULL;
839 if ((posHTCap == NULL) || (pHT == NULL))
841 RTLLIB_DEBUG(RTLLIB_DL_ERR, "posHTCap or pHTInfo can't be null in HTConstructCapabilityElement()\n");
844 memset(posHTCap, 0, *len);
845 if(pHT->ePeerHTSpecVer == HT_SPEC_VER_EWC)
847 u8 EWC11NHTCap[] = {0x00, 0x90, 0x4c, 0x33};
848 memcpy(posHTCap, EWC11NHTCap, sizeof(EWC11NHTCap));
849 pCapELE = (PHT_CAPABILITY_ELE)&(posHTCap[4]);
852 pCapELE = (PHT_CAPABILITY_ELE)posHTCap;
855 pCapELE->AdvCoding = 0;
856 if(ieee->GetHalfNmodeSupportByAPsHandler(ieee->dev))
858 pCapELE->ChlWidth = 0;
862 #ifdef _RTL8192_EXT_PATCH_
864 pCapELE->ChlWidth = (pHT->bCurBW40MHz?1:0);
867 pCapELE->ChlWidth = (pHT->bRegBW40MHz?1:0);
870 pCapELE->MimoPwrSave = pHT->SelfMimoPs;
871 pCapELE->GreenField = 0;
872 pCapELE->ShortGI20Mhz = 1;
873 pCapELE->ShortGI40Mhz = 1;
879 pCapELE->DelayBA = 0;
880 pCapELE->MaxAMSDUSize = (MAX_RECEIVE_BUFFER_SIZE>=7935)?1:0;
881 pCapELE->DssCCk = ((pHT->bRegBW40MHz)?(pHT->bRegSuppCCK?1:0):0);
883 pCapELE->LSigTxopProtect = 0;
886 RTLLIB_DEBUG(RTLLIB_DL_HT, "TX HT cap/info ele BW=%d MaxAMSDUSize:%d DssCCk:%d\n", pCapELE->ChlWidth, pCapELE->MaxAMSDUSize, pCapELE->DssCCk);
890 pCapELE->MPDUDensity = 7;
891 pCapELE->MaxRxAMPDUFactor = 2;
895 pCapELE->MaxRxAMPDUFactor = 3;
896 pCapELE->MPDUDensity = 0;
899 memcpy(pCapELE->MCS, ieee->Regdot11HTOperationalRateSet, 16);
900 if(pHT->IOTAction & HT_IOT_ACT_DISABLE_MCS15)
901 pCapELE->MCS[1] &= 0x7f;
903 if(pHT->IOTAction & HT_IOT_ACT_DISABLE_MCS14)
904 pCapELE->MCS[1] &= 0xbf;
906 if(pHT->IOTAction & HT_IOT_ACT_DISABLE_ALL_2SS)
907 pCapELE->MCS[1] &= 0x00;
909 if(ieee->GetHalfNmodeSupportByAPsHandler(ieee->dev))
912 for(i = 1; i< 16; i++)
916 memset(&pCapELE->ExtHTCapInfo, 0, 2);
919 memset(pCapELE->TxBFCap, 0, 4);
922 if(pHT->ePeerHTSpecVer == HT_SPEC_VER_EWC)
933 void HTConstructInfoElement(struct rtllib_device* ieee, u8* posHTInfo, u8* len, u8 IsEncrypt)
935 PRT_HIGH_THROUGHPUT pHT = ieee->pHTInfo;
936 PHT_INFORMATION_ELE pHTInfoEle = (PHT_INFORMATION_ELE)posHTInfo;
937 if ((posHTInfo == NULL) || (pHTInfoEle == NULL))
939 RTLLIB_DEBUG(RTLLIB_DL_ERR, "posHTInfo or pHTInfoEle can't be null in HTConstructInfoElement()\n");
943 memset(posHTInfo, 0, *len);
944 #ifdef _RTL8192_EXT_PATCH_
945 if ((ieee->iw_mode == IW_MODE_ADHOC) || (ieee->iw_mode == IW_MODE_MASTER) ||(ieee->iw_mode == IW_MODE_MESH) )
947 if ( (ieee->iw_mode == IW_MODE_ADHOC) || (ieee->iw_mode == IW_MODE_MASTER))
950 pHTInfoEle->ControlChl = ieee->current_network.channel;
951 #ifdef _RTL8192_EXT_PATCH_
952 if((!ieee->only_mesh) && (ieee->iw_mode == IW_MODE_MESH) && (ieee->state == RTLLIB_LINKED))
953 pHTInfoEle->ExtChlOffset = ((pHT->bRegBW40MHz == false)?HT_EXTCHNL_OFFSET_NO_EXT:
954 ieee->APExtChlOffset);
955 else if(ieee->iw_mode == IW_MODE_MESH)
956 pHTInfoEle->ExtChlOffset = ((pHT->bRegBW40MHz == false)?HT_EXTCHNL_OFFSET_NO_EXT:
957 (ieee->current_mesh_network.channel<=6)?
958 HT_EXTCHNL_OFFSET_UPPER:HT_EXTCHNL_OFFSET_LOWER);
961 pHTInfoEle->ExtChlOffset = ((pHT->bRegBW40MHz == false)?HT_EXTCHNL_OFFSET_NO_EXT:
962 (ieee->current_network.channel<=6)?
963 HT_EXTCHNL_OFFSET_UPPER:HT_EXTCHNL_OFFSET_LOWER);
964 pHTInfoEle->RecommemdedTxWidth = pHT->bRegBW40MHz;
965 pHTInfoEle->RIFS = 0;
966 pHTInfoEle->PSMPAccessOnly = 0;
967 pHTInfoEle->SrvIntGranularity = 0;
968 pHTInfoEle->OptMode = pHT->CurrentOpMode;
969 pHTInfoEle->NonGFDevPresent = 0;
970 pHTInfoEle->DualBeacon = 0;
971 pHTInfoEle->SecondaryBeacon = 0;
972 pHTInfoEle->LSigTxopProtectFull = 0;
973 pHTInfoEle->PcoActive = 0;
974 pHTInfoEle->PcoPhase = 0;
976 memset(pHTInfoEle->BasicMSC, 0, 16);
989 void HTConstructRT2RTAggElement(struct rtllib_device* ieee, u8* posRT2RTAgg, u8* len)
991 if (posRT2RTAgg == NULL) {
992 RTLLIB_DEBUG(RTLLIB_DL_ERR, "posRT2RTAgg can't be null in HTConstructRT2RTAggElement()\n");
995 memset(posRT2RTAgg, 0, *len);
996 *posRT2RTAgg++ = 0x00;
997 *posRT2RTAgg++ = 0xe0;
998 *posRT2RTAgg++ = 0x4c;
999 *posRT2RTAgg++ = 0x02;
1000 *posRT2RTAgg++ = 0x01;
1003 *posRT2RTAgg = 0x70;
1005 *posRT2RTAgg = 0x10;
1008 if(ieee->bSupportRemoteWakeUp) {
1009 *posRT2RTAgg |= RT_HT_CAP_USE_WOW;
1017 posRT2RTAgg->Length = 6;
1025 u8 HT_PickMCSRate(struct rtllib_device* ieee, u8* pOperateMCS)
1028 if (pOperateMCS == NULL)
1030 RTLLIB_DEBUG(RTLLIB_DL_ERR, "pOperateMCS can't be null in HT_PickMCSRate()\n");
1048 pOperateMCS[0] &=RATE_ADPT_1SS_MASK;
1049 pOperateMCS[1] &=RATE_ADPT_2SS_MASK;
1050 pOperateMCS[3] &=RATE_ADPT_MCS32_MASK;
1062 u8 HTGetHighestMCSRate(struct rtllib_device* ieee, u8* pMCSRateSet, u8* pMCSFilter)
1067 u8 availableMcsRate[16];
1068 if (pMCSRateSet == NULL || pMCSFilter == NULL)
1070 RTLLIB_DEBUG(RTLLIB_DL_ERR, "pMCSRateSet or pMCSFilter can't be null in HTGetHighestMCSRate()\n");
1074 availableMcsRate[i] = pMCSRateSet[i] & pMCSFilter[i];
1076 for(i = 0; i < 16; i++)
1078 if(availableMcsRate[i] != 0)
1084 for(i = 0; i < 16; i++)
1086 if(availableMcsRate[i] != 0)
1088 bitMap = availableMcsRate[i];
1089 for(j = 0; j < 8; j++)
1093 if(HTMcsToDataRate(ieee, (8*i+j)) > HTMcsToDataRate(ieee, mcsRate))
1100 return (mcsRate|0x80);
1103 u8 HTFilterMCSRate( struct rtllib_device* ieee, u8* pSupportMCS, u8* pOperateMCS)
1109 pOperateMCS[i] = ieee->Regdot11TxHTOperationalRateSet[i]&pSupportMCS[i];
1114 HT_PickMCSRate(ieee, pOperateMCS);
1116 if(ieee->GetHalfNmodeSupportByAPsHandler(ieee->dev))
1119 for(i=2; i<=15; i++)
1124 void HTSetConnectBwMode(struct rtllib_device* ieee, HT_CHANNEL_WIDTH Bandwidth, HT_EXTCHNL_OFFSET Offset);
1125 void HTOnAssocRsp(struct rtllib_device *ieee)
1127 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
1128 PHT_CAPABILITY_ELE pPeerHTCap = NULL;
1129 PHT_INFORMATION_ELE pPeerHTInfo = NULL;
1130 u16 nMaxAMSDUSize = 0;
1131 u8* pMcsFilter = NULL;
1133 static u8 EWC11NHTCap[] = {0x00, 0x90, 0x4c, 0x33};
1134 static u8 EWC11NHTInfo[] = {0x00, 0x90, 0x4c, 0x34};
1136 if( pHTInfo->bCurrentHTSupport == false )
1138 RTLLIB_DEBUG(RTLLIB_DL_ERR, "<=== HTOnAssocRsp(): HT_DISABLE\n");
1141 RTLLIB_DEBUG(RTLLIB_DL_HT, "===> HTOnAssocRsp_wq(): HT_ENABLE\n");
1143 if(!memcmp(pHTInfo->PeerHTCapBuf,EWC11NHTCap, sizeof(EWC11NHTCap)))
1144 pPeerHTCap = (PHT_CAPABILITY_ELE)(&pHTInfo->PeerHTCapBuf[4]);
1146 pPeerHTCap = (PHT_CAPABILITY_ELE)(pHTInfo->PeerHTCapBuf);
1148 if(!memcmp(pHTInfo->PeerHTInfoBuf, EWC11NHTInfo, sizeof(EWC11NHTInfo)))
1149 pPeerHTInfo = (PHT_INFORMATION_ELE)(&pHTInfo->PeerHTInfoBuf[4]);
1151 pPeerHTInfo = (PHT_INFORMATION_ELE)(pHTInfo->PeerHTInfoBuf);
1153 #ifdef _RTL8192_EXT_PATCH_
1154 ieee->APExtChlOffset = (HT_EXTCHNL_OFFSET)(pPeerHTInfo->ExtChlOffset);
1156 RTLLIB_DEBUG_DATA(RTLLIB_DL_DATA|RTLLIB_DL_HT, pPeerHTCap, sizeof(HT_CAPABILITY_ELE));
1157 HTSetConnectBwMode(ieee, (HT_CHANNEL_WIDTH)(pPeerHTCap->ChlWidth), (HT_EXTCHNL_OFFSET)(pPeerHTInfo->ExtChlOffset));
1158 #if defined RTL8192SE || defined RTL8192SU || defined RTL8192CE
1159 if(pHTInfo->bCurBW40MHz == true)
1161 pHTInfo->bCurTxBW40MHz = ((pPeerHTInfo->RecommemdedTxWidth == 1)?true:false);
1163 pHTInfo->bCurShortGI20MHz=
1164 ((pHTInfo->bRegShortGI20MHz)?((pPeerHTCap->ShortGI20Mhz==1)?true:false):false);
1165 pHTInfo->bCurShortGI40MHz=
1166 ((pHTInfo->bRegShortGI40MHz)?((pPeerHTCap->ShortGI40Mhz==1)?true:false):false);
1168 pHTInfo->bCurSuppCCK =
1169 ((pHTInfo->bRegSuppCCK)?((pPeerHTCap->DssCCk==1)?true:false):false);
1172 pHTInfo->bCurrent_AMSDU_Support = pHTInfo->bAMSDU_Support;
1174 nMaxAMSDUSize = (pPeerHTCap->MaxAMSDUSize==0)?3839:7935;
1176 if(pHTInfo->nAMSDU_MaxSize > nMaxAMSDUSize )
1177 pHTInfo->nCurrent_AMSDU_MaxSize = nMaxAMSDUSize;
1179 pHTInfo->nCurrent_AMSDU_MaxSize = pHTInfo->nAMSDU_MaxSize;
1181 pHTInfo->bCurrentAMPDUEnable = pHTInfo->bAMPDUEnable;
1182 if (ieee->rtllib_ap_sec_type &&
1183 (ieee->rtllib_ap_sec_type(ieee)&(SEC_ALG_WEP|SEC_ALG_TKIP))){
1184 if( (pHTInfo->IOTPeer== HT_IOT_PEER_ATHEROS) ||
1185 (pHTInfo->IOTPeer == HT_IOT_PEER_UNKNOWN) )
1186 pHTInfo->bCurrentAMPDUEnable = false;
1189 if(!pHTInfo->bRegRT2RTAggregation)
1191 if(pHTInfo->AMPDU_Factor > pPeerHTCap->MaxRxAMPDUFactor)
1192 pHTInfo->CurrentAMPDUFactor = pPeerHTCap->MaxRxAMPDUFactor;
1194 pHTInfo->CurrentAMPDUFactor = pHTInfo->AMPDU_Factor;
1198 osTmp= PacketGetElement( asocpdu, EID_Vendor, OUI_SUB_REALTEK_AGG, OUI_SUBTYPE_DONT_CARE);
1199 if(osTmp.Length >= 5)
1201 if (ieee->current_network.bssht.bdRT2RTAggregation)
1203 if( ieee->pairwise_key_type != KEY_TYPE_NA)
1204 pHTInfo->CurrentAMPDUFactor = pPeerHTCap->MaxRxAMPDUFactor;
1206 pHTInfo->CurrentAMPDUFactor = HT_AGG_SIZE_64K;
1209 if(pPeerHTCap->MaxRxAMPDUFactor < HT_AGG_SIZE_32K)
1210 pHTInfo->CurrentAMPDUFactor = pPeerHTCap->MaxRxAMPDUFactor;
1212 pHTInfo->CurrentAMPDUFactor = HT_AGG_SIZE_32K;
1217 if(pHTInfo->MPDU_Density > pPeerHTCap->MPDUDensity)
1218 pHTInfo->CurrentMPDUDensity = pHTInfo->MPDU_Density;
1220 pHTInfo->CurrentMPDUDensity = pPeerHTCap->MPDUDensity;
1221 if(ieee->pairwise_key_type != KEY_TYPE_NA )
1222 pHTInfo->CurrentMPDUDensity = 7;
1224 if(pHTInfo->MPDU_Density > pPeerHTCap->MPDUDensity)
1225 pHTInfo->CurrentMPDUDensity = pHTInfo->MPDU_Density;
1227 pHTInfo->CurrentMPDUDensity = pPeerHTCap->MPDUDensity;
1229 #if (defined RTL8192SE || defined RTL8192SU || defined RTL8192CE)
1230 if(ieee->SetHwRegHandler != NULL) {
1231 ieee->SetHwRegHandler( ieee->dev, HW_VAR_SHORTGI_DENSITY, (u8*)(&ieee->MaxMssDensity));
1232 ieee->SetHwRegHandler(ieee->dev, HW_VAR_AMPDU_FACTOR, &pHTInfo->CurrentAMPDUFactor);
1233 ieee->SetHwRegHandler(ieee->dev, HW_VAR_AMPDU_MIN_SPACE, &pHTInfo->CurrentMPDUDensity);
1235 #elif defined RTL8192CE
1236 if(ieee->SetHwRegHandler != NULL) {
1237 ieee->SetHwRegHandler(ieee->dev, HW_VAR_AMPDU_FACTOR, &pHTInfo->CurrentAMPDUFactor);
1238 ieee->SetHwRegHandler(ieee->dev, HW_VAR_AMPDU_MIN_SPACE, &pHTInfo->CurrentMPDUDensity);
1242 if(pHTInfo->IOTAction & HT_IOT_ACT_TX_USE_AMSDU_8K)
1247 pHTInfo->bCurrentAMPDUEnable = false;
1248 pHTInfo->ForcedAMSDUMode = HT_AGG_FORCE_ENABLE;
1249 pHTInfo->ForcedAMSDUMaxSize = 7935;
1251 pHTInfo->bCurRxReorderEnable = pHTInfo->bRegRxReorderEnable;
1254 if(pPeerHTCap->MCS[0] == 0)
1255 pPeerHTCap->MCS[0] = 0xff;
1257 HTIOTActDetermineRaFunc(ieee, ((pPeerHTCap->MCS[1])!=0));
1259 HTFilterMCSRate(ieee, pPeerHTCap->MCS, ieee->dot11HTOperationalRateSet);
1261 pHTInfo->PeerMimoPs = pPeerHTCap->MimoPwrSave;
1262 if(pHTInfo->PeerMimoPs == MIMO_PS_STATIC)
1263 pMcsFilter = MCS_FILTER_1SS;
1265 pMcsFilter = MCS_FILTER_ALL;
1266 ieee->HTHighestOperaRate = HTGetHighestMCSRate(ieee, ieee->dot11HTOperationalRateSet, pMcsFilter);
1267 ieee->HTCurrentOperaRate = ieee->HTHighestOperaRate;
1269 pHTInfo->CurrentOpMode = pPeerHTInfo->OptMode;
1273 void HTSetConnectBwModeCallback(struct rtllib_device* ieee);
1274 void HTInitializeHTInfo(struct rtllib_device* ieee)
1276 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
1278 RTLLIB_DEBUG(RTLLIB_DL_HT, "===========>%s()\n", __FUNCTION__);
1279 pHTInfo->bCurrentHTSupport = false;
1281 pHTInfo->bCurBW40MHz = false;
1282 pHTInfo->bCurTxBW40MHz = false;
1284 pHTInfo->bCurShortGI20MHz = false;
1285 pHTInfo->bCurShortGI40MHz = false;
1286 pHTInfo->bForcedShortGI = false;
1288 pHTInfo->bCurSuppCCK = true;
1290 pHTInfo->bCurrent_AMSDU_Support = false;
1291 pHTInfo->nCurrent_AMSDU_MaxSize = pHTInfo->nAMSDU_MaxSize;
1292 #ifdef _RTL8192_EXT_PATCH_
1293 pHTInfo->bCurrent_Mesh_AMSDU_Support = true;
1295 pHTInfo->CurrentMPDUDensity = pHTInfo->MPDU_Density;
1296 pHTInfo->CurrentAMPDUFactor = pHTInfo->AMPDU_Factor;
1298 memset((void*)(&(pHTInfo->SelfHTCap)), 0, sizeof(pHTInfo->SelfHTCap));
1299 memset((void*)(&(pHTInfo->SelfHTInfo)), 0, sizeof(pHTInfo->SelfHTInfo));
1300 memset((void*)(&(pHTInfo->PeerHTCapBuf)), 0, sizeof(pHTInfo->PeerHTCapBuf));
1301 memset((void*)(&(pHTInfo->PeerHTInfoBuf)), 0, sizeof(pHTInfo->PeerHTInfoBuf));
1303 pHTInfo->bSwBwInProgress = false;
1304 pHTInfo->ChnlOp = CHNLOP_NONE;
1306 pHTInfo->ePeerHTSpecVer = HT_SPEC_VER_IEEE;
1308 pHTInfo->bCurrentRT2RTAggregation = false;
1309 pHTInfo->bCurrentRT2RTLongSlotTime = false;
1310 pHTInfo->RT2RT_HT_Mode = (RT_HT_CAPBILITY)0;
1312 pHTInfo->IOTPeer = 0;
1313 pHTInfo->IOTAction = 0;
1314 pHTInfo->IOTRaFunc = 0;
1317 u8* RegHTSuppRateSets = &(ieee->RegHTSuppRateSet[0]);
1318 RegHTSuppRateSets[0] = 0xFF;
1319 RegHTSuppRateSets[1] = 0xFF;
1320 RegHTSuppRateSets[4] = 0x01;
1323 void HTInitializeBssDesc(PBSS_HT pBssHT)
1326 pBssHT->bdSupportHT = false;
1327 memset(pBssHT->bdHTCapBuf, 0, sizeof(pBssHT->bdHTCapBuf));
1328 pBssHT->bdHTCapLen = 0;
1329 memset(pBssHT->bdHTInfoBuf, 0, sizeof(pBssHT->bdHTInfoBuf));
1330 pBssHT->bdHTInfoLen = 0;
1332 pBssHT->bdHTSpecVer= HT_SPEC_VER_IEEE;
1334 pBssHT->bdRT2RTAggregation = false;
1335 pBssHT->bdRT2RTLongSlotTime = false;
1336 pBssHT->RT2RT_HT_Mode = (RT_HT_CAPBILITY)0;
1339 void HTResetSelfAndSavePeerSetting(struct rtllib_device* ieee, struct rtllib_network * pNetwork)
1341 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
1344 RTLLIB_DEBUG(RTLLIB_DL_HT, "==============>%s()\n", __FUNCTION__);
1345 /*unmark bEnableHT flag here is the same reason why unmarked in function rtllib_softmac_new_net. WB 2008.09.10*/
1346 if (pNetwork->bssht.bdSupportHT)
1348 pHTInfo->bCurrentHTSupport = true;
1349 pHTInfo->ePeerHTSpecVer = pNetwork->bssht.bdHTSpecVer;
1351 if(pNetwork->bssht.bdHTCapLen > 0 && pNetwork->bssht.bdHTCapLen <= sizeof(pHTInfo->PeerHTCapBuf))
1352 memcpy(pHTInfo->PeerHTCapBuf, pNetwork->bssht.bdHTCapBuf, pNetwork->bssht.bdHTCapLen);
1354 if(pNetwork->bssht.bdHTInfoLen > 0 && pNetwork->bssht.bdHTInfoLen <= sizeof(pHTInfo->PeerHTInfoBuf))
1355 memcpy(pHTInfo->PeerHTInfoBuf, pNetwork->bssht.bdHTInfoBuf, pNetwork->bssht.bdHTInfoLen);
1357 if(pHTInfo->bRegRT2RTAggregation)
1359 pHTInfo->bCurrentRT2RTAggregation = pNetwork->bssht.bdRT2RTAggregation;
1360 pHTInfo->bCurrentRT2RTLongSlotTime = pNetwork->bssht.bdRT2RTLongSlotTime;
1361 pHTInfo->RT2RT_HT_Mode = pNetwork->bssht.RT2RT_HT_Mode;
1365 pHTInfo->bCurrentRT2RTAggregation = false;
1366 pHTInfo->bCurrentRT2RTLongSlotTime = false;
1367 pHTInfo->RT2RT_HT_Mode = (RT_HT_CAPBILITY)0;
1370 HTIOTPeerDetermine(ieee);
1372 pHTInfo->IOTAction = 0;
1373 bIOTAction = HTIOTActIsDisableMCS14(ieee, pNetwork->bssid);
1375 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_MCS14;
1377 bIOTAction = HTIOTActIsDisableMCS15(ieee);
1379 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_MCS15;
1381 bIOTAction = HTIOTActIsDisableMCSTwoSpatialStream(ieee);
1383 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_ALL_2SS;
1386 bIOTAction = HTIOTActIsDisableEDCATurbo(ieee, pNetwork->bssid);
1388 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_EDCA_TURBO;
1390 #if defined(RTL8190P) || defined(RTL8192E) || defined(RTL8192U)
1391 bIOTAction = HTIOTActIsMgntUseCCK6M(ieee,pNetwork);
1393 pHTInfo->IOTAction |= HT_IOT_ACT_MGNT_USE_CCK_6M;
1394 #elif defined(RTL8192SE) || defined(RTL8192SU) || defined RTL8192CE
1395 bIOTAction = HTIOTActWAIOTBroadcom(ieee);
1398 pHTInfo->IOTAction |= HT_IOT_ACT_WA_IOT_Broadcom;
1401 bIOTAction = HTIOTActIsCCDFsync(ieee);
1403 pHTInfo->IOTAction |= HT_IOT_ACT_CDD_FSYNC;
1404 #if defined(RTL8192SU) || defined(RTL8192SE) || defined RTL8192CE
1405 bIOTAction = HTIOTActIsForcedCTS2Self(ieee,pNetwork);
1407 pHTInfo->IOTAction |= HT_IOT_ACT_FORCED_CTS2SELF;
1410 bIOTAction = HTIOTActIsEnableBETxOPLimit(ieee);
1412 pHTInfo->IOTAction |= HT_IOT_ACT_FORCED_ENABLE_BE_TXOP;
1414 #if defined(RTL8192SU)
1415 bIOTAction = HTIOCActRejcectADDBARequest(pNetwork);
1417 pHTInfo->IOTAction |= HT_IOT_ACT_REJECT_ADDBA_REQ;
1420 bIOTAction = HTIOCActAllowPeerAggOnePacket(ieee, pNetwork);
1422 pHTInfo->IOTAction |= HT_IOT_ACT_ALLOW_PEER_AGG_ONE_PKT;
1424 bIOTAction = HTIOTActIsEDCABiasRx(ieee, pNetwork);
1426 pHTInfo->IOTAction |= HT_IOT_ACT_EDCA_BIAS_ON_RX;
1428 #if defined(RTL8192SU)
1429 bIOTAction = HTIOCActIsDisableCckRate(ieee, pNetwork);
1431 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_CCK_RATE;
1433 bIOTAction = HTIOTActDisableShortGI(ieee, pNetwork);
1435 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_SHORT_GI;
1437 bIOTAction = HTIOTActDisableHighPower(ieee, pNetwork);
1439 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_HIGH_POWER;
1442 bIOTAction = HTIOTActIsForcedAMSDU8K(ieee, pNetwork);
1444 pHTInfo->IOTAction |= HT_IOT_ACT_TX_USE_AMSDU_8K;
1446 #if defined(RTL8192SU)
1447 bIOTAction = HTIOTActIsTxNoAggregation(ieee, pNetwork);
1449 pHTInfo->IOTAction |= HT_IOT_ACT_TX_NO_AGGREGATION;
1451 bIOTAction = HTIOTActIsDisableTx40MHz(ieee, pNetwork);
1453 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_TX_40_MHZ;
1455 bIOTAction = HTIOTActIsDisableTx2SS(ieee, pNetwork);
1457 pHTInfo->IOTAction |= HT_IOT_ACT_DISABLE_TX_2SS;
1460 bIOTAction = HTIOTActIsForcedRTSCTS(ieee, pNetwork);
1462 pHTInfo->IOTAction |= HT_IOT_ACT_FORCED_RTS;
1464 bIOTAction = HTIOTActIsNullDataPowerSaving(ieee, pNetwork);
1466 pHTInfo->IOTAction |= HT_IOT_ACT_NULL_DATA_POWER_SAVING;
1471 pHTInfo->bCurrentHTSupport = false;
1472 pHTInfo->bCurrentRT2RTAggregation = false;
1473 pHTInfo->bCurrentRT2RTLongSlotTime = false;
1474 pHTInfo->RT2RT_HT_Mode = (RT_HT_CAPBILITY)0;
1476 pHTInfo->IOTAction = 0;
1477 pHTInfo->IOTRaFunc = 0;
1482 void HTUpdateSelfAndPeerSetting(struct rtllib_device* ieee, struct rtllib_network * pNetwork)
1484 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
1485 PHT_INFORMATION_ELE pPeerHTInfo = (PHT_INFORMATION_ELE)pNetwork->bssht.bdHTInfoBuf;
1487 if(pHTInfo->bCurrentHTSupport)
1489 if(pNetwork->bssht.bdHTInfoLen != 0)
1490 pHTInfo->CurrentOpMode = pPeerHTInfo->OptMode;
1495 void HTUseDefaultSetting(struct rtllib_device* ieee)
1497 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
1499 if(pHTInfo->bEnableHT)
1501 pHTInfo->bCurrentHTSupport = true;
1502 pHTInfo->bCurSuppCCK = pHTInfo->bRegSuppCCK;
1504 pHTInfo->bCurBW40MHz = pHTInfo->bRegBW40MHz;
1506 pHTInfo->bCurShortGI20MHz= pHTInfo->bRegShortGI20MHz;
1508 pHTInfo->bCurShortGI40MHz= pHTInfo->bRegShortGI40MHz;
1509 #ifdef _RTL8192_EXT_PATCH_
1510 ieee->current_mesh_network.qos_data.supported = 1;
1511 ieee->current_mesh_network.qos_data.active = ieee->current_mesh_network.qos_data.supported;
1515 if(ieee->iw_mode == IW_MODE_ADHOC)
1517 ieee->current_network.qos_data.supported = 1;
1518 ieee->current_network.qos_data.active = ieee->current_network.qos_data.supported;
1519 pHTInfo->bCurrent_AMSDU_Support = 1;
1521 #ifdef _RTL8192_EXT_PATCH_
1522 else if(ieee->iw_mode == IW_MODE_MESH)
1524 pHTInfo->bCurrent_Mesh_AMSDU_Support = 1;
1525 pHTInfo->bCurrent_AMSDU_Support = pHTInfo->bAMSDU_Support;
1529 pHTInfo->bCurrent_AMSDU_Support = pHTInfo->bAMSDU_Support;
1531 pHTInfo->bCurrent_AMSDU_Support = pHTInfo->bAMSDU_Support;
1533 pHTInfo->nCurrent_AMSDU_MaxSize = pHTInfo->nAMSDU_MaxSize;
1536 if(ieee->iw_mode == IW_MODE_ADHOC)
1537 pHTInfo->bCurrentAMPDUEnable = 0;
1538 #ifdef _RTL8192_EXT_PATCH_
1539 else if(ieee->iw_mode == IW_MODE_MESH)
1541 pHTInfo->bCurrentMeshAMPDUEnable = 0;
1542 pHTInfo->bCurrentAMPDUEnable = pHTInfo->bAMPDUEnable;
1546 pHTInfo->bCurrentAMPDUEnable = pHTInfo->bAMPDUEnable;
1548 pHTInfo->bCurrentAMPDUEnable = pHTInfo->bAMPDUEnable;
1550 pHTInfo->CurrentAMPDUFactor = pHTInfo->AMPDU_Factor;
1552 pHTInfo->CurrentMPDUDensity = pHTInfo->CurrentMPDUDensity;
1555 HTFilterMCSRate(ieee, ieee->Regdot11TxHTOperationalRateSet, ieee->dot11HTOperationalRateSet);
1557 Adapter->HalFunc.InitHalRATRTableHandler( Adapter, &pMgntInfo->dot11OperationalRateSet, pMgntInfo->dot11HTOperationalRateSet);
1559 ieee->HTHighestOperaRate = HTGetHighestMCSRate(ieee, ieee->dot11HTOperationalRateSet, MCS_FILTER_ALL);
1560 ieee->HTCurrentOperaRate = ieee->HTHighestOperaRate;
1562 #if (defined RTL8192SE || defined RTL8192SU || defined RTL8192CE)
1563 if(ieee->SetHwRegHandler != NULL) {
1564 ieee->SetHwRegHandler( ieee->dev, HW_VAR_SHORTGI_DENSITY, (u8*)(&ieee->MaxMssDensity));
1565 ieee->SetHwRegHandler(ieee->dev, HW_VAR_AMPDU_FACTOR, &pHTInfo->CurrentAMPDUFactor);
1566 ieee->SetHwRegHandler(ieee->dev, HW_VAR_AMPDU_MIN_SPACE, &pHTInfo->CurrentMPDUDensity);
1573 pHTInfo->bCurrentHTSupport = false;
1577 u8 HTCCheck(struct rtllib_device* ieee, u8* pFrame)
1579 if(ieee->pHTInfo->bCurrentHTSupport)
1581 if( (IsQoSDataFrame(pFrame) && Frame_Order(pFrame)) == 1)
1583 RTLLIB_DEBUG(RTLLIB_DL_HT, "HT CONTROL FILED EXIST!!\n");
1590 void HTSetConnectBwMode(struct rtllib_device* ieee, HT_CHANNEL_WIDTH Bandwidth, HT_EXTCHNL_OFFSET Offset)
1592 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
1594 if(pHTInfo->bRegBW40MHz == false)
1597 if(ieee->GetHalfNmodeSupportByAPsHandler(ieee->dev))
1598 Bandwidth=HT_CHANNEL_WIDTH_20;
1601 if(pHTInfo->bSwBwInProgress) {
1604 if(Bandwidth==HT_CHANNEL_WIDTH_20_40)
1606 if(ieee->current_network.channel<2 && Offset==HT_EXTCHNL_OFFSET_LOWER)
1607 Offset = HT_EXTCHNL_OFFSET_NO_EXT;
1608 if(Offset==HT_EXTCHNL_OFFSET_UPPER || Offset==HT_EXTCHNL_OFFSET_LOWER) {
1609 pHTInfo->bCurBW40MHz = true;
1610 pHTInfo->CurSTAExtChnlOffset = Offset;
1612 pHTInfo->bCurBW40MHz = false;
1613 pHTInfo->CurSTAExtChnlOffset = HT_EXTCHNL_OFFSET_NO_EXT;
1616 pHTInfo->bCurBW40MHz = false;
1617 pHTInfo->CurSTAExtChnlOffset = HT_EXTCHNL_OFFSET_NO_EXT;
1620 printk("%s():pHTInfo->bCurBW40MHz:%x\n", __func__, pHTInfo->bCurBW40MHz);
1622 pHTInfo->bSwBwInProgress = true;
1624 HTSetConnectBwModeCallback(ieee);
1628 void HTSetConnectBwModeCallback(struct rtllib_device* ieee)
1630 PRT_HIGH_THROUGHPUT pHTInfo = ieee->pHTInfo;
1632 RTLLIB_DEBUG(RTLLIB_DL_HT, "======>%s()\n", __FUNCTION__);
1633 if(pHTInfo->bCurBW40MHz)
1635 if(pHTInfo->CurSTAExtChnlOffset==HT_EXTCHNL_OFFSET_UPPER)
1636 ieee->set_chan(ieee->dev, ieee->current_network.channel+2);
1637 else if(pHTInfo->CurSTAExtChnlOffset==HT_EXTCHNL_OFFSET_LOWER)
1638 ieee->set_chan(ieee->dev, ieee->current_network.channel-2);
1640 ieee->set_chan(ieee->dev, ieee->current_network.channel);
1642 ieee->SetBWModeHandler(ieee->dev, HT_CHANNEL_WIDTH_20_40, pHTInfo->CurSTAExtChnlOffset);
1644 ieee->set_chan(ieee->dev, ieee->current_network.channel);
1645 ieee->SetBWModeHandler(ieee->dev, HT_CHANNEL_WIDTH_20, HT_EXTCHNL_OFFSET_NO_EXT);
1648 pHTInfo->bSwBwInProgress = false;
1651 #ifndef BUILT_IN_RTLLIB
1652 EXPORT_SYMBOL_RSL(HTUpdateSelfAndPeerSetting);
1653 EXPORT_SYMBOL_RSL(HTFilterMCSRate);
1654 EXPORT_SYMBOL_RSL(HTGetHighestMCSRate);
1655 EXPORT_SYMBOL_RSL(MCS_FILTER_ALL);
1656 EXPORT_SYMBOL_RSL(MCS_FILTER_1SS);
1657 #ifdef _RTL8192_EXT_PATCH_
1658 EXPORT_SYMBOL_RSL(HTSetConnectBwMode);
1659 EXPORT_SYMBOL_RSL(HTConstructCapabilityElement);
1660 EXPORT_SYMBOL_RSL(HTConstructRT2RTAggElement);
1661 EXPORT_SYMBOL_RSL(HTUseDefaultSetting);
1662 EXPORT_SYMBOL_RSL(HTConstructInfoElement);