1 /******************************************************************************
3 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 * You should have received a copy of the GNU General Public License along with
15 * this program; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
19 ******************************************************************************/
20 #define _HCI_HAL_INIT_C_
23 #include <osdep_service.h>
24 #include <drv_types.h>
25 #include <rtw_efuse.h>
28 #include <HalPwrSeqCmd.h>
29 #include <Hal8723PwrSeq.h>
30 #include <rtl8723a_hal.h>
31 #include <rtl8723a_led.h>
32 #include <linux/ieee80211.h>
38 #ifdef CONFIG_EFUSE_CONFIG_FILE
40 #include <asm/uaccess.h>
41 #endif //CONFIG_EFUSE_CONFIG_FILE
45 #include <usb_osintf.h>
48 #define HAL_MAC_ENABLE 0
49 #define HAL_BB_ENABLE 0
50 #define HAL_RF_ENABLE 0
52 #define HAL_MAC_ENABLE 1
53 #define HAL_BB_ENABLE 1
54 #define HAL_RF_ENABLE 1
65 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
67 pHalData->OutEpQueueSel = 0;
68 pHalData->OutEpNumber = 0;
70 // Normal and High queue
71 value8 = rtw_read8(pAdapter, (REG_NORMAL_SIE_EP + 1));
73 if(value8 & USB_NORMAL_SIE_EP_MASK){
74 pHalData->OutEpQueueSel |= TX_SELE_HQ;
75 pHalData->OutEpNumber++;
78 if((value8 >> USB_NORMAL_SIE_EP_SHIFT) & USB_NORMAL_SIE_EP_MASK){
79 pHalData->OutEpQueueSel |= TX_SELE_NQ;
80 pHalData->OutEpNumber++;
84 value8 = rtw_read8(pAdapter, (REG_NORMAL_SIE_EP + 2));
85 if(value8 & USB_NORMAL_SIE_EP_MASK){
86 pHalData->OutEpQueueSel |= TX_SELE_LQ;
87 pHalData->OutEpNumber++;
90 // TODO: Error recovery for this case
91 //RT_ASSERT((NumOutPipe == pHalData->OutEpNumber), ("Out EP number isn't match! %d(Descriptor) != %d (SIE reg)\n", (u4Byte)NumOutPipe, (u4Byte)pHalData->OutEpNumber));
95 static bool HalUsbSetQueuePipeMapping8192CUsb(
101 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
102 bool result = _FALSE;
104 _ConfigChipOutEP(pAdapter, NumOutPipe);
106 // Normal chip with one IN and one OUT doesn't have interrupt IN EP.
107 if(1 == pHalData->OutEpNumber){
113 result = Hal_MappingOutPipe(pAdapter, NumOutPipe);
119 void rtl8192cu_interface_configure(_adapter *padapter)
121 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
122 struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
124 if (pdvobjpriv->ishighspeed == _TRUE)
126 pHalData->UsbBulkOutSize = USB_HIGH_SPEED_BULK_SIZE;//512 bytes
130 pHalData->UsbBulkOutSize = USB_FULL_SPEED_BULK_SIZE;//64 bytes
133 pHalData->interfaceIndex = pdvobjpriv->InterfaceNumber;
135 #ifdef CONFIG_USB_TX_AGGREGATION
136 pHalData->UsbTxAggMode = 1;
137 pHalData->UsbTxAggDescNum = 0x6; // only 4 bits
140 #ifdef CONFIG_USB_RX_AGGREGATION
141 pHalData->UsbRxAggMode = USB_RX_AGG_DMA;// USB_RX_AGG_DMA;
142 pHalData->UsbRxAggBlockCount = 8; //unit : 512b
143 pHalData->UsbRxAggBlockTimeout = 0x6;
144 pHalData->UsbRxAggPageCount = 48; //uint :128 b //0x0A; // 10 = MAX_RX_DMA_BUFFER_SIZE/2/pHalData->UsbBulkOutSize
145 pHalData->UsbRxAggPageTimeout = 0x4; //6, absolute time = 34ms/(2^6)
148 HalUsbSetQueuePipeMapping8192CUsb(padapter,
149 pdvobjpriv->RtNumInPipes, pdvobjpriv->RtNumOutPipes);
153 static u8 _InitPowerOn(PADAPTER padapter)
155 u8 status = _SUCCESS;
159 // RSV_CTRL 0x1C[7:0] = 0x00 // unlock ISO/CLK/Power control register
160 rtw_write8(padapter, REG_RSV_CTRL, 0x0);
162 // HW Power on sequence
163 if(!HalPwrSeqCmdParsing(padapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, rtl8723A_card_enable_flow ))
166 // 0x04[19] = 1, suggest by Jackie 2011.05.09, reset 8051
167 value8 = rtw_read8(padapter, REG_APS_FSMCO+2);
168 rtw_write8(padapter,REG_APS_FSMCO+2,(value8|BIT3));
170 // Enable MAC DMA/WMAC/SCHEDULE/SEC block
171 // Set CR bit10 to enable 32k calibration. Suggested by SD1 Gimmy. Added by tynli. 2011.08.31.
172 value16 = rtw_read16(padapter, REG_CR);
173 value16 |= (HCI_TXDMA_EN | HCI_RXDMA_EN | TXDMA_EN | RXDMA_EN
174 | PROTOCOL_EN | SCHEDULE_EN | MACTXEN | MACRXEN | ENSEC | CALTMR_EN);
175 rtw_write16(padapter, REG_CR, value16);
177 //for Efuse PG, suggest by Jackie 2011.11.23
178 PHY_SetBBReg(padapter, REG_EFUSE_CTRL, BIT28|BIT29|BIT30, 0x06);
184 static void _dbg_dump_macreg(_adapter *padapter)
189 for(index=0;index<64;index++)
192 val32 = rtw_read32(padapter,offset);
193 DBG_8723A("offset : 0x%02x ,val:0x%08x\n",offset,val32);
197 //-------------------------------------------------------------------------
199 // LLT R/W/Init function
201 //-------------------------------------------------------------------------
208 u8 status = _SUCCESS;
210 u32 value = _LLT_INIT_ADDR(address) | _LLT_INIT_DATA(data) | _LLT_OP(_LLT_WRITE_ACCESS);
212 rtw_write32(Adapter, REG_LLT_INIT, value);
217 value = rtw_read32(Adapter, REG_LLT_INIT);
218 if(_LLT_NO_ACTIVE == _LLT_OP_VALUE(value)){
222 if(count > POLLING_LLT_THRESHOLD){
223 //RT_TRACE(COMP_INIT,DBG_SERIOUS,("Failed to polling write LLT done at address %d!\n", address));
240 u32 value = _LLT_INIT_ADDR(address) | _LLT_OP(_LLT_READ_ACCESS);
242 rtw_write32(Adapter, REG_LLT_INIT, value);
244 //polling and get value
247 value = rtw_read32(Adapter, REG_LLT_INIT);
248 if(_LLT_NO_ACTIVE == _LLT_OP_VALUE(value)){
252 if(count > POLLING_LLT_THRESHOLD){
253 //RT_TRACE(COMP_INIT,DBG_SERIOUS,("Failed to polling read LLT done at address %d!\n", address));
263 //---------------------------------------------------------------
265 // MAC init functions
267 //---------------------------------------------------------------
270 PADAPTER Adapter, u8* MacID
274 for(i=0 ; i< MAC_ADDR_LEN ; i++){
275 #ifdef CONFIG_CONCURRENT_MODE
276 if(Adapter->iface_type == IFACE_PORT1)
277 rtw_write32(Adapter, REG_MACID1+i, MacID[i]);
280 rtw_write32(Adapter, REG_MACID+i, MacID[i]);
286 PADAPTER Adapter, u8* BSSID
290 for(i=0 ; i< MAC_ADDR_LEN ; i++){
291 #ifdef CONFIG_CONCURRENT_MODE
292 if(Adapter->iface_type == IFACE_PORT1)
293 rtw_write32(Adapter, REG_BSSID1+i, BSSID[i]);
296 rtw_write32(Adapter, REG_BSSID+i, BSSID[i]);
301 // Shall USB interface init this?
309 // HISR - turn all on
310 value32 = 0xFFFFFFFF;
311 rtw_write32(Adapter, REG_HISR, value32);
313 // HIMR - turn all on
314 rtw_write32(Adapter, REG_HIMR, value32);
319 _InitQueueReservedPage(
323 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
324 struct registry_priv *pregistrypriv = &Adapter->registrypriv;
326 u32 outEPNum = (u32)pHalData->OutEpNumber;
333 bool bWiFiConfig = pregistrypriv->wifi_spec;
334 //u32 txQPageNum, txQPageUnit,txQRemainPage;
337 //RT_ASSERT((outEPNum>=2), ("for WMM ,number of out-ep must more than or equal to 2!\n"));
339 numPubQ = bWiFiConfig?WMM_NORMAL_PAGE_NUM_PUBQ:NORMAL_PAGE_NUM_PUBQ;
341 if (pHalData->OutEpQueueSel & TX_SELE_HQ)
343 numHQ = bWiFiConfig?WMM_NORMAL_PAGE_NUM_HPQ:NORMAL_PAGE_NUM_HPQ;
346 if (pHalData->OutEpQueueSel & TX_SELE_LQ)
348 numLQ = bWiFiConfig?WMM_NORMAL_PAGE_NUM_LPQ:NORMAL_PAGE_NUM_LPQ;
350 // NOTE: This step shall be proceed before writting REG_RQPN.
351 if(pHalData->OutEpQueueSel & TX_SELE_NQ){
352 numNQ = bWiFiConfig?WMM_NORMAL_PAGE_NUM_NPQ:NORMAL_PAGE_NUM_NPQ;
354 value8 = (u8)_NPQ(numNQ);
355 rtw_write8(Adapter, REG_RQPN_NPQ, value8);
359 value32 = _HPQ(numHQ) | _LPQ(numLQ) | _PUBQ(numPubQ) | LD_RQPN;
360 rtw_write32(Adapter, REG_RQPN, value32);
364 _InitTxBufferBoundary(
368 struct registry_priv *pregistrypriv = &Adapter->registrypriv;
369 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
373 if(!pregistrypriv->wifi_spec){
374 txpktbuf_bndy = TX_PAGE_BOUNDARY;
377 txpktbuf_bndy = WMM_NORMAL_TX_PAGE_BOUNDARY;
380 rtw_write8(Adapter, REG_TXPKTBUF_BCNQ_BDNY, txpktbuf_bndy);
381 rtw_write8(Adapter, REG_TXPKTBUF_MGQ_BDNY, txpktbuf_bndy);
382 rtw_write8(Adapter, REG_TXPKTBUF_WMAC_LBK_BF_HD, txpktbuf_bndy);
383 rtw_write8(Adapter, REG_TRXFF_BNDY, txpktbuf_bndy);
385 rtw_write8(Adapter, REG_TDECTRL+1, txpktbuf_bndy);
387 txdmactrl = PlatformIORead2Byte(Adapter, REG_TDECTRL);
388 txdmactrl &= ~BCN_HEAD_MASK;
389 txdmactrl |= BCN_HEAD(txpktbuf_bndy);
390 PlatformIOWrite2Byte(Adapter, REG_TDECTRL, txdmactrl);
400 //srand(static_cast<unsigned int>(time(NULL)) );
401 u16 rxff_bndy = 0x27FF;//(rand() % 1) ? 0x27FF : 0x23FF;
403 rtw_write16(Adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
405 // TODO: ?? shall we set tx boundary?
410 _InitNormalChipRegPriority(
420 u16 value16 = (rtw_read16(Adapter, REG_TRXDMA_CTRL) & 0x7);
422 value16 |= _TXDMA_BEQ_MAP(beQ) | _TXDMA_BKQ_MAP(bkQ) |
423 _TXDMA_VIQ_MAP(viQ) | _TXDMA_VOQ_MAP(voQ) |
424 _TXDMA_MGQ_MAP(mgtQ)| _TXDMA_HIQ_MAP(hiQ);
426 rtw_write16(Adapter, REG_TRXDMA_CTRL, value16);
430 _InitNormalChipOneOutEpPriority(
434 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
437 switch(pHalData->OutEpQueueSel)
446 value = QUEUE_NORMAL;
449 //RT_ASSERT(FALSE,("Shall not reach here!\n"));
453 _InitNormalChipRegPriority(Adapter,
465 _InitNormalChipTwoOutEpPriority(
469 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
470 struct registry_priv *pregistrypriv = &Adapter->registrypriv;
471 u16 beQ,bkQ,viQ,voQ,mgtQ,hiQ;
477 switch(pHalData->OutEpQueueSel)
479 case (TX_SELE_HQ | TX_SELE_LQ):
480 valueHi = QUEUE_HIGH;
481 valueLow = QUEUE_LOW;
483 case (TX_SELE_NQ | TX_SELE_LQ):
484 valueHi = QUEUE_NORMAL;
485 valueLow = QUEUE_LOW;
487 case (TX_SELE_HQ | TX_SELE_NQ):
488 valueHi = QUEUE_HIGH;
489 valueLow = QUEUE_NORMAL;
492 //RT_ASSERT(FALSE,("Shall not reach here!\n"));
496 if(!pregistrypriv->wifi_spec ){
504 else{//for WMM ,CONFIG_OUT_EP_WIFI_MODE
513 _InitNormalChipRegPriority(Adapter,beQ,bkQ,viQ,voQ,mgtQ,hiQ);
518 _InitNormalChipThreeOutEpPriority(
522 struct registry_priv *pregistrypriv = &Adapter->registrypriv;
523 u16 beQ,bkQ,viQ,voQ,mgtQ,hiQ;
525 if(!pregistrypriv->wifi_spec ){// typical setting
541 _InitNormalChipRegPriority(Adapter,beQ,bkQ,viQ,voQ,mgtQ,hiQ);
545 _InitNormalChipQueuePriority(
549 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
551 switch(pHalData->OutEpNumber)
554 _InitNormalChipOneOutEpPriority(Adapter);
557 _InitNormalChipTwoOutEpPriority(Adapter);
560 _InitNormalChipThreeOutEpPriority(Adapter);
563 //RT_ASSERT(FALSE,("Shall not reach here!\n"));
575 _InitNormalChipQueuePriority(Adapter);
579 _InitHardwareDropIncorrectBulkOut(
583 u32 value32 = rtw_read32(Adapter, REG_TXDMA_OFFSET_CHK);
584 value32 |= DROP_DATA_EN;
585 rtw_write32(Adapter, REG_TXDMA_OFFSET_CHK, value32);
595 value32 = rtw_read32(Adapter, REG_CR);
597 // TODO: use the other function to set network type
598 #if RTL8191C_FPGA_NETWORKTYPE_ADHOC
599 value32 = (value32 & ~MASK_NETTYPE) | _NETTYPE(NT_LINK_AD_HOC);
601 value32 = (value32 & ~MASK_NETTYPE) | _NETTYPE(NT_LINK_AP);
603 rtw_write32(Adapter, REG_CR, value32);
604 // RASSERT(pIoBase->rtw_read8(REG_CR + 2) == 0x2);
608 _InitTransferPageSize(
612 // Tx page size is always 128.
615 value8 = _PSRX(PBP_128) | _PSTX(PBP_128);
616 rtw_write8(Adapter, REG_PBP, value8);
625 rtw_write8(Adapter,REG_RX_DRVINFO_SZ, drvInfoSize);
635 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
637 //pHalData->ReceiveConfig = AAP | APM | AM | AB | APP_ICV | ADF | AMF | APP_FCS | HTC_LOC_CTRL | APP_MIC | APP_PHYSTS;
638 //pHalData->ReceiveConfig = RCR_AAP | RCR_APM | RCR_AM | RCR_AB |RCR_CBSSID_DATA| RCR_CBSSID_BCN| RCR_APP_ICV | RCR_AMF | RCR_HTC_LOC_CTRL | RCR_APP_MIC | RCR_APP_PHYSTS;
639 // don't turn on AAP, it will allow all packets to driver
640 pHalData->ReceiveConfig = RCR_APM | RCR_AM | RCR_AB |RCR_CBSSID_DATA| RCR_CBSSID_BCN| RCR_APP_ICV | RCR_AMF | RCR_HTC_LOC_CTRL | RCR_APP_MIC | RCR_APP_PHYSTS;
641 #if (1 == RTL8192C_RX_PACKET_INCLUDE_CRC)
642 pHalData->ReceiveConfig |= ACRC32;
645 // some REG_RCR will be modified later by phy_ConfigMACWithHeaderFile()
646 rtw_write32(Adapter, REG_RCR, pHalData->ReceiveConfig);
648 // Accept all multicast address
649 rtw_write32(Adapter, REG_MAR, 0xFFFFFFFF);
650 rtw_write32(Adapter, REG_MAR + 4, 0xFFFFFFFF);
653 // Accept all data frames
655 //rtw_write16(Adapter, REG_RXFLTMAP2, value16);
658 // Since ADF is removed from RCR, ps-poll will not be indicate to driver,
659 // RxFilterMap should mask ps-poll to gurantee AP mode can rx ps-poll.
661 //rtw_write16(Adapter, REG_RXFLTMAP1, value16);
663 // Accept all management frames
665 //rtw_write16(Adapter, REG_RXFLTMAP0, value16);
667 //enable RX_SHIFT bits
668 //rtw_write8(Adapter, REG_TRXDMA_CTRL, rtw_read8(Adapter, REG_TRXDMA_CTRL)|BIT(1));
681 value32 = rtw_read32(Adapter, REG_RRSR);
682 value32 &= ~RATE_BITMAP_ALL;
683 value32 |= RATE_RRSR_CCK_ONLY_1M;
684 rtw_write32(Adapter, REG_RRSR, value32);
687 //m_spIoBase->rtw_write8(REG_CFEND_TH, 0x1);
689 // SIFS (used in NAV)
690 value16 = _SPEC_SIFS_CCK(0x10) | _SPEC_SIFS_OFDM(0x10);
691 rtw_write16(Adapter, REG_SPEC_SIFS, value16);
694 value16 = _LRL(0x30) | _SRL(0x30);
695 rtw_write16(Adapter, REG_RL, value16);
704 // Set Data Auto Rate Fallback Retry Count register.
705 rtw_write32(Adapter, REG_DARFRC, 0x00000000);
706 rtw_write32(Adapter, REG_DARFRC+4, 0x10080404);
707 rtw_write32(Adapter, REG_RARFRC, 0x04030201);
708 rtw_write32(Adapter, REG_RARFRC+4, 0x08070605);
718 // Set Spec SIFS (used in NAV)
719 rtw_write16(Adapter,REG_SPEC_SIFS, 0x100a);
720 rtw_write16(Adapter,REG_MAC_SPEC_SIFS, 0x100a);
723 rtw_write16(Adapter,REG_SIFS_CTX, 0x100a);
726 rtw_write16(Adapter,REG_SIFS_TRX, 0x100a);
729 rtw_write32(Adapter, REG_EDCA_BE_PARAM, 0x005EA42B);
730 rtw_write32(Adapter, REG_EDCA_BK_PARAM, 0x0000A44F);
731 rtw_write32(Adapter, REG_EDCA_VI_PARAM, 0x005EA324);
732 rtw_write32(Adapter, REG_EDCA_VO_PARAM, 0x002FA226);
736 static void _InitHWLed(PADAPTER Adapter)
738 struct led_priv *pledpriv = &(Adapter->ledpriv);
740 if( pledpriv->LedStrategy != HW_LED)
745 //must consider cases of antenna diversity/ commbo card/solo card/mini card
755 rtw_write8(Adapter,REG_RD_CTRL,0xFF);
756 rtw_write16(Adapter, REG_RD_NAV_NXT, 0x200);
757 rtw_write8(Adapter,REG_RD_RESP_PKT_TH,0x05);
765 rtw_write32(Adapter, REG_MACID, 0x87654321);
766 rtw_write32(Adapter, 0x0700, 0x87654321);
776 value8 = rtw_read8(Adapter, REG_FWHW_TXQ_CTRL);
777 value8 |= EN_AMPDU_RTY_NEW;
778 rtw_write8(Adapter, REG_FWHW_TXQ_CTRL, value8);
781 rtw_write8(Adapter, REG_ACKTO, 0x40);
784 /*-----------------------------------------------------------------------------
785 * Function: usb_AggSettingTxUpdate()
787 * Overview: Seperate TX/RX parameters update independent for TP detection and
788 * dynamic TX/RX aggreagtion parameters update.
792 * Output/Return: NONE
796 * 12/10/2010 MHC Seperate to smaller function.
798 *---------------------------------------------------------------------------*/
800 usb_AggSettingTxUpdate(
804 #ifdef CONFIG_USB_TX_AGGREGATION
805 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
806 //PMGNT_INFO pMgntInfo = &(Adapter->MgntInfo);
809 if(Adapter->registrypriv.wifi_spec)
810 pHalData->UsbTxAggMode = _FALSE;
812 if(pHalData->UsbTxAggMode){
813 value32 = rtw_read32(Adapter, REG_TDECTRL);
814 value32 = value32 & ~(BLK_DESC_NUM_MASK << BLK_DESC_NUM_SHIFT);
815 value32 |= ((pHalData->UsbTxAggDescNum & BLK_DESC_NUM_MASK) << BLK_DESC_NUM_SHIFT);
817 rtw_write32(Adapter, REG_TDECTRL, value32);
821 } // usb_AggSettingTxUpdate
824 /*-----------------------------------------------------------------------------
825 * Function: usb_AggSettingRxUpdate()
827 * Overview: Seperate TX/RX parameters update independent for TP detection and
828 * dynamic TX/RX aggreagtion parameters update.
832 * Output/Return: NONE
836 * 12/10/2010 MHC Seperate to smaller function.
838 *---------------------------------------------------------------------------*/
840 usb_AggSettingRxUpdate(
844 #ifdef CONFIG_USB_RX_AGGREGATION
845 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
846 //PMGNT_INFO pMgntInfo = &(Adapter->MgntInfo);
850 valueDMA = rtw_read8(Adapter, REG_TRXDMA_CTRL);
851 valueUSB = rtw_read8(Adapter, REG_USB_SPECIAL_OPTION);
853 switch(pHalData->UsbRxAggMode)
856 valueDMA |= RXDMA_AGG_EN;
857 valueUSB &= ~USB_AGG_EN;
860 valueDMA &= ~RXDMA_AGG_EN;
861 valueUSB |= USB_AGG_EN;
864 valueDMA |= RXDMA_AGG_EN;
865 valueUSB |= USB_AGG_EN;
867 case USB_RX_AGG_DISABLE:
869 valueDMA &= ~RXDMA_AGG_EN;
870 valueUSB &= ~USB_AGG_EN;
874 rtw_write8(Adapter, REG_TRXDMA_CTRL, valueDMA);
875 rtw_write8(Adapter, REG_USB_SPECIAL_OPTION, valueUSB);
877 switch(pHalData->UsbRxAggMode)
880 rtw_write8(Adapter, REG_RXDMA_AGG_PG_TH, pHalData->UsbRxAggPageCount);
881 rtw_write8(Adapter, REG_USB_DMA_AGG_TO, pHalData->UsbRxAggPageTimeout);
884 rtw_write8(Adapter, REG_USB_AGG_TH, pHalData->UsbRxAggBlockCount);
885 rtw_write8(Adapter, REG_USB_AGG_TO, pHalData->UsbRxAggBlockTimeout);
888 rtw_write8(Adapter, REG_RXDMA_AGG_PG_TH, pHalData->UsbRxAggPageCount);
889 rtw_write8(Adapter, REG_USB_DMA_AGG_TO, pHalData->UsbRxAggPageTimeout);
890 rtw_write8(Adapter, REG_USB_AGG_TH, pHalData->UsbRxAggBlockCount);
891 rtw_write8(Adapter, REG_USB_AGG_TO, pHalData->UsbRxAggBlockTimeout);
893 case USB_RX_AGG_DISABLE:
902 pHalData->HwRxPageSize = 128;
905 pHalData->HwRxPageSize = 64;
908 pHalData->HwRxPageSize = 256;
911 pHalData->HwRxPageSize = 512;
914 pHalData->HwRxPageSize = 1024;
917 //RT_ASSERT(FALSE, ("RX_PAGE_SIZE_REG_VALUE definition is incorrect!\n"));
921 } // usb_AggSettingRxUpdate
924 InitUsbAggregationSetting(
928 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
930 // Tx aggregation setting
931 usb_AggSettingTxUpdate(Adapter);
933 // Rx aggregation setting
934 usb_AggSettingRxUpdate(Adapter);
936 // 201/12/10 MH Add for USB agg mode dynamic switch.
937 pHalData->UsbRxHighSpeedMode = _FALSE;
940 /*-----------------------------------------------------------------------------
941 * Function: USB_AggModeSwitch()
943 * Overview: When RX traffic is more than 40M, we need to adjust some parameters to increase
944 * RX speed by increasing batch indication size. This will decrease TCP ACK speed, we
945 * need to monitor the influence of FTP/network share.
946 * For TX mode, we are still ubder investigation.
956 * 12/10/2010 MHC Create Version 0.
958 *---------------------------------------------------------------------------*/
965 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
966 struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
968 //pHalData->UsbRxHighSpeedMode = FALSE;
969 // How to measure the RX speed? We assume that when traffic is more than
970 if (pMgntInfo->bRegAggDMEnable == _FALSE)
972 return; // Inf not support.
976 if (pmlmepriv->LinkDetectInfo.bHigherBusyTraffic == _TRUE &&
977 pHalData->UsbRxHighSpeedMode == _FALSE)
979 pHalData->UsbRxHighSpeedMode = _TRUE;
980 DBG_8723A("UsbAggModeSwitchCheck to HIGH\n");
982 else if (pmlmepriv->LinkDetectInfo.bHigherBusyTraffic == _FALSE &&
983 pHalData->UsbRxHighSpeedMode == _TRUE)
985 pHalData->UsbRxHighSpeedMode = _FALSE;
986 DBG_8723A("UsbAggModeSwitchCheck to LOW\n");
993 // 2010/12/10 MH Add for USB Aggregation judgement we need to
994 //if( pMgntInfo->LinkDetectInfo.NumRxOkInPeriod > 4000 ||
995 // pMgntInfo->LinkDetectInfo.NumTxOkInPeriod > 4000 )
997 #ifdef CONFIG_USB_TX_AGGREGATION
998 //usb_AggSettingTxUpdate(Adapter);
1001 #ifdef CONFIG_USB_RX_AGGREGATION
1002 if (pHalData->UsbRxHighSpeedMode == _TRUE)
1004 // 2010/12/10 MH The parameter is tested by SD1 engineer and SD3 channel emulator.
1006 pHalData->UsbRxAggBlockCount = 40;
1007 pHalData->UsbRxAggBlockTimeout = 5;
1009 pHalData->UsbRxAggPageCount = 72;
1010 pHalData->UsbRxAggPageTimeout = 6;
1015 pHalData->UsbRxAggBlockCount = pMgntInfo->RegUsbRxAggBlockCount;
1016 pHalData->UsbRxAggBlockTimeout = pMgntInfo->RegUsbRxAggBlockTimeout;
1018 pHalData->UsbRxAggPageCount = pMgntInfo->RegUsbRxAggPageCount;
1019 pHalData->UsbRxAggPageTimeout = pMgntInfo->RegUsbRxAggPageTimeout;
1023 } // USB_AggModeSwitch
1031 PHAL_DATA_8192CUSB pHalData = GetHalData8192CUsb(Adapter);
1032 u1Byte regBwOpMode = 0;
1033 u4Byte regRATR = 0, regRRSR = 0;
1036 //1 This part need to modified according to the rate set we filtered!!
1038 // Set RRSR, RATR, and REG_BWOPMODE registers
1040 switch(Adapter->RegWirelessMode)
1042 case WIRELESS_MODE_B:
1043 regBwOpMode = BW_OPMODE_20MHZ;
1044 regRATR = RATE_ALL_CCK;
1045 regRRSR = RATE_ALL_CCK;
1047 case WIRELESS_MODE_A:
1050 regBwOpMode = BW_OPMODE_5G |BW_OPMODE_20MHZ;
1051 regRATR = RATE_ALL_OFDM_AG;
1052 regRRSR = RATE_ALL_OFDM_AG;
1055 case WIRELESS_MODE_G:
1056 regBwOpMode = BW_OPMODE_20MHZ;
1057 regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
1058 regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
1060 case WIRELESS_MODE_AUTO:
1061 if (Adapter->bInHctTest)
1063 regBwOpMode = BW_OPMODE_20MHZ;
1064 regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
1065 regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
1069 regBwOpMode = BW_OPMODE_20MHZ;
1070 regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG | RATE_ALL_OFDM_1SS | RATE_ALL_OFDM_2SS;
1071 regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
1074 case WIRELESS_MODE_N_24G:
1075 // It support CCK rate by default.
1076 // CCK rate will be filtered out only when associated AP does not support it.
1077 regBwOpMode = BW_OPMODE_20MHZ;
1078 regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG | RATE_ALL_OFDM_1SS | RATE_ALL_OFDM_2SS;
1079 regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
1081 case WIRELESS_MODE_N_5G:
1084 regBwOpMode = BW_OPMODE_5G;
1085 regRATR = RATE_ALL_OFDM_AG | RATE_ALL_OFDM_1SS | RATE_ALL_OFDM_2SS;
1086 regRRSR = RATE_ALL_OFDM_AG;
1092 //PlatformEFIOWrite4Byte(Adapter, REG_INIRTS_RATE_SEL, regRRSR);
1093 rtw_write8(Adapter, REG_BWOPMODE, regBwOpMode);
1095 // For Min Spacing configuration.
1096 switch(pHalData->RF_Type)
1100 RT_TRACE(COMP_INIT, DBG_LOUD, ("Initializeadapter: RF_Type%s\n", (pHalData->RF_Type==RF_1T1R? "(1T1R)":"(1T2R)")));
1101 Adapter->MgntInfo.MinSpaceCfg = (MAX_MSS_DENSITY_1T<<3);
1105 RT_TRACE(COMP_INIT, DBG_LOUD, ("Initializeadapter:RF_Type(2T2R)\n"));
1106 Adapter->MgntInfo.MinSpaceCfg = (MAX_MSS_DENSITY_2T<<3);
1110 rtw_write8(Adapter, REG_AMPDU_MIN_SPACE, Adapter->MgntInfo.MinSpaceCfg);
1119 struct registry_priv *pregpriv = &Adapter->registrypriv;
1120 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1121 bool is92CU = IS_92C_SERIAL(pHalData->VersionID);
1124 pHalData->rf_chip = RF_PSEUDO_11N;
1128 pHalData->rf_chip = RF_6052;
1130 if(_FALSE == is92CU){
1131 pHalData->rf_type = RF_1T1R;
1132 DBG_8723A("Set RF Chip ID to RF_6052 and RF type to 1T1R.\n");
1136 // TODO: Consider that EEPROM set 92CU to 1T1R later.
1137 // Force to overwrite setting according to chip version. Ignore EEPROM setting.
1138 //pHalData->RF_Type = is92CU ? RF_2T2R : RF_1T1R;
1139 MSG_8723A("Set RF Chip ID to RF_6052 and RF type to %d.\n", pHalData->rf_type);
1143 static VOID _InitAdhocWorkaroundParams(PADAPTER Adapter)
1145 #ifdef RTL8192CU_ADHOC_WORKAROUND_SETTING
1146 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1147 pHalData->RegBcnCtrlVal = rtw_read8(Adapter, REG_BCN_CTRL);
1148 pHalData->RegTxPause = rtw_read8(Adapter, REG_TXPAUSE);
1149 pHalData->RegFwHwTxQCtrl = rtw_read8(Adapter, REG_FWHW_TXQ_CTRL+2);
1150 pHalData->RegReg542 = rtw_read8(Adapter, REG_TBTT_PROHIBIT+2);
1154 // Set CCK and OFDM Block "ON"
1155 static VOID _BBTurnOnBlock(
1163 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bCCKEn, 0x1);
1164 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
1167 #define MgntActSet_RF_State(...)
1168 static void _RfPowerSave(PADAPTER padapter)
1171 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
1172 struct pwrctrl_priv *ppwrctrl = &padapter->pwrctrlpriv;
1173 rt_rf_power_state eRfPowerStateToSet;
1181 // 2010/08/11 MH Merge from 8192SE for Minicard init. We need to confirm current radio status
1182 // and then decide to enable RF or not.!!!??? For Selective suspend mode. We may not
1183 // call init_adapter. May cause some problem??
1185 // Fix the bug that Hw/Sw radio off before S3/S4, the RF off action will not be executed
1186 // in MgntActSet_RF_State() after wake up, because the value of pHalData->eRFPowerState
1187 // is the same as eRfOff, we should change it to eRfOn after we config RF parameters.
1188 // Added by tynli. 2010.03.30.
1189 ppwrctrl->rf_pwrstate = rf_on;
1190 RT_CLEAR_PS_LEVEL(ppwrctrl, RT_RF_OFF_LEVL_HALT_NIC);
1191 //Added by chiyokolin, 2011.10.12 for Tx
1192 rtw_write8(padapter, REG_TXPAUSE, 0x00);
1194 // 20100326 Joseph: Copy from GPIOChangeRFWorkItemCallBack() function to check HW radio on/off.
1195 // 20100329 Joseph: Revise and integrate the HW/SW radio off code in initialization.
1197 eRfPowerStateToSet = (rt_rf_power_state) RfOnOffDetect(padapter);
1198 ppwrctrl->rfoff_reason |= eRfPowerStateToSet==rf_on ? RF_CHANGE_BY_INIT : RF_CHANGE_BY_HW;
1199 ppwrctrl->rfoff_reason |= (ppwrctrl->reg_rfoff) ? RF_CHANGE_BY_SW : 0;
1201 if (ppwrctrl->rfoff_reason & RF_CHANGE_BY_HW)
1202 ppwrctrl->b_hw_radio_off = _TRUE;
1204 if (ppwrctrl->reg_rfoff == _TRUE)
1206 // User disable RF via registry.
1207 RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("InitializeAdapter8192CUsb(): Turn off RF for RegRfOff.\n"));
1208 MgntActSet_RF_State(padapter, rf_off, RF_CHANGE_BY_SW, _TRUE);
1210 // if (padapter->bSlaveOfDMSP)
1213 else if (ppwrctrl->rfoff_reason > RF_CHANGE_BY_PS)
1215 // H/W or S/W RF OFF before sleep.
1216 RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("InitializeAdapter8192CUsb(): Turn off RF for RfOffReason(%ld).\n", pMgntInfo->RfOffReason));
1217 MgntActSet_RF_State(padapter, rf_off, ppwrctrl->rfoff_reason, _TRUE);
1221 // Perform GPIO polling to find out current RF state. added by Roger, 2010.04.09.
1223 // if (RT_GetInterfaceSelection(padapter)==INTF_SEL2_MINICARD &&
1224 if ((pHalData->BoardType == BOARD_MINICARD) &&
1225 (padapter->MgntInfo.PowerSaveControl.bGpioRfSw))
1227 RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("InitializeAdapter8192CU(): RF=%d \n", eRfPowerStateToSet));
1228 if (eRfPowerStateToSet == rf_off)
1230 MgntActSet_RF_State(padapter, rf_off, RF_CHANGE_BY_HW, _TRUE);
1231 ppwrctrl->b_hw_radio_off = _TRUE;
1235 ppwrctrl->rf_pwrstate = rf_off;
1236 ppwrctrl->rfoff_reason = RF_CHANGE_BY_INIT;
1237 ppwrctrl->b_hw_radio_off = _FALSE;
1238 MgntActSet_RF_State(padapter, rf_on, ppwrctrl->rfoff_reason, _TRUE);
1244 ppwrctrl->rf_pwrstate = rf_off;
1245 ppwrctrl->rfoff_reason = RF_CHANGE_BY_INIT;
1246 MgntActSet_RF_State(padapter, rf_on, ppwrctrl->rfoff_reason, _TRUE);
1249 ppwrctrl->rfoff_reason = 0;
1250 ppwrctrl->b_hw_radio_off = _FALSE;
1251 ppwrctrl->rf_pwrstate = rf_on;
1252 if (padapter->ledpriv.LedControlHandler)
1253 padapter->ledpriv.LedControlHandler(padapter, LED_CTL_POWER_ON);
1256 // 2010/-8/09 MH For power down module, we need to enable register block contrl reg at 0x1c.
1257 // Then enable power down control bit of register 0x04 BIT4 and BIT15 as 1.
1258 if (pHalData->pwrdown && eRfPowerStateToSet == rf_off)
1260 // Enable register area 0x0-0xc.
1261 rtw_write8(padapter, REG_RSV_CTRL, 0x0);
1264 // <Roger_Notes> We should configure HW PDn source for WiFi ONLY, and then
1265 // our HW will be set in power-down mode if PDn source from all functions are configured.
1268 u1bTmp = rtw_read8(padapter, REG_MULTI_FUNC_CTRL);
1269 u1bTmp |= WL_HWPDN_EN;
1270 rtw_write8(padapter, REG_MULTI_FUNC_CTRL, u1bTmp);
1281 // 2010/08/09 MH Add for power down check.
1284 HalDetectPwrDownMode(
1289 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1290 struct pwrctrl_priv *pwrctrlpriv = &Adapter->pwrctrlpriv;
1292 EFUSE_ShadowRead(Adapter, 1, EEPROM_RF_OPT3, (u32 *)&tmpvalue);
1294 // 2010/08/25 MH INF priority > PDN Efuse value.
1295 if(tmpvalue & BIT4 && pwrctrlpriv->reg_pdnmode)
1297 pHalData->pwrdown = _TRUE;
1301 pHalData->pwrdown = _FALSE;
1304 DBG_8723A("HalDetectPwrDownMode(): PDN=%d\n", pHalData->pwrdown);
1305 return pHalData->pwrdown;
1307 } // HalDetectPwrDownMode
1311 // 2010/08/26 MH Add for selective suspend mode check.
1312 // If Efuse 0x0e bit1 is not enabled, we can not support selective suspend for Minicard and
1316 HalDetectSelectiveSuspendMode(
1321 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1322 struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(Adapter);
1324 // If support HW radio detect, we need to enable WOL ability, otherwise, we
1325 // can not use FW to notify host the power state switch.
1327 EFUSE_ShadowRead(Adapter, 1, EEPROM_USB_OPTIONAL1, (u32 *)&tmpvalue);
1329 DBG_8723A("HalDetectSelectiveSuspendMode(): SS ");
1332 DBG_8723A("Enable\n");
1336 DBG_8723A("Disable\n");
1337 pdvobjpriv->RegUsbSS = _FALSE;
1340 // 2010/09/01 MH According to Dongle Selective Suspend INF. We can switch SS mode.
1341 if (pdvobjpriv->RegUsbSS && !SUPPORT_HW_RADIO_DETECT(pHalData))
1343 //PMGNT_INFO pMgntInfo = &(Adapter->MgntInfo);
1345 //if (!pMgntInfo->bRegDongleSS)
1347 // RT_TRACE(COMP_INIT, DBG_LOUD, ("Dongle disable SS\n"));
1348 pdvobjpriv->RegUsbSS = _FALSE;
1351 } // HalDetectSelectiveSuspendMode
1352 /*-----------------------------------------------------------------------------
1353 * Function: HwSuspendModeEnable92Cu()
1355 * Overview: HW suspend mode switch.
1365 * 08/23/2010 MHC HW suspend mode switch test..
1366 *---------------------------------------------------------------------------*/
1368 HwSuspendModeEnable92Cu(
1373 } // HwSuspendModeEnable92Cu
1375 rt_rf_power_state RfOnOffDetect(PADAPTER pAdapter )
1377 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
1379 rt_rf_power_state rfpowerstate = rf_off;
1381 if(pAdapter->pwrctrlpriv.bHWPowerdown)
1383 val8 = rtw_read8(pAdapter, REG_HSISR);
1384 DBG_8723A("pwrdown, 0x5c(BIT7)=%02x\n", val8);
1385 rfpowerstate = (val8 & BIT7) ? rf_off: rf_on;
1389 rtw_write8( pAdapter, REG_MAC_PINMUX_CFG,rtw_read8(pAdapter, REG_MAC_PINMUX_CFG)&~(BIT3));
1390 val8 = rtw_read8(pAdapter, REG_GPIO_IO_SEL);
1391 DBG_8723A("GPIO_IN=%02x\n", val8);
1392 rfpowerstate = (val8 & BIT3) ? rf_on : rf_off;
1394 return rfpowerstate;
1395 } // HalDetectPwrDownMode
1397 void _ps_open_RF(_adapter *padapter);
1399 u32 rtl8723au_hal_init(PADAPTER Adapter)
1402 u32 boundary, status = _SUCCESS;
1403 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1404 struct pwrctrl_priv *pwrctrlpriv = &Adapter->pwrctrlpriv;
1405 struct registry_priv *pregistrypriv = &Adapter->registrypriv;
1406 u8 is92C = IS_92C_SERIAL(pHalData->VersionID);
1407 rt_rf_power_state eRfPowerStateToSet;
1408 u32 NavUpper = WiFiNavUpperUs;
1410 u32 init_start_time = rtw_get_current_time();
1413 #ifdef DBG_HAL_INIT_PROFILING
1415 enum HAL_INIT_STAGES {
1416 HAL_INIT_STAGES_BEGIN = 0,
1417 HAL_INIT_STAGES_INIT_PW_ON,
1418 HAL_INIT_STAGES_INIT_LLTT,
1419 HAL_INIT_STAGES_MISC01,
1420 HAL_INIT_STAGES_DOWNLOAD_FW,
1421 HAL_INIT_STAGES_MAC,
1424 HAL_INIT_STAGES_MISC02,
1425 HAL_INIT_STAGES_TURN_ON_BLOCK,
1426 HAL_INIT_STAGES_INIT_SECURITY,
1427 HAL_INIT_STAGES_MISC11,
1428 //HAL_INIT_STAGES_RF_PS,
1429 HAL_INIT_STAGES_IQK,
1430 HAL_INIT_STAGES_PW_TRACK,
1431 HAL_INIT_STAGES_LCK,
1432 HAL_INIT_STAGES_MISC21,
1433 //HAL_INIT_STAGES_INIT_PABIAS,
1434 #ifdef CONFIG_BT_COEXIST
1435 HAL_INIT_STAGES_BT_COEXIST,
1437 //HAL_INIT_STAGES_ANTENNA_SEL,
1438 HAL_INIT_STAGES_INIT_HAL_DM,
1439 HAL_INIT_STAGES_MISC31,
1440 HAL_INIT_STAGES_END,
1444 char * hal_init_stages_str[] = {
1445 "HAL_INIT_STAGES_BEGIN",
1446 "HAL_INIT_STAGES_INIT_PW_ON",
1447 "HAL_INIT_STAGES_INIT_LLTT",
1448 "HAL_INIT_STAGES_MISC01",
1449 "HAL_INIT_STAGES_DOWNLOAD_FW",
1450 "HAL_INIT_STAGES_MAC",
1451 "HAL_INIT_STAGES_BB",
1452 "HAL_INIT_STAGES_RF",
1453 "HAL_INIT_STAGES_MISC02",
1454 "HAL_INIT_STAGES_TURN_ON_BLOCK",
1455 "HAL_INIT_STAGES_INIT_SECURITY",
1456 "HAL_INIT_STAGES_MISC11",
1457 //"HAL_INIT_STAGES_RF_PS",
1458 "HAL_INIT_STAGES_IQK",
1459 "HAL_INIT_STAGES_PW_TRACK",
1460 "HAL_INIT_STAGES_LCK",
1461 "HAL_INIT_STAGES_MISC21",
1462 //"HAL_INIT_STAGES_INIT_PABIAS",
1463 #ifdef CONFIG_BT_COEXIST
1464 "HAL_INIT_STAGES_BT_COEXIST",
1466 //"HAL_INIT_STAGES_ANTENNA_SEL",
1467 "HAL_INIT_STAGES_INIT_HAL_DM",
1468 "HAL_INIT_STAGES_MISC31",
1469 "HAL_INIT_STAGES_END",
1472 int hal_init_profiling_i;
1473 u32 hal_init_stages_timestamp[HAL_INIT_STAGES_NUM]; //used to record the time of each stage's starting point
1475 for(hal_init_profiling_i=0;hal_init_profiling_i<HAL_INIT_STAGES_NUM;hal_init_profiling_i++)
1476 hal_init_stages_timestamp[hal_init_profiling_i]=0;
1478 #define HAL_INIT_PROFILE_TAG(stage) hal_init_stages_timestamp[(stage)]=rtw_get_current_time();
1480 #define HAL_INIT_PROFILE_TAG(stage) do {} while(0)
1481 #endif //DBG_HAL_INIT_PROFILING
1487 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_BEGIN);
1488 if(Adapter->pwrctrlpriv.bkeepfwalive)
1490 _ps_open_RF(Adapter);
1492 if(pHalData->bIQKInitialized ){
1493 rtl8192c_PHY_IQCalibrate(Adapter,_TRUE);
1496 rtl8192c_PHY_IQCalibrate(Adapter,_FALSE);
1497 pHalData->bIQKInitialized = _TRUE;
1499 rtl8192c_odm_CheckTXPowerTracking(Adapter);
1500 rtl8192c_PHY_LCCalibrate(Adapter);
1505 // pHalData->bMACFuncEnable = _FALSE;
1506 // Check if MAC has already power on. by tynli. 2011.05.27.
1507 val8 = rtw_read8(Adapter, REG_CR);
1508 RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
1509 ("%s: REG_CR 0x100=0x%02x\n", __FUNCTION__, val8));
1510 //Fix 92DU-VC S3 hang with the reason is that secondary mac is not initialized.
1511 //0x100 value of first mac is 0xEA while 0x100 value of secondary is 0x00
1512 //by sherry 20111102
1514 pHalData->bMACFuncEnable = _FALSE;
1516 pHalData->bMACFuncEnable = _TRUE;
1517 RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
1518 ("%s: MAC has already power on\n", __FUNCTION__));
1521 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_PW_ON);
1522 status = _InitPowerOn(Adapter);
1523 if(status == _FAIL){
1524 RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("Failed to init power on!\n"));
1528 #ifdef CONFIG_BT_COEXIST
1530 // 2010/09/23 MH Accordgin to Alfred's siggestion. we need to enable SIC to prevent HW
1531 // to enter suspend mode automatically. If host does not send SOF every 3ms. Or under DTM
1532 // test with rtl8188cu selective suspend enabler filter driver, WIN host will trigger the device to
1533 // enter suspend mode after some test (unknow reason now). We need to prevent the case otherwise
1534 // the register will be 0xea and all TX/RX path stop accidently.
1537 // 2010/10/01 MH If the OS is XP, host will trigger USB device to enter D3 mode. In CU HW design
1538 // it will enter suspend mode automatically. In slim combo card, the BT clock will be cut off if HW
1539 // enter suspend mode. We need to seperate differet case.
1541 if (BT_IsBtExist(Adapter))
1544 #if OS_WIN_FROM_VISTA(OS_VERSION)
1545 RT_TRACE(COMP_INIT, DBG_LOUD, ("Slim_combo win7/vista need not enable SIC\n"));
1547 RT_TRACE(COMP_INIT, DBG_LOUD, ("Slim_combo XP enable SIC\n"));
1548 // 2010/10/15 MH According to Alfre's description, e need to enable bit14 at first an then enable bit12.
1549 // Otherwise, HW will enter debug mode and 8051 can not work. We need to stay at test mode to enable SIC.
1550 rtw_write16(Adapter, REG_GPIO_MUXCFG, rtw_read16(Adapter, REG_GPIO_MUXCFG)|BIT14);
1551 rtw_write16(Adapter, REG_GPIO_MUXCFG, rtw_read16(Adapter, REG_GPIO_MUXCFG)|BIT12);
1555 #endif // CONFIG_BT_COEXIST
1557 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_LLTT);
1558 if (!pregistrypriv->wifi_spec) {
1559 boundary = TX_PAGE_BOUNDARY;
1562 boundary = WMM_NORMAL_TX_PAGE_BOUNDARY;
1565 if (!pHalData->bMACFuncEnable)
1567 status = InitLLTTable(Adapter, boundary);
1568 if(status == _FAIL){
1569 RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("Failed to init LLT table\n"));
1575 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC01);
1576 if(pHalData->bRDGEnable){
1577 _InitRDGSetting(Adapter);
1581 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_DOWNLOAD_FW);
1583 status = rtl8723a_FirmwareDownload(Adapter);
1584 if(status != _SUCCESS)
1586 Adapter->bFWReady = _FALSE;
1587 pHalData->fw_ractrl = _FALSE;
1588 DBG_8723A("fw download fail!\n");
1593 Adapter->bFWReady = _TRUE;
1594 pHalData->fw_ractrl = _TRUE;
1595 DBG_8723A("fw download ok!\n");
1599 rtl8723a_InitializeFirmwareVars(Adapter);
1601 if(pwrctrlpriv->reg_rfoff == _TRUE){
1602 pwrctrlpriv->rf_pwrstate = rf_off;
1605 // 2010/08/09 MH We need to check if we need to turnon or off RF after detecting
1606 // HW GPIO pin. Before PHY_RFConfig8192C.
1607 //HalDetectPwrDownMode(Adapter);
1608 // 2010/08/26 MH If Efuse does not support sective suspend then disable the function.
1609 //HalDetectSelectiveSuspendMode(Adapter);
1611 // Set RF type for BB/RF configuration
1612 _InitRFType(Adapter);//->_ReadRFType()
1614 // Save target channel
1615 // <Roger_Notes> Current Channel will be updated again later.
1616 pHalData->CurrentChannel = 6;//default set to 6
1619 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MAC);
1620 #if (HAL_MAC_ENABLE == 1)
1621 status = PHY_MACConfig8723A(Adapter);
1624 DBG_8723A("PHY_MACConfig8723A fault !!\n");
1630 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_BB);
1632 //d. Initialize BB related configurations.
1634 #if (HAL_BB_ENABLE == 1)
1635 status = PHY_BBConfig8723A(Adapter);
1638 DBG_8723A("PHY_BBConfig8723A fault !!\n");
1644 // 2011/11/15 MH Add for tx power by rate fine tune. We need to call the function after BB config.
1645 // Because the tx power by rate table is inited in BB config.
1647 // HAL_AdjustPwrIndexDiffRateOffset(Adapter);
1648 // HAL_AdjustPwrIndexbyRegistry(Adapter);
1651 // The FW command register update must after MAC and FW init ready.
1652 if (Adapter->bFWReady == TRUE)
1654 if(pDevice->RegUsbSS)
1656 u1Byte u1H2CSSRf[3]={0};
1658 SET_H2CCMD_SELECTIVE_SUSPEND_ROF_CMD_ON(u1H2CSSRf, 1);
1659 SET_H2CCMD_SELECTIVE_SUSPEND_ROF_CMD_GPIO_PERIOD(u1H2CSSRf, 500);
1661 FillH2CCmd92C(Adapter, H2C_SELECTIVE_SUSPEND_ROF_CMD, 3, u1H2CSSRf);
1662 RT_TRACE(COMP_INIT, DBG_LOUD,
1663 ("SS Set H2C_CMD for FW detect GPIO time=%d\n", GET_H2CCMD_SELECTIVE_SUSPEND_ROF_CMD_GPIO_PERIOD(u1H2CSSRf)));
1666 RT_TRACE(COMP_INIT, DBG_LOUD, ("Non-SS Driver detect GPIO by itself\n"));
1670 RT_TRACE(COMP_INIT, DBG_LOUD, ("Adapter->bFWReady == FALSE\n"));
1671 // 2011/02/11 MH If FW is not ready, we can not enter seecitve suspend mode, otherwise,
1672 // We can not support GPIO/PBC detection by FW with selectiev suspend support.
1673 pDevice->RegUsbSS = FALSE;
1678 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_RF);
1679 #if (HAL_RF_ENABLE == 1)
1680 status = PHY_RFConfig8723A(Adapter);
1683 DBG_8723A("PHY_RFConfig8723A fault !!\n");
1688 PHY_SetBBReg(Adapter, RF_T_METER, bMaskDWord, 0x0381808d);
1689 PHY_SetBBReg(Adapter, RF_SYN_G4, bMaskDWord, 0xf2ffff83);
1690 PHY_SetBBReg(Adapter, RF_SYN_G4, bMaskDWord, 0xf2ffff82);
1691 PHY_SetBBReg(Adapter, RF_SYN_G4, bMaskDWord, 0xf2ffff83);
1694 PHY_SetBBReg(Adapter, rFPGA0_TxInfo, bMaskDWord, 0x00000003); //0x804[14]=0
1695 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFInterfaceSW, bMaskDWord, 0x07000760); //0x870[6:5]=b'11
1696 PHY_SetBBReg(Adapter, rFPGA0_XA_RFInterfaceOE, bMaskDWord, 0x66F60210); //0x860[6:5]=b'00
1698 RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("%s: 0x870 = value 0x%x\n", __FUNCTION__, PHY_QueryBBReg(Adapter, 0x870, bMaskDWord)));
1703 // Joseph Note: Keep RfRegChnlVal for later use.
1705 pHalData->RfRegChnlVal[0] = PHY_QueryRFReg(Adapter, (RF_RADIO_PATH_E)0, RF_CHNLBW, bRFRegOffsetMask);
1706 pHalData->RfRegChnlVal[1] = PHY_QueryRFReg(Adapter, (RF_RADIO_PATH_E)1, RF_CHNLBW, bRFRegOffsetMask);
1709 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC02);
1710 if (!pHalData->bMACFuncEnable) {
1711 _InitQueueReservedPage(Adapter);
1712 _InitTxBufferBoundary(Adapter);
1714 _InitQueuePriority(Adapter);
1715 _InitPageBoundary(Adapter);
1716 _InitTransferPageSize(Adapter);
1718 // Get Rx PHY status in order to report RSSI and others.
1719 _InitDriverInfoSize(Adapter, DRVINFO_SZ);
1721 _InitInterrupt(Adapter);
1722 hal_init_macaddr(Adapter);//set mac_address
1723 _InitNetworkType(Adapter);//set msr
1724 _InitWMACSetting(Adapter);
1725 _InitAdaptiveCtrl(Adapter);
1727 _InitRateFallback(Adapter);
1728 _InitRetryFunction(Adapter);
1729 InitUsbAggregationSetting(Adapter);
1730 _InitOperationMode(Adapter);//todo
1731 rtl8723a_InitBeaconParameters(Adapter);
1732 rtl8723a_InitBeaconMaxError(Adapter, _TRUE);
1734 #ifdef RTL8192CU_ADHOC_WORKAROUND_SETTING
1735 _InitAdhocWorkaroundParams(Adapter);
1738 #if ENABLE_USB_DROP_INCORRECT_OUT
1739 _InitHardwareDropIncorrectBulkOut(Adapter);
1742 #if defined(CONFIG_CONCURRENT_MODE) || defined(CONFIG_TX_MCAST2UNI)
1743 // Enable lifetime check for the four ACs
1744 rtw_write8(Adapter, REG_LIFETIME_EN, 0x0F);
1745 #ifdef CONFIG_TX_MCAST2UNI
1746 rtw_write16(Adapter, REG_PKT_VO_VI_LIFE_TIME, 0x0400); // unit: 256us. 256ms
1747 rtw_write16(Adapter, REG_PKT_BE_BK_LIFE_TIME, 0x0400); // unit: 256us. 256ms
1748 #else // CONFIG_TX_MCAST2UNI
1749 rtw_write16(Adapter, REG_PKT_VO_VI_LIFE_TIME, 0x3000); // unit: 256us. 3s
1750 rtw_write16(Adapter, REG_PKT_BE_BK_LIFE_TIME, 0x3000); // unit: 256us. 3s
1751 #endif // CONFIG_TX_MCAST2UNI
1752 #endif // CONFIG_CONCURRENT_MODE || CONFIG_TX_MCAST2UNI
1756 _InitHWLed(Adapter);
1759 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_TURN_ON_BLOCK);
1760 _BBTurnOnBlock(Adapter);
1761 //NicIFSetMacAddress(padapter, padapter->PermanentAddress);
1763 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_SECURITY);
1764 invalidate_cam_all(Adapter);
1766 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC11);
1767 // 2010/12/17 MH We need to set TX power according to EFUSE content at first.
1768 PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
1770 rtl8723a_InitAntenna_Selection(Adapter);
1773 //set 0x0 to 0xFF by tynli. Default enable HW SEQ NUM.
1774 rtw_write8(Adapter,REG_HWSEQ_CTRL, 0xFF);
1777 // Disable BAR, suggested by Scott
1778 // 2010.04.09 add by hpfan
1780 rtw_write32(Adapter, REG_BAR_MODE_CTRL, 0x0201ffff);
1782 if(pregistrypriv->wifi_spec)
1783 rtw_write16(Adapter,REG_FAST_EDCA_CTRL ,0);
1785 // Move by Neo for USB SS from above setp
1786 _RfPowerSave(Adapter);
1788 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_IQK);
1789 // 2010/08/26 MH Merge from 8192CE.
1790 //sherry masked that it has been done in _RfPowerSave
1792 //recovery for 8192cu and 9723Au 20111017
1793 if(pwrctrlpriv->rf_pwrstate == rf_on)
1795 if(pHalData->bIQKInitialized ){
1796 rtl8192c_PHY_IQCalibrate(Adapter,_TRUE);
1798 rtl8192c_PHY_IQCalibrate(Adapter,_FALSE);
1799 pHalData->bIQKInitialized = _TRUE;
1802 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_PW_TRACK);
1803 rtl8192c_odm_CheckTXPowerTracking(Adapter);
1805 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_LCK);
1806 rtl8192c_PHY_LCCalibrate(Adapter);
1808 #ifdef CONFIG_BT_COEXIST
1809 rtl8723a_SingleDualAntennaDetection(Adapter);
1814 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC21);
1815 #ifdef USB_INTERFERENCE_ISSUE
1816 //fixed USB interface interference issue
1817 rtw_write8(Adapter, 0xfe40, 0xe0);
1818 rtw_write8(Adapter, 0xfe41, 0x8d);
1819 rtw_write8(Adapter, 0xfe42, 0x80);
1820 rtw_write32(Adapter,0x20c,0xfd0320);
1822 //2011/01/07 ,suggest by Johnny,for solved the problem that too many protocol error on USB bus
1823 if(!IS_81xxC_VENDOR_UMC_A_CUT(pHalData->VersionID) )//&& !IS_92C_SERIAL(pHalData->VersionID))// TSMC , 8188
1826 rtw_write8(Adapter, 0xFE40, 0xE6);
1827 rtw_write8(Adapter, 0xFE41, 0x94);
1828 rtw_write8(Adapter, 0xFE42, 0x80);
1831 rtw_write8(Adapter, 0xFE40, 0xE0);
1832 rtw_write8(Adapter, 0xFE41, 0x19);
1833 rtw_write8(Adapter, 0xFE42, 0x80);
1836 rtw_write8(Adapter, 0xFE40, 0xE5);
1837 rtw_write8(Adapter, 0xFE41, 0x91);
1838 rtw_write8(Adapter, 0xFE42, 0x80);
1841 rtw_write8(Adapter, 0xFE40, 0xE2);
1842 rtw_write8(Adapter, 0xFE41, 0x81);
1843 rtw_write8(Adapter, 0xFE42, 0x80);
1848 #endif //USB_INTERFERENCE_ISSUE
1850 //HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_PABIAS);
1851 // _InitPABias(Adapter);
1853 #ifdef CONFIG_BT_COEXIST
1854 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_BT_COEXIST);
1855 // Init BT hw config.
1856 BT_InitHwConfig(Adapter);
1859 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_HAL_DM);
1860 rtl8723a_InitHalDm(Adapter);
1863 // 2010/05/20 MH We need to init timer after update setting. Otherwise, we can not get correct inf setting.
1864 // 2010/05/18 MH For SE series only now. Init GPIO detect time
1865 if(pDevice->RegUsbSS)
1867 RT_TRACE(COMP_INIT, DBG_LOUD, (" call GpioDetectTimerStart8192CU\n"));
1868 GpioDetectTimerStart8192CU(Adapter); // Disable temporarily
1871 // 2010/08/23 MH According to Alfred's suggestion, we need to to prevent HW enter
1872 // suspend mode automatically.
1873 HwSuspendModeEnable92Cu(Adapter, _FALSE);
1876 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC31);
1877 rtw_hal_set_hwreg(Adapter, HW_VAR_NAV_UPPER, (u8*)&NavUpper);
1879 // 2011/03/09 MH debug only, UMC-B cut pass 2500 S5 test, but we need to fin root cause.
1880 if (((rtw_read32(Adapter, rFPGA0_RFMOD) & 0xFF000000) != 0x83000000)) {
1881 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT(24), 1);
1882 RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("%s: IQK fail recorver\n", __FUNCTION__));
1885 #ifdef CONFIG_XMIT_ACK
1886 //ack for xmit mgmt frames.
1887 rtw_write32(Adapter, REG_FWHW_TXQ_CTRL, rtw_read32(Adapter, REG_FWHW_TXQ_CTRL)|BIT(12));
1888 #endif //CONFIG_XMIT_ACK
1890 //_dbg_dump_macreg(padapter);
1893 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_END);
1895 DBG_8723A("%s in %dms\n", __FUNCTION__, rtw_get_passing_time_ms(init_start_time));
1897 #ifdef DBG_HAL_INIT_PROFILING
1898 hal_init_stages_timestamp[HAL_INIT_STAGES_END]=rtw_get_current_time();
1900 for(hal_init_profiling_i=0;hal_init_profiling_i<HAL_INIT_STAGES_NUM-1;hal_init_profiling_i++) {
1901 DBG_8723A("DBG_HAL_INIT_PROFILING: %35s, %u, %5u, %5u\n"
1902 , hal_init_stages_str[hal_init_profiling_i]
1903 , hal_init_stages_timestamp[hal_init_profiling_i]
1904 , (hal_init_stages_timestamp[hal_init_profiling_i+1]-hal_init_stages_timestamp[hal_init_profiling_i])
1905 , rtw_get_time_interval_ms(hal_init_stages_timestamp[hal_init_profiling_i], hal_init_stages_timestamp[hal_init_profiling_i+1])
1916 #define SYNC_SD7_20110802_phy_SsPwrSwitch92CU
1917 #ifdef SYNC_SD7_20110802_phy_SsPwrSwitch92CU
1919 phy_SsPwrSwitch92CU(
1921 rt_rf_power_state eRFPowerState,
1925 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1928 switch( eRFPowerState )
1931 if (bRegSSPwrLvl == 1)
1933 // 1. Enable MAC Clock. Can not be enabled now.
1934 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) | BIT(3));
1936 // 2. Force PWM, Enable SPS18_LDO_Marco_Block
1937 rtw_write8(Adapter, REG_SPS0_CTRL,
1938 rtw_read8(Adapter, REG_SPS0_CTRL) | (BIT0|BIT3));
1940 // 3. restore BB, AFE control register.
1942 if (pHalData->rf_type == RF_2T2R)
1943 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 1);
1945 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 1);
1946 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 1);
1947 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1, 0);
1950 //DbgPrint("0x0e70 = %x\n", Adapter->PS_BBRegBackup[PSBBREG_AFE0]);
1951 //PHY_SetBBReg(Adapter, 0x0e70, bMaskDWord ,Adapter->PS_BBRegBackup[PSBBREG_AFE0] );
1952 //PHY_SetBBReg(Adapter, 0x0e70, bMaskDWord ,0x631B25A0 );
1953 if (pHalData->rf_type == RF_2T2R)
1954 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x63DB25A0 );
1955 else if (pHalData->rf_type == RF_1T1R)
1956 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x631B25A0 );
1958 // 4. issue 3-wire command that RF set to Rx idle mode. This is used to re-write the RX idle mode.
1959 // We can only prvide a usual value instead and then HW will modify the value by itself.
1960 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0x32D95);
1961 if (pHalData->rf_type == RF_2T2R)
1963 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0x32D95);
1966 else // Level 2 or others.
1968 //h. AFE_PLL_CTRL 0x28[7:0] = 0x80 //disable AFE PLL
1969 rtw_write8(Adapter, REG_AFE_PLL_CTRL, 0x81);
1971 // i. AFE_XTAL_CTRL 0x24[15:0] = 0x880F //gated AFE DIG_CLOCK
1972 rtw_write16(Adapter, REG_AFE_XTAL_CTRL, 0x800F);
1975 // 1. Enable MAC Clock. Can not be enabled now.
1976 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) | BIT(3));
1978 // 2. Force PWM, Enable SPS18_LDO_Marco_Block
1979 rtw_write8(Adapter, REG_SPS0_CTRL,
1980 rtw_read8(Adapter, REG_SPS0_CTRL) | (BIT0|BIT3));
1982 // 3. restore BB, AFE control register.
1984 if (pHalData->rf_type == RF_2T2R)
1985 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 1);
1987 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 1);
1988 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 1);
1989 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1, 0);
1992 if (pHalData->rf_type == RF_2T2R)
1993 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x63DB25A0 );
1994 else if (pHalData->rf_type == RF_1T1R)
1995 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x631B25A0 );
1997 // 4. issue 3-wire command that RF set to Rx idle mode. This is used to re-write the RX idle mode.
1998 // We can only prvide a usual value instead and then HW will modify the value by itself.
1999 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0x32D95);
2000 if (pHalData->rf_type == RF_2T2R)
2002 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0x32D95);
2005 // 5. gated MAC Clock
2006 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) & ~(BIT(3)));
2007 //rtw_write8(Adapter, REG_SYS_CLKR+1, rtw_read8(Adapter, REG_SYS_CLKR+1)|(BIT3));
2010 //u8 eRFPath = RF_PATH_A,value8 = 0, retry = 0;
2012 //PHY_SetRFReg(Adapter, (RF_RADIO_PATH_E)eRFPath, 0x0, bMaskByte0, 0x0);
2013 // 2010/08/12 MH Add for B path under SS test.
2014 //if (pHalData->RF_Type == RF_2T2R)
2015 //PHY_SetRFReg(Adapter, RF_PATH_B, 0x0, bMaskByte0, 0x0);
2017 bytetmp = rtw_read8(Adapter, REG_APSD_CTRL);
2018 rtw_write8(Adapter, REG_APSD_CTRL, bytetmp & ~BIT6);
2022 // Set BB reset at first
2023 rtw_write8(Adapter, REG_SYS_FUNC_EN, 0x17 );//0x16
2026 rtw_write8(Adapter, REG_TXPAUSE, 0x0);
2028 //CardSelectiveSuspendLeave(Adapter);
2035 value8 = rtw_read8(Adapter, REG_SPS0_CTRL) ;
2036 if (IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID))
2039 value8 &= ~(BIT0|BIT3);
2040 if (bRegSSPwrLvl == 1)
2042 RT_TRACE(_module_hal_init_c_, _drv_err_, ("SS LVL1\n"));
2043 // Disable RF and BB only for SelectSuspend.
2045 // 1. Set BB/RF to shutdown.
2046 // (1) Reg878[5:3]= 0 // RF rx_code for preamble power saving
2047 // (2)Reg878[21:19]= 0 //Turn off RF-B
2048 // (3) RegC04[7:4]= 0 // turn off all paths for packet detection
2049 // (4) Reg800[1] = 1 // enable preamble power saving
2050 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF0] = PHY_QueryBBReg(Adapter, rFPGA0_XAB_RFParameter, bMaskDWord);
2051 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF1] = PHY_QueryBBReg(Adapter, rOFDM0_TRxPathEnable, bMaskDWord);
2052 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF2] = PHY_QueryBBReg(Adapter, rFPGA0_RFMOD, bMaskDWord);
2053 if (pHalData->rf_type == RF_2T2R)
2055 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 0);
2057 else if (pHalData->rf_type == RF_1T1R)
2059 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 0);
2061 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 0);
2062 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1,1);
2064 // 2 .AFE control register to power down. bit[30:22]
2065 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_AFE0] = PHY_QueryBBReg(Adapter, rRx_Wait_CCA, bMaskDWord);
2066 if (pHalData->rf_type == RF_2T2R)
2067 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x00DB25A0);
2068 else if (pHalData->rf_type == RF_1T1R)
2069 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x001B25A0);
2071 // 3. issue 3-wire command that RF set to power down.
2072 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0);
2073 if (pHalData->rf_type == RF_2T2R)
2075 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0);
2078 // 4. Force PFM , disable SPS18_LDO_Marco_Block
2079 rtw_write8(Adapter, REG_SPS0_CTRL, value8);
2081 // 5. gated MAC Clock
2082 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) & ~(BIT(3)));
2084 else // Level 2 or others.
2086 RT_TRACE(_module_hal_init_c_, _drv_err_, ("SS LVL2\n"));
2088 u8 eRFPath = RF_PATH_A,value8 = 0;
2089 rtw_write8(Adapter, REG_TXPAUSE, 0xFF);
2090 PHY_SetRFReg(Adapter, (RF_RADIO_PATH_E)eRFPath, 0x0, bMaskByte0, 0x0);
2091 // 2010/08/12 MH Add for B path under SS test.
2092 //if (pHalData->RF_Type == RF_2T2R)
2093 //PHY_SetRFReg(Adapter, RF_PATH_B, 0x0, bMaskByte0, 0x0);
2096 rtw_write8(Adapter, REG_APSD_CTRL, value8);//0x40
2098 // After switch APSD, we need to delay for stability
2101 // Set BB reset at first
2103 value8 |=( FEN_USBD | FEN_USBA | FEN_BB_GLB_RSTn);
2104 rtw_write8(Adapter, REG_SYS_FUNC_EN,value8 );//0x16
2107 // Disable RF and BB only for SelectSuspend.
2109 // 1. Set BB/RF to shutdown.
2110 // (1) Reg878[5:3]= 0 // RF rx_code for preamble power saving
2111 // (2)Reg878[21:19]= 0 //Turn off RF-B
2112 // (3) RegC04[7:4]= 0 // turn off all paths for packet detection
2113 // (4) Reg800[1] = 1 // enable preamble power saving
2114 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF0] = PHY_QueryBBReg(Adapter, rFPGA0_XAB_RFParameter, bMaskDWord);
2115 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF1] = PHY_QueryBBReg(Adapter, rOFDM0_TRxPathEnable, bMaskDWord);
2116 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF2] = PHY_QueryBBReg(Adapter, rFPGA0_RFMOD, bMaskDWord);
2117 if (pHalData->rf_type == RF_2T2R)
2119 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 0);
2121 else if (pHalData->rf_type == RF_1T1R)
2123 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 0);
2125 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 0);
2126 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1,1);
2128 // 2 .AFE control register to power down. bit[30:22]
2129 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_AFE0] = PHY_QueryBBReg(Adapter, rRx_Wait_CCA, bMaskDWord);
2130 if (pHalData->rf_type == RF_2T2R)
2131 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x00DB25A0);
2132 else if (pHalData->rf_type == RF_1T1R)
2133 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x001B25A0);
2135 // 3. issue 3-wire command that RF set to power down.
2136 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0);
2137 if (pHalData->rf_type == RF_2T2R)
2139 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0);
2142 // 4. Force PFM , disable SPS18_LDO_Marco_Block
2143 rtw_write8(Adapter, REG_SPS0_CTRL, value8);
2145 // 2010/10/13 MH/Isaachsu exchange sequence.
2146 //h. AFE_PLL_CTRL 0x28[7:0] = 0x80 //disable AFE PLL
2147 rtw_write8(Adapter, REG_AFE_PLL_CTRL, 0x80);
2150 // i. AFE_XTAL_CTRL 0x24[15:0] = 0x880F //gated AFE DIG_CLOCK
2151 rtw_write16(Adapter, REG_AFE_XTAL_CTRL, 0xA80F);
2153 // 5. gated MAC Clock
2154 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) & ~(BIT(3)));
2155 //rtw_write8(Adapter, REG_SYS_CLKR+1, rtw_read8(Adapter, REG_SYS_CLKR+1)& ~(BIT3))
2157 //CardSelectiveSuspendEnter(Adapter);
2166 } // phy_PowerSwitch92CU
2168 void _ps_open_RF(_adapter *padapter) {
2169 //here call with bRegSSPwrLvl 1, bRegSSPwrLvl 2 needs to be verified
2170 phy_SsPwrSwitch92CU(padapter, rf_on, 1);
2173 void _ps_close_RF(_adapter *padapter){
2174 //here call with bRegSSPwrLvl 1, bRegSSPwrLvl 2 needs to be verified
2175 phy_SsPwrSwitch92CU(padapter, rf_off, 1);
2177 #endif //SYNC_SD7_20110802_phy_SsPwrSwitch92CU
2186 /***************************************
2187 j. GPIO_PIN_CTRL 0x44[31:0]=0x000 //
2188 k. Value = GPIO_PIN_CTRL[7:0]
2189 l. GPIO_PIN_CTRL 0x44[31:0] = 0x00FF0000 | (value <<8); //write external PIN level
2190 m. GPIO_MUXCFG 0x42 [15:0] = 0x0780
2191 n. LEDCFG 0x4C[15:0] = 0x8080
2192 ***************************************/
2197 //1. Disable GPIO[7:0]
2198 rtw_write16(Adapter, REG_GPIO_PIN_CTRL+2, 0x0000);
2199 value32 = rtw_read32(Adapter, REG_GPIO_PIN_CTRL) & 0xFFFF00FF;
2200 value8 = (u8) (value32&0x000000FF);
2201 value32 |= ((value8<<8) | 0x00FF0000);
2202 rtw_write32(Adapter, REG_GPIO_PIN_CTRL, value32);
2204 //2. Disable GPIO[10:8]
2205 rtw_write8(Adapter, REG_GPIO_MUXCFG+3, 0x00);
2206 value16 = rtw_read16(Adapter, REG_GPIO_MUXCFG+2) & 0xFF0F;
2207 value8 = (u8) (value16&0x000F);
2208 value16 |= ((value8<<4) | 0x0780);
2209 rtw_write16(Adapter, REG_GPIO_MUXCFG+2, value16);
2211 //3. Disable LED0 & 1
2212 rtw_write16(Adapter, REG_LEDCFG0, 0x8080);
2214 //RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Disable GPIO and LED.\n"));
2216 } //end of _DisableGPIO()
2219 _ResetFWDownloadRegister(
2225 value32 = rtw_read32(Adapter, REG_MCUFWDL);
2226 value32 &= ~(MCUFWDL_EN | MCUFWDL_RDY);
2227 rtw_write32(Adapter, REG_MCUFWDL, value32);
2228 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Reset FW download register.\n"));
2237 int rtStatus = _SUCCESS;
2238 u32 pollingCount = 0;
2241 //disable RF/ AFE AD/DA
2243 rtw_write8(Adapter, REG_APSD_CTRL, value8);
2246 #if (RTL8192CU_ASIC_VERIFICATION)
2250 if(rtw_read8(Adapter, REG_APSD_CTRL) & APSDOFF_STATUS){
2251 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Disable RF, AFE, AD, DA Done!\n"));
2255 if(pollingCount++ > POLLING_READY_TIMEOUT_COUNT){
2256 //RT_TRACE(COMP_INIT, DBG_SERIOUS, ("Failed to polling APSDOFF_STATUS done!\n"));
2264 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Disable RF, AFE,AD, DA.\n"));
2277 value16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
2278 value16 &= ~(FEN_BBRSTB | FEN_BB_GLB_RSTn);
2279 rtw_write16(Adapter, REG_SYS_FUNC_EN, value16);
2280 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Reset BB.\n"));
2291 value16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
2292 value16 &= ~FEN_CPUEN;
2293 rtw_write16(Adapter, REG_SYS_FUNC_EN, value16);
2294 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Reset MCU.\n"));
2298 _DisableMAC_AFE_PLL(
2304 //disable MAC/ AFE PLL
2305 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
2306 value32 |= APDM_MAC;
2307 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2309 value32 |= APFM_OFF;
2310 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2311 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Disable MAC, AFE PLL.\n"));
2315 _AutoPowerDownToHostOff(
2320 rtw_write8(Adapter, REG_SPS0_CTRL, 0x22);
2322 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
2324 value32 |= APDM_HOST;//card disable
2325 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2326 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Auto Power Down to Host-off state.\n"));
2329 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
2330 value32 &= ~AFSM_PCIE;
2331 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2342 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
2345 value32 |= AFSM_HSUS;
2346 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2348 //RT_ASSERT(0 == (rtw_read32(Adapter, REG_APS_FSMCO) & BIT(12)),(""));
2349 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Set USB suspend.\n"));
2354 _DisableRFAFEAndResetBB(
2358 /**************************************
2359 a. TXPAUSE 0x522[7:0] = 0xFF //Pause MAC TX queue
2360 b. RF path 0 offset 0x00 = 0x00 // disable RF
2361 c. APSD_CTRL 0x600[7:0] = 0x40
2362 d. SYS_FUNC_EN 0x02[7:0] = 0x16 //reset BB state machine
2363 e. SYS_FUNC_EN 0x02[7:0] = 0x14 //reset BB state machine
2364 ***************************************/
2365 u8 eRFPath = 0,value8 = 0;
2366 rtw_write8(Adapter, REG_TXPAUSE, 0xFF);
2367 PHY_SetRFReg(Adapter, (RF_RADIO_PATH_E)eRFPath, 0x0, bMaskByte0, 0x0);
2370 rtw_write8(Adapter, REG_APSD_CTRL, value8);//0x40
2373 value8 |=( FEN_USBD | FEN_USBA | FEN_BB_GLB_RSTn);
2374 rtw_write8(Adapter, REG_SYS_FUNC_EN,value8 );//0x16
2376 value8 &=( ~FEN_BB_GLB_RSTn );
2377 rtw_write8(Adapter, REG_SYS_FUNC_EN, value8); //0x14
2379 //RT_TRACE(COMP_INIT, DBG_LOUD, ("======> RF off and reset BB.\n"));
2383 _ResetDigitalProcedure1(
2389 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2391 if(pHalData->FirmwareVersion <= 0x20){
2393 /*****************************
2394 f. SYS_FUNC_EN 0x03[7:0]=0x54 // reset MAC register, DCORE
2395 g. MCUFWDL 0x80[7:0]=0 // reset MCU ready status
2396 ******************************/
2398 PlatformIOWrite1Byte(Adapter, REG_SYS_FUNC_EN+1, 0x54);
2399 PlatformIOWrite1Byte(Adapter, REG_MCUFWDL, 0);
2401 /*****************************
2402 f. MCUFWDL 0x80[7:0]=0 // reset MCU ready status
2403 g. SYS_FUNC_EN 0x02[10]= 0 // reset MCU register, (8051 reset)
2404 h. SYS_FUNC_EN 0x02[15-12]= 5 // reset MAC register, DCORE
2405 i. SYS_FUNC_EN 0x02[10]= 1 // enable MCU register, (8051 enable)
2406 ******************************/
2408 rtw_write8(Adapter, REG_MCUFWDL, 0);
2410 valu16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
2411 rtw_write16(Adapter, REG_SYS_FUNC_EN, (valu16 & (~FEN_CPUEN)));//reset MCU ,8051
2413 valu16 = rtw_read16(Adapter, REG_SYS_FUNC_EN)&0x0FFF;
2414 rtw_write16(Adapter, REG_SYS_FUNC_EN, (valu16 |(FEN_HWPDN|FEN_ELDR)));//reset MAC
2416 #ifdef DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE
2419 if( (val=rtw_read8(Adapter, REG_MCUFWDL)))
2420 DBG_8723A("DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE %s:%d REG_MCUFWDL:0x%02x\n", __FUNCTION__, __LINE__, val);
2425 valu16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
2426 rtw_write16(Adapter, REG_SYS_FUNC_EN, (valu16 | FEN_CPUEN));//enable MCU ,8051
2434 if(rtw_read8(Adapter, REG_MCUFWDL) & BIT1)
2435 { //IF fw in RAM code, do reset
2437 rtw_write8(Adapter, REG_MCUFWDL, 0);
2438 if(Adapter->bFWReady){
2439 // 2010/08/25 MH Accordign to RD alfred's suggestion, we need to disable other
2440 // HRCV INT to influence 8051 reset.
2441 rtw_write8(Adapter, REG_FWIMR, 0x20);
2443 rtw_write8(Adapter, REG_HMETFR+3, 0x20);//8051 reset by self
2445 while( (retry_cnts++ <100) && (FEN_CPUEN &rtw_read16(Adapter, REG_SYS_FUNC_EN)))
2447 rtw_udelay_os(50);//PlatformStallExecution(50);//us
2450 if(retry_cnts >= 100){
2451 DBG_8723A("%s #####=> 8051 reset failed!.........................\n", __FUNCTION__);
2452 // if 8051 reset fail we trigger GPIO 0 for LA
2453 //PlatformEFIOWrite4Byte( Adapter,
2454 // REG_GPIO_PIN_CTRL,
2456 // 2010/08/31 MH According to Filen's info, if 8051 reset fail, reset MAC directly.
2457 rtw_write8(Adapter, REG_SYS_FUNC_EN+1, 0x50); //Reset MAC and Enable 8051
2461 //DBG_8723A("%s =====> 8051 reset success (%d) .\n", __FUNCTION__, retry_cnts);
2465 DBG_8723A("%s =====> 8051 in RAM but !Adapter->bFWReady\n", __FUNCTION__);
2469 //DBG_8723A("%s =====> 8051 in ROM.\n", __FUNCTION__);
2472 #ifdef DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE
2475 if( (val=rtw_read8(Adapter, REG_MCUFWDL)))
2476 DBG_8723A("DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE %s:%d REG_MCUFWDL:0x%02x\n", __FUNCTION__, __LINE__, val);
2480 rtw_write8(Adapter, REG_SYS_FUNC_EN+1, 0x54); //Reset MAC and Enable 8051
2483 // Clear rpwm value for initial toggle bit trigger.
2484 rtw_write8(Adapter, REG_USB_HRPWM, 0x00);
2487 /*****************************
2488 Without HW auto state machine
2489 g. SYS_CLKR 0x08[15:0] = 0x30A3 //disable MAC clock
2490 h. AFE_PLL_CTRL 0x28[7:0] = 0x80 //disable AFE PLL
2491 i. AFE_XTAL_CTRL 0x24[15:0] = 0x880F //gated AFE DIG_CLOCK
2492 j. SYS_ISO_CTRL 0x00[7:0] = 0xF9 // isolated digital to PON
2493 ******************************/
2494 //rtw_write16(Adapter, REG_SYS_CLKR, 0x30A3);
2495 rtw_write16(Adapter, REG_SYS_CLKR, 0x70A3);//modify to 0x70A3 by Scott.
2496 rtw_write8(Adapter, REG_AFE_PLL_CTRL, 0x80);
2497 rtw_write16(Adapter, REG_AFE_XTAL_CTRL, 0x880F);
2498 rtw_write8(Adapter, REG_SYS_ISO_CTRL, 0xF9);
2502 // Disable all RF/BB power
2503 rtw_write8(Adapter, REG_RF_CTRL, 0x00);
2505 //RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Reset Digital.\n"));
2510 _ResetDigitalProcedure2(
2514 /*****************************
2515 k. SYS_FUNC_EN 0x03[7:0] = 0x44 // disable ELDR runction
2516 l. SYS_CLKR 0x08[15:0] = 0x3083 // disable ELDR clock
2517 m. SYS_ISO_CTRL 0x01[7:0] = 0x83 // isolated ELDR to PON
2518 ******************************/
2519 //rtw_write8(Adapter, REG_SYS_FUNC_EN+1, 0x44);//marked by Scott.
2520 //rtw_write16(Adapter, REG_SYS_CLKR, 0x3083);
2521 //rtw_write8(Adapter, REG_SYS_ISO_CTRL+1, 0x83);
2523 rtw_write16(Adapter, REG_SYS_CLKR, 0x70a3); //modify to 0x70a3 by Scott.
2524 rtw_write8(Adapter, REG_SYS_ISO_CTRL+1, 0x82); //modify to 0x82 by Scott.
2535 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2538 /*****************************
2539 n. LDOA15_CTRL 0x20[7:0] = 0x04 // disable A15 power
2540 o. LDOV12D_CTRL 0x21[7:0] = 0x54 // disable digital core power
2541 r. When driver call disable, the ASIC will turn off remaining clock automatically
2542 ******************************/
2544 rtw_write8(Adapter, REG_LDOA15_CTRL, 0x04);
2545 //PlatformIOWrite1Byte(Adapter, REG_LDOV12D_CTRL, 0x54);
2547 value8 = rtw_read8(Adapter, REG_LDOV12D_CTRL);
2548 value8 &= (~LDV12_EN);
2549 rtw_write8(Adapter, REG_LDOV12D_CTRL, value8);
2550 //RT_TRACE(COMP_INIT, DBG_LOUD, (" REG_LDOV12D_CTRL Reg0x21:0x%02x.\n",value8));
2553 /*****************************
2554 h. SPS0_CTRL 0x11[7:0] = 0x23 //enter PFM mode
2555 i. APS_FSMCO 0x04[15:0] = 0x4802 // set USB suspend
2556 ******************************/
2560 if (IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID))
2563 rtw_write8(Adapter, REG_SPS0_CTRL, value8);
2568 //value16 |= (APDM_HOST | /*AFSM_HSUS |*/PFM_ALDN);
2569 // 2010/08/31 According to Filen description, we need to use HW to shut down 8051 automatically.
2570 // Becasue suspend operatione need the asistance of 8051 to wait for 3ms.
2571 value16 |= (APDM_HOST | AFSM_HSUS |PFM_ALDN);
2575 value16 |= (APDM_HOST | AFSM_HSUS |PFM_ALDN);
2578 rtw_write16(Adapter, REG_APS_FSMCO,value16 );//0x4802
2580 rtw_write8(Adapter, REG_RSV_CTRL, 0x0e);
2583 //tynli_test for suspend mode.
2585 rtw_write8(Adapter, 0xfe10, 0x19);
2589 //RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Disable Analog Reg0x04:0x%04x.\n",value16));
2592 static void rtl8723au_hw_power_down(_adapter *padapter)
2596 DBG_8723A("PowerDownRTL8723U\n");
2599 // 1. Run Card Disable Flow
2600 // Done before this function call.
2602 // 2. 0x04[16] = 0 // reset WLON
2603 u1bTmp = rtw_read8(padapter, REG_APS_FSMCO+2);
2604 rtw_write8(padapter, REG_APS_FSMCO+2, (u1bTmp&(~BIT0)));
2606 // 3. 0x04[12:11] = 2b'11 // enable suspend
2607 // Done before this function call.
2609 // 4. 0x04[15] = 1 // enable PDN
2610 u1bTmp = rtw_read8(padapter, REG_APS_FSMCO+1);
2611 rtw_write8(padapter, REG_APS_FSMCO+1, (u1bTmp|BIT7));
2615 // Description: RTL8723e card disable power sequence v003 which suggested by Scott.
2616 // First created by tynli. 2011.01.28.
2619 CardDisableRTL8723U(
2624 // PMGNT_INFO pMgntInfo = &(Adapter->MgntInfo);
2626 DBG_8723A("CardDisableRTL8723U\n");
2628 // USB-MF Card Disable Flow
2629 // 1. Run LPS WL RFOFF flow
2630 HalPwrSeqCmdParsing(Adapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, rtl8723A_enter_lps_flow);
2632 // 2. 0x1F[7:0] = 0 // turn off RF
2633 rtw_write8(Adapter, REG_RF_CTRL, 0x00);
2635 // ==== Reset digital sequence ======
2636 if((rtw_read8(Adapter, REG_MCUFWDL)&BIT7) &&
2637 Adapter->bFWReady) //8051 RAM code
2639 rtl8723a_FirmwareSelfReset(Adapter);
2642 // Reset MCU. Suggested by Filen. 2011.01.26. by tynli.
2643 u1bTmp = rtw_read8(Adapter, REG_SYS_FUNC_EN+1);
2644 rtw_write8(Adapter, REG_SYS_FUNC_EN+1, (u1bTmp&(~BIT2)));
2646 // g. MCUFWDL 0x80[1:0]=0 // reset MCU ready status
2647 rtw_write8(Adapter, REG_MCUFWDL, 0x00);
2649 // ==== Reset digital sequence end ======
2650 // if((pMgntInfo->RfOffReason & RF_CHANGE_BY_HW) )
2652 // Card disable power action flow
2653 HalPwrSeqCmdParsing(Adapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, rtl8723A_card_disable_flow);
2656 // Reset MCU IO Wrapper, added by Roger, 2011.08.30.
2657 u1bTmp = rtw_read8(Adapter, REG_RSV_CTRL+1);
2658 rtw_write8(Adapter, REG_RSV_CTRL+1, (u1bTmp&(~BIT0)));
2659 u1bTmp = rtw_read8(Adapter, REG_RSV_CTRL+1);
2660 rtw_write8(Adapter, REG_RSV_CTRL+1, u1bTmp|BIT0);
2662 // 7. RSV_CTRL 0x1C[7:0] = 0x0E // lock ISO/CLK/Power control register
2663 rtw_write8(Adapter, REG_RSV_CTRL, 0x0e);
2668 u32 rtl8723au_hal_deinit(PADAPTER padapter)
2670 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
2673 DBG_8723A("==> %s\n", __FUNCTION__);
2675 #ifdef CONFIG_BT_COEXIST
2676 BT_HaltProcess(padapter);
2678 // 2011/02/18 To Fix RU LNA power leakage problem. We need to execute below below in
2679 // Adapter init and halt sequence. Accordingto EEchou's opinion, we can enable the ability for all
2680 // IC. Accord to johnny's opinion, only RU need the support.
2681 CardDisableRTL8723U(padapter);
2687 unsigned int rtl8723au_inirp_init(PADAPTER Adapter)
2690 struct recv_buf *precvbuf;
2692 struct dvobj_priv *pdev= adapter_to_dvobj(Adapter);
2693 struct intf_hdl * pintfhdl=&Adapter->iopriv.intf;
2694 struct recv_priv *precvpriv = &(Adapter->recvpriv);
2695 u32 (*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
2696 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2697 u32 (*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
2698 HAL_DATA_TYPE *pHalData=GET_HAL_DATA(Adapter);
2699 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2703 _read_port = pintfhdl->io_ops._read_port;
2707 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("===> usb_inirp_init \n"));
2709 precvpriv->ff_hwaddr = RECV_BULK_IN_ADDR;
2711 //issue Rx irp to receive data
2712 precvbuf = (struct recv_buf *)precvpriv->precv_buf;
2713 for(i=0; i<NR_RECVBUFF; i++)
2715 if(_read_port(pintfhdl, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf) == _FALSE )
2717 RT_TRACE(_module_hci_hal_init_c_,_drv_err_,("usb_rx_init: usb_read_port error \n"));
2723 precvpriv->free_recv_buf_queue_cnt--;
2726 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2727 _read_interrupt = pintfhdl->io_ops._read_interrupt;
2728 if(_read_interrupt(pintfhdl, RECV_INT_IN_ADDR) == _FALSE )
2730 RT_TRACE(_module_hci_hal_init_c_,_drv_err_,("usb_rx_init: usb_read_interrupt error \n"));
2733 pHalData->IntrMask[0]=rtw_read32(Adapter, REG_USB_HIMR);
2734 MSG_8723A("pHalData->IntrMask = 0x%04x\n", pHalData->IntrMask[0]);
2735 pHalData->IntrMask[0]|=UHIMR_C2HCMD|UHIMR_CPWM;
2736 rtw_write32(Adapter, REG_USB_HIMR,pHalData->IntrMask[0]);
2737 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2741 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("<=== usb_inirp_init \n"));
2749 unsigned int rtl8723au_inirp_deinit(PADAPTER Adapter)
2751 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2752 u32 (*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
2753 HAL_DATA_TYPE *pHalData=GET_HAL_DATA(Adapter);
2754 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2755 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("\n ===> usb_rx_deinit \n"));
2757 rtw_read_port_cancel(Adapter);
2758 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2759 pHalData->IntrMask[0]=rtw_read32(Adapter, REG_USB_HIMR);
2760 MSG_8723A("%s pHalData->IntrMask = 0x%04x\n",__FUNCTION__, pHalData->IntrMask[0]);
2761 pHalData->IntrMask[0]=0x0;
2762 rtw_write32(Adapter, REG_USB_HIMR,pHalData->IntrMask[0]);
2763 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("\n <=== usb_rx_deinit \n"));
2764 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2774 //RT_ASSERT((channel < 14), ("Channel %d no is supported!\n"));
2776 if(channel < 3){ // Channel 1~3
2779 else if(channel < 9){ // Channel 4~9
2783 return 2; // Channel 10~14
2787 //-------------------------------------------------------------------
2789 // EEPROM/EFUSE Content Parsing
2791 //-------------------------------------------------------------------
2799 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2801 if(_FALSE == AutoloadFail){
2803 pHalData->EEPROMVID = le16_to_cpu( *(u16 *)&PROMContent[EEPROM_VID]);
2804 pHalData->EEPROMPID = le16_to_cpu( *(u16 *)&PROMContent[EEPROM_PID]);
2806 // Customer ID, 0x00 and 0xff are reserved for Realtek.
2807 pHalData->EEPROMCustomerID = *(u8 *)&PROMContent[EEPROM_CUSTOMER_ID];
2808 pHalData->EEPROMSubCustomerID = *(u8 *)&PROMContent[EEPROM_SUBCUSTOMER_ID];
2812 pHalData->EEPROMVID = EEPROM_Default_VID;
2813 pHalData->EEPROMPID = EEPROM_Default_PID;
2815 // Customer ID, 0x00 and 0xff are reserved for Realtek.
2816 pHalData->EEPROMCustomerID = EEPROM_Default_CustomerID;
2817 pHalData->EEPROMSubCustomerID = EEPROM_Default_SubCustomerID;
2821 // For customized behavior.
2822 if((pHalData->EEPROMVID == 0x103C) || (pHalData->EEPROMVID == 0x1629))// HP Lite-On for RTL8188CUS Slim Combo.
2823 pHalData->CustomerID = RT_CID_819x_HP;
2825 // Decide CustomerID according to VID/DID or EEPROM
2826 switch(pHalData->EEPROMCustomerID)
2828 case EEPROM_CID_DEFAULT:
2829 if((pHalData->EEPROMVID == 0x2001) && (pHalData->EEPROMPID == 0x3308))
2830 pHalData->CustomerID = RT_CID_DLINK;
2831 else if((pHalData->EEPROMVID == 0x2001) && (pHalData->EEPROMPID == 0x3309))
2832 pHalData->CustomerID = RT_CID_DLINK;
2833 else if((pHalData->EEPROMVID == 0x2001) && (pHalData->EEPROMPID == 0x330a))
2834 pHalData->CustomerID = RT_CID_DLINK;
2836 case EEPROM_CID_WHQL:
2838 Adapter->bInHctTest = TRUE;
2840 pMgntInfo->bSupportTurboMode = FALSE;
2841 pMgntInfo->bAutoTurboBy8186 = FALSE;
2843 pMgntInfo->PowerSaveControl.bInactivePs = FALSE;
2844 pMgntInfo->PowerSaveControl.bIPSModeBackup = FALSE;
2845 pMgntInfo->PowerSaveControl.bLeisurePs = FALSE;
2847 pMgntInfo->keepAliveLevel = 0;
2849 Adapter->bUnloadDriverwhenS3S4 = FALSE;
2853 pHalData->CustomerID = RT_CID_DEFAULT;
2858 MSG_8723A("EEPROMVID = 0x%04x\n", pHalData->EEPROMVID);
2859 MSG_8723A("EEPROMPID = 0x%04x\n", pHalData->EEPROMPID);
2860 MSG_8723A("EEPROMCustomerID : 0x%02x\n", pHalData->EEPROMCustomerID);
2861 MSG_8723A("EEPROMSubCustomerID: 0x%02x\n", pHalData->EEPROMSubCustomerID);
2863 MSG_8723A("RT_CustomerID: 0x%02x\n", pHalData->CustomerID);
2875 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(Adapter);
2877 if(_FALSE == AutoloadFail){
2878 //Read Permanent MAC address and set value to hardware
2879 memcpy(pEEPROM->mac_addr, &PROMContent[EEPROM_MAC_ADDR], ETH_ALEN);
2882 //Random assigh MAC address
2883 u8 sMacAddr[MAC_ADDR_LEN] = {0x00, 0xE0, 0x4C, 0x81, 0x92, 0x00};
2884 //sMacAddr[5] = (u8)GetRandomNumber(1, 254);
2885 memcpy(pEEPROM->mac_addr, sMacAddr, ETH_ALEN);
2887 DBG_8723A("%s MAC Address from EFUSE = "MAC_FMT"\n",__FUNCTION__, MAC_ARG(pEEPROM->mac_addr));
2888 //NicIFSetMacAddress(Adapter, Adapter->PermanentAddress);
2889 //RT_PRINT_ADDR(COMP_INIT|COMP_EFUSE, DBG_LOUD, "MAC Addr: %s", Adapter->PermanentAddress);
2900 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2902 u8 boardType = BOARD_USB_DONGLE;
2905 if(IS_8723_SERIES(pHalData->VersionID))
2906 pHalData->rf_type = RF_1T1R;
2908 pHalData->rf_type = RF_2T2R;
2910 pHalData->BoardType = boardType;
2914 boardType = PROMContent[EEPROM_NORMAL_BoardType];
2915 boardType &= BOARD_TYPE_NORMAL_MASK;//bit[7:5]
2918 pHalData->BoardType = boardType;
2919 MSG_8723A("_ReadBoardType(%x)\n",pHalData->BoardType);
2921 if (boardType == BOARD_USB_High_PA)
2922 pHalData->ExternalPA = 1;
2933 struct led_priv *pledpriv = &(Adapter->ledpriv);
2934 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2935 #ifdef CONFIG_SW_LED
2936 pledpriv->bRegUseLed = _TRUE;
2941 switch(pHalData->CustomerID)
2943 case RT_CID_DEFAULT:
2944 pledpriv->LedStrategy = SW_LED_MODE1;
2945 pledpriv->bRegUseLed = _TRUE;
2948 case RT_CID_819x_HP:
2949 pledpriv->LedStrategy = SW_LED_MODE6;
2953 pledpriv->LedStrategy = SW_LED_MODE1;
2957 if( BOARD_MINICARD == pHalData->BoardType )
2959 pledpriv->LedStrategy = SW_LED_MODE6;
2961 pHalData->bLedOpenDrain = _TRUE;// Support Open-drain arrangement for controlling the LED. Added by Roger, 2009.10.16.
2963 pledpriv->LedStrategy = HW_LED;
2964 #endif //CONFIG_SW_LED
2974 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2975 struct dm_priv *pdmpriv = &pHalData->dmpriv;
2979 // ThermalMeter from EEPROM
2982 tempval = PROMContent[EEPROM_THERMAL_METER];
2984 tempval = EEPROM_Default_ThermalMeter;
2986 pHalData->EEPROMThermalMeter = (tempval&0x1f); //[4:0]
2988 if(pHalData->EEPROMThermalMeter == 0x1f || AutoloadFail)
2989 pdmpriv->bAPKThermalMeterIgnore = _TRUE;
2992 if(pHalData->EEPROMThermalMeter < 0x06 || pHalData->EEPROMThermalMeter > 0x1c)
2993 pHalData->EEPROMThermalMeter = 0x12;
2996 pdmpriv->ThermalMeter[0] = pHalData->EEPROMThermalMeter;
2998 //RTPRINT(FINIT, INIT_TxPower, ("ThermalMeter = 0x%x\n", pHalData->EEPROMThermalMeter));
3014 readAntennaDiversity(
3021 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
3022 struct registry_priv *registry_par = &pAdapter->registrypriv;
3026 // Antenna Diversity setting.
3027 if(registry_par->antdiv_cfg == 2) // 2: From Efuse
3028 pHalData->AntDivCfg = (hwinfo[EEPROM_RF_OPT1]&0x18)>>3;
3030 pHalData->AntDivCfg = registry_par->antdiv_cfg ; // 0:OFF , 1:ON,
3032 DBG_8723A("### AntDivCfg(%x)\n",pHalData->AntDivCfg);
3034 //if(pHalData->EEPROMBluetoothCoexist!=0 && pHalData->EEPROMBluetoothAntNum==Ant_x1)
3035 // pHalData->AntDivCfg = 0;
3039 pHalData->AntDivCfg = 0;
3044 // Read HW power down mode selection
3045 static void _ReadPSSetting(PADAPTER Adapter, u8*PROMContent, u8 AutoloadFail)
3048 Adapter->pwrctrlpriv.bHWPowerdown = _FALSE;
3049 Adapter->pwrctrlpriv.bSupportRemoteWakeup = _FALSE;
3052 //if(SUPPORT_HW_RADIO_DETECT(Adapter))
3053 Adapter->pwrctrlpriv.bHWPwrPindetect = Adapter->registrypriv.hwpwrp_detect;
3055 //Adapter->pwrctrlpriv.bHWPwrPindetect = _FALSE;//dongle not support new
3058 //hw power down mode selection , 0:rf-off / 1:power down
3060 if(Adapter->registrypriv.hwpdn_mode==2)
3061 Adapter->pwrctrlpriv.bHWPowerdown = (PROMContent[EEPROM_RF_OPT3] & BIT4);
3063 Adapter->pwrctrlpriv.bHWPowerdown = Adapter->registrypriv.hwpdn_mode;
3065 // decide hw if support remote wakeup function
3066 // if hw supported, 8051 (SIE) will generate WeakUP signal( D+/D- toggle) when autoresume
3067 Adapter->pwrctrlpriv.bSupportRemoteWakeup = (PROMContent[EEPROM_TEST_USB_OPT] & BIT1)?_TRUE :_FALSE;
3069 //if(SUPPORT_HW_RADIO_DETECT(Adapter))
3070 //Adapter->registrypriv.usbss_enable = Adapter->pwrctrlpriv.bSupportRemoteWakeup ;
3072 DBG_8723A("%s...bHWPwrPindetect(%x)-bHWPowerdown(%x) ,bSupportRemoteWakeup(%x)\n",__FUNCTION__,
3073 Adapter->pwrctrlpriv.bHWPwrPindetect,Adapter->pwrctrlpriv.bHWPowerdown ,Adapter->pwrctrlpriv.bSupportRemoteWakeup);
3075 DBG_8723A("### PS params=> power_mgnt(%x),usbss_enable(%x) ###\n",Adapter->registrypriv.power_mgnt,Adapter->registrypriv.usbss_enable);
3087 Hal_EfuseParsePIDVID_8723AU(
3093 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
3097 pHalData->EEPROMVID = 0;
3098 pHalData->EEPROMPID = 0;
3103 pHalData->EEPROMVID = le16_to_cpu(*(u16*)&hwinfo[EEPROM_VID_8723AU]);
3104 pHalData->EEPROMPID = le16_to_cpu(*(u16*)&hwinfo[EEPROM_PID_8723AU]);
3108 MSG_8723A("EEPROM VID = 0x%4x\n", pHalData->EEPROMVID);
3109 MSG_8723A("EEPROM PID = 0x%4x\n", pHalData->EEPROMPID);
3114 Hal_EfuseParseMACAddr_8723AU(
3121 u8 sMacAddr[6] = {0x00, 0xE0, 0x4C, 0x87, 0x23, 0x00};
3122 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
3126 // sMacAddr[5] = (u1Byte)GetRandomNumber(1, 254);
3128 pEEPROM->mac_addr[i] = sMacAddr[i];
3132 //Read Permanent MAC address
3134 memcpy(pEEPROM->mac_addr, &hwinfo[EEPROM_MAC_ADDR_8723AU], ETH_ALEN);
3138 usValue = *(u16*)&hwinfo[EEPROM_MAC_ADDR_8723S+i];
3139 *((u16*)(&pEEPROM->mac_addr[i])) = usValue;
3143 // NicIFSetMacAddress(pAdapter, pAdapter->PermanentAddress);
3145 RT_TRACE(_module_hci_hal_init_c_, _drv_notice_,
3146 ("Hal_EfuseParseMACAddr_8723AU: Permanent Address=%02x:%02x:%02x:%02x:%02x:%02x\n",
3147 pEEPROM->mac_addr[0], pEEPROM->mac_addr[1],
3148 pEEPROM->mac_addr[2], pEEPROM->mac_addr[3],
3149 pEEPROM->mac_addr[4], pEEPROM->mac_addr[5]));
3153 #ifdef CONFIG_EFUSE_CONFIG_FILE
3154 static u32 Hal_readPGDataFromConfigFile(
3162 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
3163 u8 *PROMContent = pEEPROM->efuse_eeprom_data;
3166 temp[2] = 0; // add end of string '\0'
3168 fp = filp_open("/system/etc/wifi/wifi_efuse.map", O_RDWR, 0644);
3170 pEEPROM->bloadfile_fail_flag= _TRUE;
3171 DBG_8723A("Error, Efuse configure file doesn't exist.\n");
3178 DBG_8723A("Efuse configure file:\n");
3179 for (i=0; i<HWSET_MAX_SIZE_88E; i++) {
3180 vfs_read(fp, temp, 2, &pos);
3181 PROMContent[i] = simple_strtoul(temp, NULL, 16 );
3182 pos += 1; // Filter the space character
3183 DBG_8723A("%02X \n", PROMContent[i]);
3188 filp_close(fp, NULL);
3190 pEEPROM->bloadfile_fail_flag= _FALSE;
3196 Hal_ReadMACAddrFromFile_8723AU(
3205 u32 curtime = rtw_get_current_time();
3206 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
3209 u8 null_mac_addr[ETH_ALEN] = {0, 0, 0,0, 0, 0};
3210 u8 multi_mac_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
3212 memset(source_addr, 0, 18);
3213 memset(pEEPROM->mac_addr, 0, ETH_ALEN);
3215 fp = filp_open("/data/wifimac.txt", O_RDWR, 0644);
3217 pEEPROM->bloadmac_fail_flag = _TRUE;
3218 DBG_8723A("Error, wifi mac address file doesn't exist.\n");
3223 DBG_8723A("wifi mac address:\n");
3224 vfs_read(fp, source_addr, 18, &pos);
3225 source_addr[17] = ':';
3227 head = end = source_addr;
3228 for (i=0; i<ETH_ALEN; i++) {
3229 while (end && (*end != ':') )
3232 if (end && (*end == ':') )
3235 pEEPROM->mac_addr[i] = simple_strtoul(head, NULL, 16 );
3241 DBG_8723A("%02x \n", pEEPROM->mac_addr[i]);
3246 filp_close(fp, NULL);
3249 if ((!memcmp(pEEPROM->mac_addr, null_mac_addr, ETH_ALEN)) ||
3250 (!memcmp(pEEPROM->mac_addr, multi_mac_addr, ETH_ALEN)) ) {
3251 pEEPROM->mac_addr[0] = 0x00;
3252 pEEPROM->mac_addr[1] = 0xe0;
3253 pEEPROM->mac_addr[2] = 0x4c;
3254 pEEPROM->mac_addr[3] = (u8)(curtime & 0xff) ;
3255 pEEPROM->mac_addr[4] = (u8)((curtime>>8) & 0xff) ;
3256 pEEPROM->mac_addr[5] = (u8)((curtime>>16) & 0xff) ;
3259 pEEPROM->bloadmac_fail_flag = _FALSE;
3261 DBG_8723A("Hal_ReadMACAddrFromFile_8188ES: Permanent Address = %02x-%02x-%02x-%02x-%02x-%02x\n",
3262 pEEPROM->mac_addr[0], pEEPROM->mac_addr[1],
3263 pEEPROM->mac_addr[2], pEEPROM->mac_addr[3],
3264 pEEPROM->mac_addr[4], pEEPROM->mac_addr[5]);
3266 #endif //CONFIG_EFUSE_CONFIG_FILE
3274 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
3275 //PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
3276 u8 hwinfo[HWSET_MAX_SIZE];
3278 #ifdef CONFIG_EFUSE_CONFIG_FILE
3279 Hal_readPGDataFromConfigFile(padapter);
3280 #else //CONFIG_EFUSE_CONFIG_FILE
3281 Hal_InitPGData(padapter, hwinfo);
3282 #endif //CONFIG_EFUSE_CONFIG_FILE
3283 Hal_EfuseParseIDCode(padapter, hwinfo);
3284 Hal_EfuseParsePIDVID_8723AU(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3285 Hal_EfuseParseEEPROMVer(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3286 #ifdef CONFIG_EFUSE_CONFIG_FILE
3287 Hal_ReadMACAddrFromFile_8723AU(padapter);
3288 #else //CONFIG_EFUSE_CONFIG_FILE
3289 Hal_EfuseParseMACAddr_8723AU(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3291 Hal_EfuseParseTxPowerInfo_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3292 _ReadBoardType(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3293 Hal_EfuseParseBTCoexistInfo_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3295 rtl8723a_EfuseParseChnlPlan(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3296 Hal_EfuseParseThermalMeter_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3297 _ReadLEDSetting(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3298 // _ReadRFSetting(Adapter, PROMContent, pEEPROM->bautoload_fail_flag);
3299 // _ReadPSSetting(Adapter, PROMContent, pEEPROM->bautoload_fail_flag);
3300 Hal_EfuseParseAntennaDiversity(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3302 Hal_EfuseParseEEPROMVer(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3303 Hal_EfuseParseCustomerID(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3304 Hal_EfuseParseRateIndicationOption(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3305 Hal_EfuseParseXtal_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
3307 // The following part initialize some vars by PG info.
3309 Hal_InitChannelPlan(padapter);
3313 //hal_CustomizedBehavior_8723U(Adapter);
3315 // Adapter->bDongle = (PROMContent[EEPROM_EASY_REPLACEMENT] == 1)? 0: 1;
3316 DBG_8723A("%s(): REPLACEMENT = %x\n",__FUNCTION__,padapter->bDongle);
3319 static void _ReadPROMContent(
3323 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(Adapter);
3324 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3325 u8 PROMContent[HWSET_MAX_SIZE]={0};
3330 eeValue = rtw_read8(Adapter, REG_9346CR);
3331 // To check system boot selection.
3332 pEEPROM->EepromOrEfuse = (eeValue & BOOT_FROM_EEPROM) ? _TRUE : _FALSE;
3333 pEEPROM->bautoload_fail_flag = (eeValue & EEPROM_EN) ? _FALSE : _TRUE;
3336 DBG_8723A("Boot from %s, Autoload %s !\n", (pEEPROM->EepromOrEfuse ? "EEPROM" : "EFUSE"),
3337 (pEEPROM->bautoload_fail_flag ? "Fail" : "OK") );
3339 readAdapterInfo(Adapter);
3348 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3351 //if(Adapter->bInHctTest){
3352 // pMgntInfo->PowerSaveControl.bInactivePs = FALSE;
3353 // pMgntInfo->PowerSaveControl.bIPSModeBackup = FALSE;
3354 // pMgntInfo->PowerSaveControl.bLeisurePs = FALSE;
3355 // pMgntInfo->keepAliveLevel = 0;
3366 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3369 pHalData->rf_chip = RF_PSEUDO_11N;
3371 pHalData->rf_chip = RF_6052;
3375 void _ReadSilmComboMode(PADAPTER Adapter)
3377 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3379 pHalData->SlimComboDbg = _FALSE; // Default is not debug mode.
3384 // We should set Efuse cell selection to WiFi cell in default.
3389 // Added by Roger, 2010.11.23.
3398 value32 = rtw_read32(Adapter, EFUSE_TEST);
3399 value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_WIFI_SEL_0);
3400 rtw_write32(Adapter, EFUSE_TEST, value32);
3403 static int _ReadAdapterInfo8723AU(PADAPTER Adapter)
3405 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3406 u32 start=rtw_get_current_time();
3408 MSG_8723A("====> _ReadAdapterInfo8723AU\n");
3410 //Efuse_InitSomeVar(Adapter);
3412 hal_EfuseCellSel(Adapter);
3414 _ReadRFType(Adapter);//rf_chip -> _InitRFType()
3415 _ReadPROMContent(Adapter);
3417 // 2010/10/25 MH THe function must be called after borad_type & IC-Version recognize.
3418 _ReadSilmComboMode(Adapter);
3420 _InitOtherVariable(Adapter);
3422 //MSG_8723A("%s()(done), rf_chip=0x%x, rf_type=0x%x\n", __FUNCTION__, pHalData->rf_chip, pHalData->rf_type);
3424 MSG_8723A("<==== _ReadAdapterInfo8723AU in %d ms\n", rtw_get_passing_time_ms(start));
3430 static void ReadAdapterInfo8723AU(PADAPTER Adapter)
3432 // Read EEPROM size before call any EEPROM function
3433 Adapter->EepromAddressSize = GetEEPROMSize8723A(Adapter);
3435 _ReadAdapterInfo8723AU(Adapter);
3439 #define GPIO_DEBUG_PORT_NUM 0
3440 static void rtl8192cu_trigger_gpio_0(_adapter *padapter)
3444 DBG_8723A("==> trigger_gpio_0...\n");
3445 rtw_write16_async(padapter,REG_GPIO_PIN_CTRL,0);
3446 rtw_write8_async(padapter,REG_GPIO_PIN_CTRL+2,0xFF);
3447 gpioctrl = (BIT(GPIO_DEBUG_PORT_NUM)<<24 )|(BIT(GPIO_DEBUG_PORT_NUM)<<16);
3448 rtw_write32_async(padapter,REG_GPIO_PIN_CTRL,gpioctrl);
3449 gpioctrl |= (BIT(GPIO_DEBUG_PORT_NUM)<<8);
3450 rtw_write32_async(padapter,REG_GPIO_PIN_CTRL,gpioctrl);
3451 DBG_8723A("<=== trigger_gpio_0...\n");
3456 * If variable not handled here,
3457 * some variables will be processed in SetHwReg8723A()
3459 void SetHwReg8723AU(PADAPTER Adapter, u8 variable, u8* val)
3461 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
3467 case HW_VAR_RXDMA_AGG_PG_TH:
3468 #ifdef CONFIG_USB_RX_AGGREGATION
3470 u8 threshold = *val;
3472 threshold = pHalData->UsbRxAggPageCount;
3473 SetHwReg8723A(Adapter, HW_VAR_RXDMA_AGG_PG_TH, &threshold);
3478 case HW_VAR_SET_RPWM:
3479 rtw_write8(Adapter, REG_USB_HRPWM, *val);
3482 case HW_VAR_TRIGGER_GPIO_0:
3483 rtl8192cu_trigger_gpio_0(Adapter);
3487 SetHwReg8723A(Adapter, variable, val);
3495 * If variable not handled here,
3496 * some variables will be processed in GetHwReg8723A()
3498 void GetHwReg8723AU(PADAPTER Adapter, u8 variable, u8* val)
3500 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
3507 GetHwReg8723A(Adapter, variable, val);
3516 // Query setting of specified variable.
3519 GetHalDefVar8192CUsb(
3521 HAL_DEF_VARIABLE eVariable,
3525 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3526 u8 bResult = _SUCCESS;
3530 case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB:
3531 *((int *)pValue) = pHalData->dmpriv.UndecoratedSmoothedPWDB;
3533 case HAL_DEF_IS_SUPPORT_ANT_DIV:
3534 #ifdef CONFIG_ANTENNA_DIVERSITY
3535 *((u8 *)pValue) = (IS_92C_SERIAL(pHalData->VersionID) ||(pHalData->AntDivCfg==0))?_FALSE:_TRUE;
3538 case HAL_DEF_CURRENT_ANTENNA:
3539 #ifdef CONFIG_ANTENNA_DIVERSITY
3540 *(( u8*)pValue) = pHalData->CurAntenna;
3543 case HAL_DEF_DRVINFO_SZ:
3544 *(( u32*)pValue) = DRVINFO_SZ;
3546 case HAL_DEF_MAX_RECVBUF_SZ:
3547 *(( u32*)pValue) = MAX_RECVBUF_SZ;
3549 case HAL_DEF_RX_PACKET_OFFSET:
3550 *(( u32*)pValue) = RXDESC_SIZE + DRVINFO_SZ;
3552 case HAL_DEF_DBG_DUMP_RXPKT:
3553 *(( u8*)pValue) = pHalData->bDumpRxPkt;
3555 case HAL_DEF_DBG_DM_FUNC:
3556 *(( u32*)pValue) =pHalData->odmpriv.SupportAbility;
3558 case HW_VAR_MAX_RX_AMPDU_FACTOR:
3559 *(( u32*)pValue) = IEEE80211_HT_MAX_AMPDU_64K;
3561 case HW_DEF_ODM_DBG_FLAG:
3563 u8Byte DebugComponents = *((u32*)pValue);
3564 PDM_ODM_T pDM_Odm = &(pHalData->odmpriv);
3565 printk("pDM_Odm->DebugComponents = 0x%llx \n",pDM_Odm->DebugComponents );
3569 //RT_TRACE(COMP_INIT, DBG_WARNING, ("GetHalDefVar8192CUsb(): Unkown variable: %d!\n", eVariable));
3582 // Change default setting of specified variable.
3585 SetHalDefVar8192CUsb(
3587 HAL_DEF_VARIABLE eVariable,
3591 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3592 u8 bResult = _SUCCESS;
3596 case HAL_DEF_DBG_DUMP_RXPKT:
3597 pHalData->bDumpRxPkt = *(( u8*)pValue);
3599 case HAL_DEF_DBG_DM_FUNC:
3601 u8 dm_func = *(( u8*)pValue);
3602 struct dm_priv *pdmpriv = &pHalData->dmpriv;
3603 DM_ODM_T *podmpriv = &pHalData->odmpriv;
3605 if(dm_func == 0){ //disable all dynamic func
3606 podmpriv->SupportAbility = DYNAMIC_FUNC_DISABLE;
3607 DBG_8723A("==> Disable all dynamic function...\n");
3609 else if(dm_func == 1){//disable DIG
3610 podmpriv->SupportAbility &= (~DYNAMIC_BB_DIG);
3611 DBG_8723A("==> Disable DIG...\n");
3613 else if(dm_func == 2){//disable High power
3614 podmpriv->SupportAbility &= (~DYNAMIC_BB_DYNAMIC_TXPWR);
3616 else if(dm_func == 3){//disable tx power tracking
3617 podmpriv->SupportAbility &= (~DYNAMIC_RF_CALIBRATION);
3618 DBG_8723A("==> Disable tx power tracking...\n");
3620 else if(dm_func == 4){//disable BT coexistence
3621 pdmpriv->DMFlag &= (~DYNAMIC_FUNC_BT);
3623 else if(dm_func == 5){//disable antenna diversity
3624 podmpriv->SupportAbility &= (~DYNAMIC_BB_ANT_DIV);
3626 else if(dm_func == 6){//turn on all dynamic func
3627 if(!(podmpriv->SupportAbility & DYNAMIC_BB_DIG))
3629 DIG_T *pDigTable = &podmpriv->DM_DigTable;
3630 pDigTable->CurIGValue= rtw_read8(Adapter,0xc50);
3632 pdmpriv->DMFlag |= DYNAMIC_FUNC_BT;
3633 podmpriv->SupportAbility = DYNAMIC_ALL_FUNC_ENABLE;
3634 DBG_8723A("==> Turn on all dynamic function...\n");
3638 case HW_DEF_FA_CNT_DUMP:
3640 u8 bRSSIDump = *((u8*)pValue);
3641 PDM_ODM_T pDM_Odm = &(pHalData->odmpriv);
3643 pDM_Odm->DebugComponents = ODM_COMP_DIG|ODM_COMP_FA_CNT ;
3645 pDM_Odm->DebugComponents = 0;
3649 case HW_DEF_ODM_DBG_FLAG:
3651 u8Byte DebugComponents = *((u8Byte*)pValue);
3652 PDM_ODM_T pDM_Odm = &(pHalData->odmpriv);
3653 pDM_Odm->DebugComponents = DebugComponents;
3657 //RT_TRACE(COMP_INIT, DBG_TRACE, ("SetHalDefVar819xUsb(): Unkown variable: %d!\n", eVariable));
3666 u32 _update_92cu_basic_rate(_adapter *padapter, unsigned int mask)
3668 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
3669 unsigned int BrateCfg = 0;
3672 if(pHalData->VersionID != VERSION_TEST_CHIP_88C)
3673 BrateCfg = mask & 0x15F;
3674 else //for 88CU 46PING setting, Disable CCK 2M, 5.5M, Others must tuning
3675 BrateCfg = mask & 0x159;
3677 BrateCfg |= 0x01; // default enable 1M ACK rate
3682 void _update_response_rate(_adapter *padapter,unsigned int mask)
3685 // Set RRSR rate table.
3686 rtw_write8(padapter, REG_RRSR, mask&0xff);
3687 rtw_write8(padapter,REG_RRSR+1, (mask>>8)&0xff);
3689 // Set RTS initial rate
3695 rtw_write8(padapter, REG_INIRTS_RATE_SEL, RateIndex);
3698 void UpdateHalRAMask8192CUsb(PADAPTER padapter, u32 mac_id,u8 rssi_level )
3700 //volatile unsigned int result;
3702 u8 networkType, raid;
3703 u32 mask,rate_bitmap;
3704 u8 shortGIrate = _FALSE;
3705 int supportRateNum = 0;
3706 struct sta_info *psta;
3707 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
3708 struct dm_priv *pdmpriv = &pHalData->dmpriv;
3709 struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
3710 struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
3711 WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
3712 #ifdef CONFIG_CONCURRENT_MODE
3713 if(rtw_buddy_adapter_up(padapter) && padapter->adapter_type > PRIMARY_ADAPTER)
3714 pHalData = GET_HAL_DATA(padapter->pbuddy_adapter);
3715 #endif //CONFIG_CONCURRENT_MODE
3717 if (mac_id >= NUM_STA) //CAM_SIZE
3722 psta = pmlmeinfo->FW_sta_info[mac_id].psta;
3730 case 0:// for infra mode
3731 #ifdef CONFIG_CONCURRENT_MODE
3732 case 2:// first station uses macid=0, second station uses macid=2
3734 supportRateNum = rtw_get_rateset_len(cur_network->SupportedRates);
3735 networkType = judge_network_type(padapter, cur_network->SupportedRates, supportRateNum) & 0xf;
3736 //pmlmeext->cur_wireless_mode = networkType;
3737 raid = networktype_to_raid(networkType);
3739 mask = update_supported_rate(cur_network->SupportedRates, supportRateNum);
3740 mask |= (pmlmeinfo->HT_enable)? update_MSC_rate(&(pmlmeinfo->HT_caps)): 0;
3743 if (support_short_GI(padapter, &(pmlmeinfo->HT_caps)))
3745 shortGIrate = _TRUE;
3750 case 1://for broadcast/multicast
3751 supportRateNum = rtw_get_rateset_len(pmlmeinfo->FW_sta_info[mac_id].SupportedRates);
3752 if(pmlmeext->cur_wireless_mode & WIRELESS_11B)
3753 networkType = WIRELESS_11B;
3755 networkType = WIRELESS_11G;
3756 raid = networktype_to_raid(networkType);
3758 mask = update_basic_rate(cur_network->SupportedRates, supportRateNum);
3762 default: //for each sta in IBSS
3763 supportRateNum = rtw_get_rateset_len(pmlmeinfo->FW_sta_info[mac_id].SupportedRates);
3764 networkType = judge_network_type(padapter, pmlmeinfo->FW_sta_info[mac_id].SupportedRates, supportRateNum) & 0xf;
3765 //pmlmeext->cur_wireless_mode = networkType;
3766 raid = networktype_to_raid(networkType);
3768 mask = update_supported_rate(cur_network->SupportedRates, supportRateNum);
3771 //todo: support HT in IBSS
3776 //mask &=0x0fffffff;
3777 rate_bitmap = 0x0fffffff;
3778 #ifdef CONFIG_ODM_REFRESH_RAMASK
3780 rate_bitmap = ODM_Get_Rate_Bitmap(&pHalData->odmpriv,mac_id,mask,rssi_level);
3781 printk("%s => mac_id:%d, networkType:0x%02x, mask:0x%08x\n\t ==> rssi_level:%d, rate_bitmap:0x%08x\n",
3782 __FUNCTION__,mac_id,networkType,mask,rssi_level,rate_bitmap);
3786 mask &= rate_bitmap;
3787 mask |= ((raid<<28)&0xf0000000);
3790 init_rate = get_highest_rate_idx(mask)&0x3f;
3792 if(pHalData->fw_ractrl == _TRUE)
3796 //arg = (cam_idx-4)&0x1f;//MACID
3797 arg = mac_id&0x1f;//MACID
3801 if (shortGIrate==_TRUE)
3804 DBG_8723A("update raid entry, mask=0x%x, arg=0x%x\n", mask, arg);
3806 rtl8192c_set_raid_cmd(padapter, mask, arg);
3811 if (shortGIrate==_TRUE)
3812 init_rate |= BIT(6);
3814 rtw_write8(padapter, (REG_INIDATA_RATE_SEL+mac_id), init_rate);
3820 psta->init_rate = init_rate;
3822 //set correct initial date rate for each mac_id
3823 pdmpriv->INIDATA_RATE[mac_id] = init_rate;
3826 static void rtl8723au_init_default_value(PADAPTER padapter)
3828 rtl8723a_init_default_value(padapter);
3831 static u8 rtl8192cu_ps_func(PADAPTER Adapter,HAL_INTF_PS_FUNC efunc_id, u8 *val)
3836 #if defined(CONFIG_AUTOSUSPEND) && defined(SUPPORT_HW_RFOFF_DETECTED)
3837 case HAL_USB_SELECT_SUSPEND:
3839 u8 bfwpoll = *(( u8*)val);
3840 rtl8192c_set_FwSelectSuspend_cmd(Adapter,bfwpoll ,500);//note fw to support hw power down ping detect
3843 #endif //CONFIG_AUTOSUSPEND && SUPPORT_HW_RFOFF_DETECTED
3851 void rtl8723au_set_hal_ops(_adapter * padapter)
3853 struct hal_ops *pHalFunc = &padapter->HalFunc;
3857 padapter->HalData = kzalloc(sizeof(HAL_DATA_TYPE), GFP_KERNEL);
3858 if(padapter->HalData == NULL){
3859 DBG_8723A("cant not alloc memory for HAL DATA \n");
3861 //memset(padapter->HalData, 0, sizeof(HAL_DATA_TYPE));
3862 padapter->hal_data_sz = sizeof(HAL_DATA_TYPE);
3864 pHalFunc->hal_init = &rtl8723au_hal_init;
3865 pHalFunc->hal_deinit = &rtl8723au_hal_deinit;
3867 //pHalFunc->free_hal_data = &rtl8192c_free_hal_data;
3869 pHalFunc->inirp_init = &rtl8723au_inirp_init;
3870 pHalFunc->inirp_deinit = &rtl8723au_inirp_deinit;
3872 pHalFunc->init_xmit_priv = &rtl8192cu_init_xmit_priv;
3873 pHalFunc->free_xmit_priv = &rtl8192cu_free_xmit_priv;
3875 pHalFunc->init_recv_priv = &rtl8192cu_init_recv_priv;
3876 pHalFunc->free_recv_priv = &rtl8192cu_free_recv_priv;
3877 #ifdef CONFIG_SW_LED
3878 pHalFunc->InitSwLeds = &rtl8723au_InitSwLeds;
3879 pHalFunc->DeInitSwLeds = &rtl8723au_DeInitSwLeds;
3880 #else //case of hw led or no led
3881 pHalFunc->InitSwLeds = NULL;
3882 pHalFunc->DeInitSwLeds = NULL;
3883 #endif//CONFIG_SW_LED
3885 pHalFunc->init_default_value = &rtl8723au_init_default_value;
3886 pHalFunc->intf_chip_configure = &rtl8192cu_interface_configure;
3887 pHalFunc->read_adapter_info = &ReadAdapterInfo8723AU;
3889 //pHalFunc->set_bwmode_handler = &PHY_SetBWMode8192C;
3890 //pHalFunc->set_channel_handler = &PHY_SwChnl8192C;
3892 //pHalFunc->hal_dm_watchdog = &rtl8192c_HalDmWatchDog;
3894 pHalFunc->SetHwRegHandler = &SetHwReg8723AU;
3895 pHalFunc->GetHwRegHandler = &GetHwReg8723AU;
3896 pHalFunc->GetHalDefVarHandler = &GetHalDefVar8192CUsb;
3897 pHalFunc->SetHalDefVarHandler = &SetHalDefVar8192CUsb;
3899 pHalFunc->UpdateRAMaskHandler = &UpdateHalRAMask8192CUsb;
3901 pHalFunc->hal_xmit = &rtl8192cu_hal_xmit;
3902 pHalFunc->mgnt_xmit = &rtl8192cu_mgnt_xmit;
3903 pHalFunc->hal_xmitframe_enqueue = &rtl8723au_hal_xmitframe_enqueue;
3905 #ifdef CONFIG_HOSTAPD_MLME
3906 pHalFunc->hostap_mgnt_xmit_entry = &rtl8192cu_hostap_mgnt_xmit_entry;
3908 pHalFunc->interface_ps_func = &rtl8192cu_ps_func;
3910 rtl8723a_set_hal_ops(pHalFunc);