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", (u32)NumOutPipe, (u32)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 *---------------------------------------------------------------------------*/
964 } // USB_AggModeSwitch
978 struct registry_priv *pregpriv = &Adapter->registrypriv;
979 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
980 bool is92CU = IS_92C_SERIAL(pHalData->VersionID);
983 pHalData->rf_chip = RF_PSEUDO_11N;
987 pHalData->rf_chip = RF_6052;
989 if(_FALSE == is92CU){
990 pHalData->rf_type = RF_1T1R;
991 DBG_8723A("Set RF Chip ID to RF_6052 and RF type to 1T1R.\n");
995 // TODO: Consider that EEPROM set 92CU to 1T1R later.
996 // Force to overwrite setting according to chip version. Ignore EEPROM setting.
997 //pHalData->RF_Type = is92CU ? RF_2T2R : RF_1T1R;
998 MSG_8723A("Set RF Chip ID to RF_6052 and RF type to %d.\n", pHalData->rf_type);
1002 static void _InitAdhocWorkaroundParams(PADAPTER Adapter)
1004 #ifdef RTL8192CU_ADHOC_WORKAROUND_SETTING
1005 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1006 pHalData->RegBcnCtrlVal = rtw_read8(Adapter, REG_BCN_CTRL);
1007 pHalData->RegTxPause = rtw_read8(Adapter, REG_TXPAUSE);
1008 pHalData->RegFwHwTxQCtrl = rtw_read8(Adapter, REG_FWHW_TXQ_CTRL+2);
1009 pHalData->RegReg542 = rtw_read8(Adapter, REG_TBTT_PROHIBIT+2);
1013 // Set CCK and OFDM Block "ON"
1014 static void _BBTurnOnBlock(
1022 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bCCKEn, 0x1);
1023 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
1026 #define MgntActSet_RF_State(...)
1027 static void _RfPowerSave(PADAPTER padapter)
1037 // 2010/08/09 MH Add for power down check.
1040 HalDetectPwrDownMode(
1045 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1046 struct pwrctrl_priv *pwrctrlpriv = &Adapter->pwrctrlpriv;
1048 EFUSE_ShadowRead(Adapter, 1, EEPROM_RF_OPT3, (u32 *)&tmpvalue);
1050 // 2010/08/25 MH INF priority > PDN Efuse value.
1051 if(tmpvalue & BIT4 && pwrctrlpriv->reg_pdnmode)
1053 pHalData->pwrdown = _TRUE;
1057 pHalData->pwrdown = _FALSE;
1060 DBG_8723A("HalDetectPwrDownMode(): PDN=%d\n", pHalData->pwrdown);
1061 return pHalData->pwrdown;
1063 } // HalDetectPwrDownMode
1067 // 2010/08/26 MH Add for selective suspend mode check.
1068 // If Efuse 0x0e bit1 is not enabled, we can not support selective suspend for Minicard and
1072 HalDetectSelectiveSuspendMode(
1077 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1078 struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(Adapter);
1080 // If support HW radio detect, we need to enable WOL ability, otherwise, we
1081 // can not use FW to notify host the power state switch.
1083 EFUSE_ShadowRead(Adapter, 1, EEPROM_USB_OPTIONAL1, (u32 *)&tmpvalue);
1085 DBG_8723A("HalDetectSelectiveSuspendMode(): SS ");
1088 DBG_8723A("Enable\n");
1092 DBG_8723A("Disable\n");
1093 pdvobjpriv->RegUsbSS = _FALSE;
1096 // 2010/09/01 MH According to Dongle Selective Suspend INF. We can switch SS mode.
1097 if (pdvobjpriv->RegUsbSS && !SUPPORT_HW_RADIO_DETECT(pHalData))
1099 //PMGNT_INFO pMgntInfo = &(Adapter->MgntInfo);
1101 //if (!pMgntInfo->bRegDongleSS)
1103 // RT_TRACE(COMP_INIT, DBG_LOUD, ("Dongle disable SS\n"));
1104 pdvobjpriv->RegUsbSS = _FALSE;
1107 } // HalDetectSelectiveSuspendMode
1108 /*-----------------------------------------------------------------------------
1109 * Function: HwSuspendModeEnable92Cu()
1111 * Overview: HW suspend mode switch.
1121 * 08/23/2010 MHC HW suspend mode switch test..
1122 *---------------------------------------------------------------------------*/
1124 HwSuspendModeEnable92Cu(
1129 } // HwSuspendModeEnable92Cu
1131 rt_rf_power_state RfOnOffDetect(PADAPTER pAdapter )
1133 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
1135 rt_rf_power_state rfpowerstate = rf_off;
1137 if(pAdapter->pwrctrlpriv.bHWPowerdown)
1139 val8 = rtw_read8(pAdapter, REG_HSISR);
1140 DBG_8723A("pwrdown, 0x5c(BIT7)=%02x\n", val8);
1141 rfpowerstate = (val8 & BIT7) ? rf_off: rf_on;
1145 rtw_write8( pAdapter, REG_MAC_PINMUX_CFG,rtw_read8(pAdapter, REG_MAC_PINMUX_CFG)&~(BIT3));
1146 val8 = rtw_read8(pAdapter, REG_GPIO_IO_SEL);
1147 DBG_8723A("GPIO_IN=%02x\n", val8);
1148 rfpowerstate = (val8 & BIT3) ? rf_on : rf_off;
1150 return rfpowerstate;
1151 } // HalDetectPwrDownMode
1153 void _ps_open_RF(_adapter *padapter);
1155 u32 rtl8723au_hal_init(PADAPTER Adapter)
1158 u32 boundary, status = _SUCCESS;
1159 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1160 struct pwrctrl_priv *pwrctrlpriv = &Adapter->pwrctrlpriv;
1161 struct registry_priv *pregistrypriv = &Adapter->registrypriv;
1162 u8 is92C = IS_92C_SERIAL(pHalData->VersionID);
1163 rt_rf_power_state eRfPowerStateToSet;
1164 u32 NavUpper = WiFiNavUpperUs;
1166 u32 init_start_time = rtw_get_current_time();
1169 #ifdef DBG_HAL_INIT_PROFILING
1171 enum HAL_INIT_STAGES {
1172 HAL_INIT_STAGES_BEGIN = 0,
1173 HAL_INIT_STAGES_INIT_PW_ON,
1174 HAL_INIT_STAGES_INIT_LLTT,
1175 HAL_INIT_STAGES_MISC01,
1176 HAL_INIT_STAGES_DOWNLOAD_FW,
1177 HAL_INIT_STAGES_MAC,
1180 HAL_INIT_STAGES_MISC02,
1181 HAL_INIT_STAGES_TURN_ON_BLOCK,
1182 HAL_INIT_STAGES_INIT_SECURITY,
1183 HAL_INIT_STAGES_MISC11,
1184 //HAL_INIT_STAGES_RF_PS,
1185 HAL_INIT_STAGES_IQK,
1186 HAL_INIT_STAGES_PW_TRACK,
1187 HAL_INIT_STAGES_LCK,
1188 HAL_INIT_STAGES_MISC21,
1189 //HAL_INIT_STAGES_INIT_PABIAS,
1190 #ifdef CONFIG_BT_COEXIST
1191 HAL_INIT_STAGES_BT_COEXIST,
1193 //HAL_INIT_STAGES_ANTENNA_SEL,
1194 HAL_INIT_STAGES_INIT_HAL_DM,
1195 HAL_INIT_STAGES_MISC31,
1196 HAL_INIT_STAGES_END,
1200 char * hal_init_stages_str[] = {
1201 "HAL_INIT_STAGES_BEGIN",
1202 "HAL_INIT_STAGES_INIT_PW_ON",
1203 "HAL_INIT_STAGES_INIT_LLTT",
1204 "HAL_INIT_STAGES_MISC01",
1205 "HAL_INIT_STAGES_DOWNLOAD_FW",
1206 "HAL_INIT_STAGES_MAC",
1207 "HAL_INIT_STAGES_BB",
1208 "HAL_INIT_STAGES_RF",
1209 "HAL_INIT_STAGES_MISC02",
1210 "HAL_INIT_STAGES_TURN_ON_BLOCK",
1211 "HAL_INIT_STAGES_INIT_SECURITY",
1212 "HAL_INIT_STAGES_MISC11",
1213 //"HAL_INIT_STAGES_RF_PS",
1214 "HAL_INIT_STAGES_IQK",
1215 "HAL_INIT_STAGES_PW_TRACK",
1216 "HAL_INIT_STAGES_LCK",
1217 "HAL_INIT_STAGES_MISC21",
1218 //"HAL_INIT_STAGES_INIT_PABIAS",
1219 #ifdef CONFIG_BT_COEXIST
1220 "HAL_INIT_STAGES_BT_COEXIST",
1222 //"HAL_INIT_STAGES_ANTENNA_SEL",
1223 "HAL_INIT_STAGES_INIT_HAL_DM",
1224 "HAL_INIT_STAGES_MISC31",
1225 "HAL_INIT_STAGES_END",
1228 int hal_init_profiling_i;
1229 u32 hal_init_stages_timestamp[HAL_INIT_STAGES_NUM]; //used to record the time of each stage's starting point
1231 for(hal_init_profiling_i=0;hal_init_profiling_i<HAL_INIT_STAGES_NUM;hal_init_profiling_i++)
1232 hal_init_stages_timestamp[hal_init_profiling_i]=0;
1234 #define HAL_INIT_PROFILE_TAG(stage) hal_init_stages_timestamp[(stage)]=rtw_get_current_time();
1236 #define HAL_INIT_PROFILE_TAG(stage) do {} while(0)
1237 #endif //DBG_HAL_INIT_PROFILING
1243 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_BEGIN);
1244 if(Adapter->pwrctrlpriv.bkeepfwalive)
1246 _ps_open_RF(Adapter);
1248 if(pHalData->bIQKInitialized ){
1249 rtl8192c_PHY_IQCalibrate(Adapter,_TRUE);
1252 rtl8192c_PHY_IQCalibrate(Adapter,_FALSE);
1253 pHalData->bIQKInitialized = _TRUE;
1255 rtl8192c_odm_CheckTXPowerTracking(Adapter);
1256 rtl8192c_PHY_LCCalibrate(Adapter);
1261 // pHalData->bMACFuncEnable = _FALSE;
1262 // Check if MAC has already power on. by tynli. 2011.05.27.
1263 val8 = rtw_read8(Adapter, REG_CR);
1264 RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
1265 ("%s: REG_CR 0x100=0x%02x\n", __FUNCTION__, val8));
1266 //Fix 92DU-VC S3 hang with the reason is that secondary mac is not initialized.
1267 //0x100 value of first mac is 0xEA while 0x100 value of secondary is 0x00
1268 //by sherry 20111102
1270 pHalData->bMACFuncEnable = _FALSE;
1272 pHalData->bMACFuncEnable = _TRUE;
1273 RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
1274 ("%s: MAC has already power on\n", __FUNCTION__));
1277 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_PW_ON);
1278 status = _InitPowerOn(Adapter);
1279 if(status == _FAIL){
1280 RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("Failed to init power on!\n"));
1284 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_LLTT);
1285 if (!pregistrypriv->wifi_spec) {
1286 boundary = TX_PAGE_BOUNDARY;
1289 boundary = WMM_NORMAL_TX_PAGE_BOUNDARY;
1292 if (!pHalData->bMACFuncEnable)
1294 status = InitLLTTable(Adapter, boundary);
1295 if(status == _FAIL){
1296 RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("Failed to init LLT table\n"));
1302 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC01);
1303 if(pHalData->bRDGEnable){
1304 _InitRDGSetting(Adapter);
1308 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_DOWNLOAD_FW);
1310 status = rtl8723a_FirmwareDownload(Adapter);
1311 if(status != _SUCCESS)
1313 Adapter->bFWReady = _FALSE;
1314 pHalData->fw_ractrl = _FALSE;
1315 DBG_8723A("fw download fail!\n");
1320 Adapter->bFWReady = _TRUE;
1321 pHalData->fw_ractrl = _TRUE;
1322 DBG_8723A("fw download ok!\n");
1326 rtl8723a_InitializeFirmwareVars(Adapter);
1328 if(pwrctrlpriv->reg_rfoff == _TRUE){
1329 pwrctrlpriv->rf_pwrstate = rf_off;
1332 // 2010/08/09 MH We need to check if we need to turnon or off RF after detecting
1333 // HW GPIO pin. Before PHY_RFConfig8192C.
1334 //HalDetectPwrDownMode(Adapter);
1335 // 2010/08/26 MH If Efuse does not support sective suspend then disable the function.
1336 //HalDetectSelectiveSuspendMode(Adapter);
1338 // Set RF type for BB/RF configuration
1339 _InitRFType(Adapter);//->_ReadRFType()
1341 // Save target channel
1342 // <Roger_Notes> Current Channel will be updated again later.
1343 pHalData->CurrentChannel = 6;//default set to 6
1346 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MAC);
1347 #if (HAL_MAC_ENABLE == 1)
1348 status = PHY_MACConfig8723A(Adapter);
1351 DBG_8723A("PHY_MACConfig8723A fault !!\n");
1357 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_BB);
1359 //d. Initialize BB related configurations.
1361 #if (HAL_BB_ENABLE == 1)
1362 status = PHY_BBConfig8723A(Adapter);
1365 DBG_8723A("PHY_BBConfig8723A fault !!\n");
1371 // 2011/11/15 MH Add for tx power by rate fine tune. We need to call the function after BB config.
1372 // Because the tx power by rate table is inited in BB config.
1374 // HAL_AdjustPwrIndexDiffRateOffset(Adapter);
1375 // HAL_AdjustPwrIndexbyRegistry(Adapter);
1377 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_RF);
1378 #if (HAL_RF_ENABLE == 1)
1379 status = PHY_RFConfig8723A(Adapter);
1382 DBG_8723A("PHY_RFConfig8723A fault !!\n");
1387 PHY_SetBBReg(Adapter, RF_T_METER, bMaskDWord, 0x0381808d);
1388 PHY_SetBBReg(Adapter, RF_SYN_G4, bMaskDWord, 0xf2ffff83);
1389 PHY_SetBBReg(Adapter, RF_SYN_G4, bMaskDWord, 0xf2ffff82);
1390 PHY_SetBBReg(Adapter, RF_SYN_G4, bMaskDWord, 0xf2ffff83);
1393 PHY_SetBBReg(Adapter, rFPGA0_TxInfo, bMaskDWord, 0x00000003); //0x804[14]=0
1394 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFInterfaceSW, bMaskDWord, 0x07000760); //0x870[6:5]=b'11
1395 PHY_SetBBReg(Adapter, rFPGA0_XA_RFInterfaceOE, bMaskDWord, 0x66F60210); //0x860[6:5]=b'00
1397 RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("%s: 0x870 = value 0x%x\n", __FUNCTION__, PHY_QueryBBReg(Adapter, 0x870, bMaskDWord)));
1402 // Joseph Note: Keep RfRegChnlVal for later use.
1404 pHalData->RfRegChnlVal[0] = PHY_QueryRFReg(Adapter, (RF_RADIO_PATH_E)0, RF_CHNLBW, bRFRegOffsetMask);
1405 pHalData->RfRegChnlVal[1] = PHY_QueryRFReg(Adapter, (RF_RADIO_PATH_E)1, RF_CHNLBW, bRFRegOffsetMask);
1408 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC02);
1409 if (!pHalData->bMACFuncEnable) {
1410 _InitQueueReservedPage(Adapter);
1411 _InitTxBufferBoundary(Adapter);
1413 _InitQueuePriority(Adapter);
1414 _InitPageBoundary(Adapter);
1415 _InitTransferPageSize(Adapter);
1417 // Get Rx PHY status in order to report RSSI and others.
1418 _InitDriverInfoSize(Adapter, DRVINFO_SZ);
1420 _InitInterrupt(Adapter);
1421 hal_init_macaddr(Adapter);//set mac_address
1422 _InitNetworkType(Adapter);//set msr
1423 _InitWMACSetting(Adapter);
1424 _InitAdaptiveCtrl(Adapter);
1426 _InitRateFallback(Adapter);
1427 _InitRetryFunction(Adapter);
1428 InitUsbAggregationSetting(Adapter);
1429 _InitOperationMode(Adapter);//todo
1430 rtl8723a_InitBeaconParameters(Adapter);
1431 rtl8723a_InitBeaconMaxError(Adapter, _TRUE);
1433 #ifdef RTL8192CU_ADHOC_WORKAROUND_SETTING
1434 _InitAdhocWorkaroundParams(Adapter);
1437 #if ENABLE_USB_DROP_INCORRECT_OUT
1438 _InitHardwareDropIncorrectBulkOut(Adapter);
1441 #if defined(CONFIG_CONCURRENT_MODE) || defined(CONFIG_TX_MCAST2UNI)
1442 // Enable lifetime check for the four ACs
1443 rtw_write8(Adapter, REG_LIFETIME_EN, 0x0F);
1444 #ifdef CONFIG_TX_MCAST2UNI
1445 rtw_write16(Adapter, REG_PKT_VO_VI_LIFE_TIME, 0x0400); // unit: 256us. 256ms
1446 rtw_write16(Adapter, REG_PKT_BE_BK_LIFE_TIME, 0x0400); // unit: 256us. 256ms
1447 #else // CONFIG_TX_MCAST2UNI
1448 rtw_write16(Adapter, REG_PKT_VO_VI_LIFE_TIME, 0x3000); // unit: 256us. 3s
1449 rtw_write16(Adapter, REG_PKT_BE_BK_LIFE_TIME, 0x3000); // unit: 256us. 3s
1450 #endif // CONFIG_TX_MCAST2UNI
1451 #endif // CONFIG_CONCURRENT_MODE || CONFIG_TX_MCAST2UNI
1455 _InitHWLed(Adapter);
1458 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_TURN_ON_BLOCK);
1459 _BBTurnOnBlock(Adapter);
1460 //NicIFSetMacAddress(padapter, padapter->PermanentAddress);
1462 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_SECURITY);
1463 invalidate_cam_all(Adapter);
1465 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC11);
1466 // 2010/12/17 MH We need to set TX power according to EFUSE content at first.
1467 PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
1469 rtl8723a_InitAntenna_Selection(Adapter);
1472 //set 0x0 to 0xFF by tynli. Default enable HW SEQ NUM.
1473 rtw_write8(Adapter,REG_HWSEQ_CTRL, 0xFF);
1476 // Disable BAR, suggested by Scott
1477 // 2010.04.09 add by hpfan
1479 rtw_write32(Adapter, REG_BAR_MODE_CTRL, 0x0201ffff);
1481 if(pregistrypriv->wifi_spec)
1482 rtw_write16(Adapter,REG_FAST_EDCA_CTRL ,0);
1484 // Move by Neo for USB SS from above setp
1485 _RfPowerSave(Adapter);
1487 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_IQK);
1488 // 2010/08/26 MH Merge from 8192CE.
1489 //sherry masked that it has been done in _RfPowerSave
1491 //recovery for 8192cu and 9723Au 20111017
1492 if(pwrctrlpriv->rf_pwrstate == rf_on)
1494 if(pHalData->bIQKInitialized ){
1495 rtl8192c_PHY_IQCalibrate(Adapter,_TRUE);
1497 rtl8192c_PHY_IQCalibrate(Adapter,_FALSE);
1498 pHalData->bIQKInitialized = _TRUE;
1501 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_PW_TRACK);
1502 rtl8192c_odm_CheckTXPowerTracking(Adapter);
1504 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_LCK);
1505 rtl8192c_PHY_LCCalibrate(Adapter);
1507 #ifdef CONFIG_BT_COEXIST
1508 rtl8723a_SingleDualAntennaDetection(Adapter);
1513 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC21);
1514 #ifdef USB_INTERFERENCE_ISSUE
1515 //fixed USB interface interference issue
1516 rtw_write8(Adapter, 0xfe40, 0xe0);
1517 rtw_write8(Adapter, 0xfe41, 0x8d);
1518 rtw_write8(Adapter, 0xfe42, 0x80);
1519 rtw_write32(Adapter,0x20c,0xfd0320);
1521 //2011/01/07 ,suggest by Johnny,for solved the problem that too many protocol error on USB bus
1522 if(!IS_81xxC_VENDOR_UMC_A_CUT(pHalData->VersionID) )//&& !IS_92C_SERIAL(pHalData->VersionID))// TSMC , 8188
1525 rtw_write8(Adapter, 0xFE40, 0xE6);
1526 rtw_write8(Adapter, 0xFE41, 0x94);
1527 rtw_write8(Adapter, 0xFE42, 0x80);
1530 rtw_write8(Adapter, 0xFE40, 0xE0);
1531 rtw_write8(Adapter, 0xFE41, 0x19);
1532 rtw_write8(Adapter, 0xFE42, 0x80);
1535 rtw_write8(Adapter, 0xFE40, 0xE5);
1536 rtw_write8(Adapter, 0xFE41, 0x91);
1537 rtw_write8(Adapter, 0xFE42, 0x80);
1540 rtw_write8(Adapter, 0xFE40, 0xE2);
1541 rtw_write8(Adapter, 0xFE41, 0x81);
1542 rtw_write8(Adapter, 0xFE42, 0x80);
1547 #endif //USB_INTERFERENCE_ISSUE
1549 //HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_PABIAS);
1550 // _InitPABias(Adapter);
1552 #ifdef CONFIG_BT_COEXIST
1553 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_BT_COEXIST);
1554 // Init BT hw config.
1555 BT_InitHwConfig(Adapter);
1558 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_INIT_HAL_DM);
1559 rtl8723a_InitHalDm(Adapter);
1561 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_MISC31);
1562 rtw_hal_set_hwreg(Adapter, HW_VAR_NAV_UPPER, (u8*)&NavUpper);
1564 // 2011/03/09 MH debug only, UMC-B cut pass 2500 S5 test, but we need to fin root cause.
1565 if (((rtw_read32(Adapter, rFPGA0_RFMOD) & 0xFF000000) != 0x83000000)) {
1566 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT(24), 1);
1567 RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("%s: IQK fail recorver\n", __FUNCTION__));
1570 #ifdef CONFIG_XMIT_ACK
1571 //ack for xmit mgmt frames.
1572 rtw_write32(Adapter, REG_FWHW_TXQ_CTRL, rtw_read32(Adapter, REG_FWHW_TXQ_CTRL)|BIT(12));
1573 #endif //CONFIG_XMIT_ACK
1575 //_dbg_dump_macreg(padapter);
1578 HAL_INIT_PROFILE_TAG(HAL_INIT_STAGES_END);
1580 DBG_8723A("%s in %dms\n", __FUNCTION__, rtw_get_passing_time_ms(init_start_time));
1582 #ifdef DBG_HAL_INIT_PROFILING
1583 hal_init_stages_timestamp[HAL_INIT_STAGES_END]=rtw_get_current_time();
1585 for(hal_init_profiling_i=0;hal_init_profiling_i<HAL_INIT_STAGES_NUM-1;hal_init_profiling_i++) {
1586 DBG_8723A("DBG_HAL_INIT_PROFILING: %35s, %u, %5u, %5u\n"
1587 , hal_init_stages_str[hal_init_profiling_i]
1588 , hal_init_stages_timestamp[hal_init_profiling_i]
1589 , (hal_init_stages_timestamp[hal_init_profiling_i+1]-hal_init_stages_timestamp[hal_init_profiling_i])
1590 , rtw_get_time_interval_ms(hal_init_stages_timestamp[hal_init_profiling_i], hal_init_stages_timestamp[hal_init_profiling_i+1])
1601 #define SYNC_SD7_20110802_phy_SsPwrSwitch92CU
1602 #ifdef SYNC_SD7_20110802_phy_SsPwrSwitch92CU
1604 phy_SsPwrSwitch92CU(
1606 rt_rf_power_state eRFPowerState,
1610 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
1613 switch( eRFPowerState )
1616 if (bRegSSPwrLvl == 1)
1618 // 1. Enable MAC Clock. Can not be enabled now.
1619 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) | BIT(3));
1621 // 2. Force PWM, Enable SPS18_LDO_Marco_Block
1622 rtw_write8(Adapter, REG_SPS0_CTRL,
1623 rtw_read8(Adapter, REG_SPS0_CTRL) | (BIT0|BIT3));
1625 // 3. restore BB, AFE control register.
1627 if (pHalData->rf_type == RF_2T2R)
1628 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 1);
1630 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 1);
1631 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 1);
1632 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1, 0);
1635 //DbgPrint("0x0e70 = %x\n", Adapter->PS_BBRegBackup[PSBBREG_AFE0]);
1636 //PHY_SetBBReg(Adapter, 0x0e70, bMaskDWord ,Adapter->PS_BBRegBackup[PSBBREG_AFE0] );
1637 //PHY_SetBBReg(Adapter, 0x0e70, bMaskDWord ,0x631B25A0 );
1638 if (pHalData->rf_type == RF_2T2R)
1639 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x63DB25A0 );
1640 else if (pHalData->rf_type == RF_1T1R)
1641 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x631B25A0 );
1643 // 4. issue 3-wire command that RF set to Rx idle mode. This is used to re-write the RX idle mode.
1644 // We can only prvide a usual value instead and then HW will modify the value by itself.
1645 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0x32D95);
1646 if (pHalData->rf_type == RF_2T2R)
1648 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0x32D95);
1651 else // Level 2 or others.
1653 //h. AFE_PLL_CTRL 0x28[7:0] = 0x80 //disable AFE PLL
1654 rtw_write8(Adapter, REG_AFE_PLL_CTRL, 0x81);
1656 // i. AFE_XTAL_CTRL 0x24[15:0] = 0x880F //gated AFE DIG_CLOCK
1657 rtw_write16(Adapter, REG_AFE_XTAL_CTRL, 0x800F);
1660 // 1. Enable MAC Clock. Can not be enabled now.
1661 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) | BIT(3));
1663 // 2. Force PWM, Enable SPS18_LDO_Marco_Block
1664 rtw_write8(Adapter, REG_SPS0_CTRL,
1665 rtw_read8(Adapter, REG_SPS0_CTRL) | (BIT0|BIT3));
1667 // 3. restore BB, AFE control register.
1669 if (pHalData->rf_type == RF_2T2R)
1670 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 1);
1672 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 1);
1673 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 1);
1674 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1, 0);
1677 if (pHalData->rf_type == RF_2T2R)
1678 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x63DB25A0 );
1679 else if (pHalData->rf_type == RF_1T1R)
1680 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x631B25A0 );
1682 // 4. issue 3-wire command that RF set to Rx idle mode. This is used to re-write the RX idle mode.
1683 // We can only prvide a usual value instead and then HW will modify the value by itself.
1684 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0x32D95);
1685 if (pHalData->rf_type == RF_2T2R)
1687 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0x32D95);
1690 // 5. gated MAC Clock
1691 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) & ~(BIT(3)));
1692 //rtw_write8(Adapter, REG_SYS_CLKR+1, rtw_read8(Adapter, REG_SYS_CLKR+1)|(BIT3));
1695 //u8 eRFPath = RF_PATH_A,value8 = 0, retry = 0;
1697 //PHY_SetRFReg(Adapter, (RF_RADIO_PATH_E)eRFPath, 0x0, bMaskByte0, 0x0);
1698 // 2010/08/12 MH Add for B path under SS test.
1699 //if (pHalData->RF_Type == RF_2T2R)
1700 //PHY_SetRFReg(Adapter, RF_PATH_B, 0x0, bMaskByte0, 0x0);
1702 bytetmp = rtw_read8(Adapter, REG_APSD_CTRL);
1703 rtw_write8(Adapter, REG_APSD_CTRL, bytetmp & ~BIT6);
1707 // Set BB reset at first
1708 rtw_write8(Adapter, REG_SYS_FUNC_EN, 0x17 );//0x16
1711 rtw_write8(Adapter, REG_TXPAUSE, 0x0);
1713 //CardSelectiveSuspendLeave(Adapter);
1720 value8 = rtw_read8(Adapter, REG_SPS0_CTRL) ;
1721 if (IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID))
1724 value8 &= ~(BIT0|BIT3);
1725 if (bRegSSPwrLvl == 1)
1727 RT_TRACE(_module_hal_init_c_, _drv_err_, ("SS LVL1\n"));
1728 // Disable RF and BB only for SelectSuspend.
1730 // 1. Set BB/RF to shutdown.
1731 // (1) Reg878[5:3]= 0 // RF rx_code for preamble power saving
1732 // (2)Reg878[21:19]= 0 //Turn off RF-B
1733 // (3) RegC04[7:4]= 0 // turn off all paths for packet detection
1734 // (4) Reg800[1] = 1 // enable preamble power saving
1735 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF0] = PHY_QueryBBReg(Adapter, rFPGA0_XAB_RFParameter, bMaskDWord);
1736 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF1] = PHY_QueryBBReg(Adapter, rOFDM0_TRxPathEnable, bMaskDWord);
1737 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF2] = PHY_QueryBBReg(Adapter, rFPGA0_RFMOD, bMaskDWord);
1738 if (pHalData->rf_type == RF_2T2R)
1740 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 0);
1742 else if (pHalData->rf_type == RF_1T1R)
1744 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 0);
1746 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 0);
1747 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1,1);
1749 // 2 .AFE control register to power down. bit[30:22]
1750 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_AFE0] = PHY_QueryBBReg(Adapter, rRx_Wait_CCA, bMaskDWord);
1751 if (pHalData->rf_type == RF_2T2R)
1752 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x00DB25A0);
1753 else if (pHalData->rf_type == RF_1T1R)
1754 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x001B25A0);
1756 // 3. issue 3-wire command that RF set to power down.
1757 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0);
1758 if (pHalData->rf_type == RF_2T2R)
1760 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0);
1763 // 4. Force PFM , disable SPS18_LDO_Marco_Block
1764 rtw_write8(Adapter, REG_SPS0_CTRL, value8);
1766 // 5. gated MAC Clock
1767 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) & ~(BIT(3)));
1769 else // Level 2 or others.
1771 RT_TRACE(_module_hal_init_c_, _drv_err_, ("SS LVL2\n"));
1773 u8 eRFPath = RF_PATH_A,value8 = 0;
1774 rtw_write8(Adapter, REG_TXPAUSE, 0xFF);
1775 PHY_SetRFReg(Adapter, (RF_RADIO_PATH_E)eRFPath, 0x0, bMaskByte0, 0x0);
1776 // 2010/08/12 MH Add for B path under SS test.
1777 //if (pHalData->RF_Type == RF_2T2R)
1778 //PHY_SetRFReg(Adapter, RF_PATH_B, 0x0, bMaskByte0, 0x0);
1781 rtw_write8(Adapter, REG_APSD_CTRL, value8);//0x40
1783 // After switch APSD, we need to delay for stability
1786 // Set BB reset at first
1788 value8 |=( FEN_USBD | FEN_USBA | FEN_BB_GLB_RSTn);
1789 rtw_write8(Adapter, REG_SYS_FUNC_EN,value8 );//0x16
1792 // Disable RF and BB only for SelectSuspend.
1794 // 1. Set BB/RF to shutdown.
1795 // (1) Reg878[5:3]= 0 // RF rx_code for preamble power saving
1796 // (2)Reg878[21:19]= 0 //Turn off RF-B
1797 // (3) RegC04[7:4]= 0 // turn off all paths for packet detection
1798 // (4) Reg800[1] = 1 // enable preamble power saving
1799 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF0] = PHY_QueryBBReg(Adapter, rFPGA0_XAB_RFParameter, bMaskDWord);
1800 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF1] = PHY_QueryBBReg(Adapter, rOFDM0_TRxPathEnable, bMaskDWord);
1801 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF2] = PHY_QueryBBReg(Adapter, rFPGA0_RFMOD, bMaskDWord);
1802 if (pHalData->rf_type == RF_2T2R)
1804 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x380038, 0);
1806 else if (pHalData->rf_type == RF_1T1R)
1808 PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 0);
1810 PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 0);
1811 PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT1,1);
1813 // 2 .AFE control register to power down. bit[30:22]
1814 Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_AFE0] = PHY_QueryBBReg(Adapter, rRx_Wait_CCA, bMaskDWord);
1815 if (pHalData->rf_type == RF_2T2R)
1816 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x00DB25A0);
1817 else if (pHalData->rf_type == RF_1T1R)
1818 PHY_SetBBReg(Adapter, rRx_Wait_CCA, bMaskDWord ,0x001B25A0);
1820 // 3. issue 3-wire command that RF set to power down.
1821 PHY_SetRFReg(Adapter,RF_PATH_A, 0, bRFRegOffsetMask,0);
1822 if (pHalData->rf_type == RF_2T2R)
1824 PHY_SetRFReg(Adapter,RF_PATH_B, 0, bRFRegOffsetMask,0);
1827 // 4. Force PFM , disable SPS18_LDO_Marco_Block
1828 rtw_write8(Adapter, REG_SPS0_CTRL, value8);
1830 // 2010/10/13 MH/Isaachsu exchange sequence.
1831 //h. AFE_PLL_CTRL 0x28[7:0] = 0x80 //disable AFE PLL
1832 rtw_write8(Adapter, REG_AFE_PLL_CTRL, 0x80);
1835 // i. AFE_XTAL_CTRL 0x24[15:0] = 0x880F //gated AFE DIG_CLOCK
1836 rtw_write16(Adapter, REG_AFE_XTAL_CTRL, 0xA80F);
1838 // 5. gated MAC Clock
1839 //WriteXBYTE(REG_SYS_CLKR+1, ReadXBYTE(REG_SYS_CLKR+1) & ~(BIT(3)));
1840 //rtw_write8(Adapter, REG_SYS_CLKR+1, rtw_read8(Adapter, REG_SYS_CLKR+1)& ~(BIT3))
1842 //CardSelectiveSuspendEnter(Adapter);
1851 } // phy_PowerSwitch92CU
1853 void _ps_open_RF(_adapter *padapter) {
1854 //here call with bRegSSPwrLvl 1, bRegSSPwrLvl 2 needs to be verified
1855 phy_SsPwrSwitch92CU(padapter, rf_on, 1);
1858 void _ps_close_RF(_adapter *padapter){
1859 //here call with bRegSSPwrLvl 1, bRegSSPwrLvl 2 needs to be verified
1860 phy_SsPwrSwitch92CU(padapter, rf_off, 1);
1862 #endif //SYNC_SD7_20110802_phy_SsPwrSwitch92CU
1871 /***************************************
1872 j. GPIO_PIN_CTRL 0x44[31:0]=0x000 //
1873 k. Value = GPIO_PIN_CTRL[7:0]
1874 l. GPIO_PIN_CTRL 0x44[31:0] = 0x00FF0000 | (value <<8); //write external PIN level
1875 m. GPIO_MUXCFG 0x42 [15:0] = 0x0780
1876 n. LEDCFG 0x4C[15:0] = 0x8080
1877 ***************************************/
1882 //1. Disable GPIO[7:0]
1883 rtw_write16(Adapter, REG_GPIO_PIN_CTRL+2, 0x0000);
1884 value32 = rtw_read32(Adapter, REG_GPIO_PIN_CTRL) & 0xFFFF00FF;
1885 value8 = (u8) (value32&0x000000FF);
1886 value32 |= ((value8<<8) | 0x00FF0000);
1887 rtw_write32(Adapter, REG_GPIO_PIN_CTRL, value32);
1889 //2. Disable GPIO[10:8]
1890 rtw_write8(Adapter, REG_GPIO_MUXCFG+3, 0x00);
1891 value16 = rtw_read16(Adapter, REG_GPIO_MUXCFG+2) & 0xFF0F;
1892 value8 = (u8) (value16&0x000F);
1893 value16 |= ((value8<<4) | 0x0780);
1894 rtw_write16(Adapter, REG_GPIO_MUXCFG+2, value16);
1896 //3. Disable LED0 & 1
1897 rtw_write16(Adapter, REG_LEDCFG0, 0x8080);
1899 //RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Disable GPIO and LED.\n"));
1901 } //end of _DisableGPIO()
1904 _ResetFWDownloadRegister(
1910 value32 = rtw_read32(Adapter, REG_MCUFWDL);
1911 value32 &= ~(MCUFWDL_EN | MCUFWDL_RDY);
1912 rtw_write32(Adapter, REG_MCUFWDL, value32);
1913 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Reset FW download register.\n"));
1922 int rtStatus = _SUCCESS;
1923 u32 pollingCount = 0;
1926 //disable RF/ AFE AD/DA
1928 rtw_write8(Adapter, REG_APSD_CTRL, value8);
1931 #if (RTL8192CU_ASIC_VERIFICATION)
1935 if(rtw_read8(Adapter, REG_APSD_CTRL) & APSDOFF_STATUS){
1936 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Disable RF, AFE, AD, DA Done!\n"));
1940 if(pollingCount++ > POLLING_READY_TIMEOUT_COUNT){
1941 //RT_TRACE(COMP_INIT, DBG_SERIOUS, ("Failed to polling APSDOFF_STATUS done!\n"));
1949 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Disable RF, AFE,AD, DA.\n"));
1962 value16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
1963 value16 &= ~(FEN_BBRSTB | FEN_BB_GLB_RSTn);
1964 rtw_write16(Adapter, REG_SYS_FUNC_EN, value16);
1965 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Reset BB.\n"));
1976 value16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
1977 value16 &= ~FEN_CPUEN;
1978 rtw_write16(Adapter, REG_SYS_FUNC_EN, value16);
1979 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Reset MCU.\n"));
1983 _DisableMAC_AFE_PLL(
1989 //disable MAC/ AFE PLL
1990 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
1991 value32 |= APDM_MAC;
1992 rtw_write32(Adapter, REG_APS_FSMCO, value32);
1994 value32 |= APFM_OFF;
1995 rtw_write32(Adapter, REG_APS_FSMCO, value32);
1996 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Disable MAC, AFE PLL.\n"));
2000 _AutoPowerDownToHostOff(
2005 rtw_write8(Adapter, REG_SPS0_CTRL, 0x22);
2007 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
2009 value32 |= APDM_HOST;//card disable
2010 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2011 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Auto Power Down to Host-off state.\n"));
2014 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
2015 value32 &= ~AFSM_PCIE;
2016 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2027 value32 = rtw_read32(Adapter, REG_APS_FSMCO);
2030 value32 |= AFSM_HSUS;
2031 rtw_write32(Adapter, REG_APS_FSMCO, value32);
2033 //RT_ASSERT(0 == (rtw_read32(Adapter, REG_APS_FSMCO) & BIT(12)),(""));
2034 //RT_TRACE(COMP_INIT, DBG_LOUD, ("Set USB suspend.\n"));
2039 _DisableRFAFEAndResetBB(
2043 /**************************************
2044 a. TXPAUSE 0x522[7:0] = 0xFF //Pause MAC TX queue
2045 b. RF path 0 offset 0x00 = 0x00 // disable RF
2046 c. APSD_CTRL 0x600[7:0] = 0x40
2047 d. SYS_FUNC_EN 0x02[7:0] = 0x16 //reset BB state machine
2048 e. SYS_FUNC_EN 0x02[7:0] = 0x14 //reset BB state machine
2049 ***************************************/
2050 u8 eRFPath = 0,value8 = 0;
2051 rtw_write8(Adapter, REG_TXPAUSE, 0xFF);
2052 PHY_SetRFReg(Adapter, (RF_RADIO_PATH_E)eRFPath, 0x0, bMaskByte0, 0x0);
2055 rtw_write8(Adapter, REG_APSD_CTRL, value8);//0x40
2058 value8 |=( FEN_USBD | FEN_USBA | FEN_BB_GLB_RSTn);
2059 rtw_write8(Adapter, REG_SYS_FUNC_EN,value8 );//0x16
2061 value8 &=( ~FEN_BB_GLB_RSTn );
2062 rtw_write8(Adapter, REG_SYS_FUNC_EN, value8); //0x14
2064 //RT_TRACE(COMP_INIT, DBG_LOUD, ("======> RF off and reset BB.\n"));
2068 _ResetDigitalProcedure1(
2074 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2076 if(pHalData->FirmwareVersion <= 0x20){
2077 /*****************************
2078 f. MCUFWDL 0x80[7:0]=0 // reset MCU ready status
2079 g. SYS_FUNC_EN 0x02[10]= 0 // reset MCU register, (8051 reset)
2080 h. SYS_FUNC_EN 0x02[15-12]= 5 // reset MAC register, DCORE
2081 i. SYS_FUNC_EN 0x02[10]= 1 // enable MCU register, (8051 enable)
2082 ******************************/
2084 rtw_write8(Adapter, REG_MCUFWDL, 0);
2086 valu16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
2087 rtw_write16(Adapter, REG_SYS_FUNC_EN, (valu16 & (~FEN_CPUEN)));//reset MCU ,8051
2089 valu16 = rtw_read16(Adapter, REG_SYS_FUNC_EN)&0x0FFF;
2090 rtw_write16(Adapter, REG_SYS_FUNC_EN, (valu16 |(FEN_HWPDN|FEN_ELDR)));//reset MAC
2092 #ifdef DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE
2095 if( (val=rtw_read8(Adapter, REG_MCUFWDL)))
2096 DBG_8723A("DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE %s:%d REG_MCUFWDL:0x%02x\n", __FUNCTION__, __LINE__, val);
2101 valu16 = rtw_read16(Adapter, REG_SYS_FUNC_EN);
2102 rtw_write16(Adapter, REG_SYS_FUNC_EN, (valu16 | FEN_CPUEN));//enable MCU ,8051
2106 if(rtw_read8(Adapter, REG_MCUFWDL) & BIT1)
2107 { //IF fw in RAM code, do reset
2109 rtw_write8(Adapter, REG_MCUFWDL, 0);
2110 if(Adapter->bFWReady){
2111 // 2010/08/25 MH Accordign to RD alfred's suggestion, we need to disable other
2112 // HRCV INT to influence 8051 reset.
2113 rtw_write8(Adapter, REG_FWIMR, 0x20);
2115 rtw_write8(Adapter, REG_HMETFR+3, 0x20);//8051 reset by self
2117 while( (retry_cnts++ <100) && (FEN_CPUEN &rtw_read16(Adapter, REG_SYS_FUNC_EN)))
2119 rtw_udelay_os(50);//PlatformStallExecution(50);//us
2122 if(retry_cnts >= 100){
2123 DBG_8723A("%s #####=> 8051 reset failed!.........................\n", __FUNCTION__);
2124 // if 8051 reset fail we trigger GPIO 0 for LA
2125 //PlatformEFIOWrite4Byte( Adapter,
2126 // REG_GPIO_PIN_CTRL,
2128 // 2010/08/31 MH According to Filen's info, if 8051 reset fail, reset MAC directly.
2129 rtw_write8(Adapter, REG_SYS_FUNC_EN+1, 0x50); //Reset MAC and Enable 8051
2133 //DBG_8723A("%s =====> 8051 reset success (%d) .\n", __FUNCTION__, retry_cnts);
2137 DBG_8723A("%s =====> 8051 in RAM but !Adapter->bFWReady\n", __FUNCTION__);
2141 //DBG_8723A("%s =====> 8051 in ROM.\n", __FUNCTION__);
2144 #ifdef DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE
2147 if( (val=rtw_read8(Adapter, REG_MCUFWDL)))
2148 DBG_8723A("DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE %s:%d REG_MCUFWDL:0x%02x\n", __FUNCTION__, __LINE__, val);
2152 rtw_write8(Adapter, REG_SYS_FUNC_EN+1, 0x54); //Reset MAC and Enable 8051
2155 // Clear rpwm value for initial toggle bit trigger.
2156 rtw_write8(Adapter, REG_USB_HRPWM, 0x00);
2159 /*****************************
2160 Without HW auto state machine
2161 g. SYS_CLKR 0x08[15:0] = 0x30A3 //disable MAC clock
2162 h. AFE_PLL_CTRL 0x28[7:0] = 0x80 //disable AFE PLL
2163 i. AFE_XTAL_CTRL 0x24[15:0] = 0x880F //gated AFE DIG_CLOCK
2164 j. SYS_ISO_CTRL 0x00[7:0] = 0xF9 // isolated digital to PON
2165 ******************************/
2166 //rtw_write16(Adapter, REG_SYS_CLKR, 0x30A3);
2167 rtw_write16(Adapter, REG_SYS_CLKR, 0x70A3);//modify to 0x70A3 by Scott.
2168 rtw_write8(Adapter, REG_AFE_PLL_CTRL, 0x80);
2169 rtw_write16(Adapter, REG_AFE_XTAL_CTRL, 0x880F);
2170 rtw_write8(Adapter, REG_SYS_ISO_CTRL, 0xF9);
2174 // Disable all RF/BB power
2175 rtw_write8(Adapter, REG_RF_CTRL, 0x00);
2177 //RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Reset Digital.\n"));
2182 _ResetDigitalProcedure2(
2186 /*****************************
2187 k. SYS_FUNC_EN 0x03[7:0] = 0x44 // disable ELDR runction
2188 l. SYS_CLKR 0x08[15:0] = 0x3083 // disable ELDR clock
2189 m. SYS_ISO_CTRL 0x01[7:0] = 0x83 // isolated ELDR to PON
2190 ******************************/
2191 //rtw_write8(Adapter, REG_SYS_FUNC_EN+1, 0x44);//marked by Scott.
2192 //rtw_write16(Adapter, REG_SYS_CLKR, 0x3083);
2193 //rtw_write8(Adapter, REG_SYS_ISO_CTRL+1, 0x83);
2195 rtw_write16(Adapter, REG_SYS_CLKR, 0x70a3); //modify to 0x70a3 by Scott.
2196 rtw_write8(Adapter, REG_SYS_ISO_CTRL+1, 0x82); //modify to 0x82 by Scott.
2207 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2210 /*****************************
2211 n. LDOA15_CTRL 0x20[7:0] = 0x04 // disable A15 power
2212 o. LDOV12D_CTRL 0x21[7:0] = 0x54 // disable digital core power
2213 r. When driver call disable, the ASIC will turn off remaining clock automatically
2214 ******************************/
2216 rtw_write8(Adapter, REG_LDOA15_CTRL, 0x04);
2217 //PlatformIOWrite1Byte(Adapter, REG_LDOV12D_CTRL, 0x54);
2219 value8 = rtw_read8(Adapter, REG_LDOV12D_CTRL);
2220 value8 &= (~LDV12_EN);
2221 rtw_write8(Adapter, REG_LDOV12D_CTRL, value8);
2222 //RT_TRACE(COMP_INIT, DBG_LOUD, (" REG_LDOV12D_CTRL Reg0x21:0x%02x.\n",value8));
2225 /*****************************
2226 h. SPS0_CTRL 0x11[7:0] = 0x23 //enter PFM mode
2227 i. APS_FSMCO 0x04[15:0] = 0x4802 // set USB suspend
2228 ******************************/
2232 if (IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID))
2235 rtw_write8(Adapter, REG_SPS0_CTRL, value8);
2240 //value16 |= (APDM_HOST | /*AFSM_HSUS |*/PFM_ALDN);
2241 // 2010/08/31 According to Filen description, we need to use HW to shut down 8051 automatically.
2242 // Becasue suspend operatione need the asistance of 8051 to wait for 3ms.
2243 value16 |= (APDM_HOST | AFSM_HSUS |PFM_ALDN);
2247 value16 |= (APDM_HOST | AFSM_HSUS |PFM_ALDN);
2250 rtw_write16(Adapter, REG_APS_FSMCO,value16 );//0x4802
2252 rtw_write8(Adapter, REG_RSV_CTRL, 0x0e);
2255 static void rtl8723au_hw_power_down(_adapter *padapter)
2259 DBG_8723A("PowerDownRTL8723U\n");
2262 // 1. Run Card Disable Flow
2263 // Done before this function call.
2265 // 2. 0x04[16] = 0 // reset WLON
2266 u1bTmp = rtw_read8(padapter, REG_APS_FSMCO+2);
2267 rtw_write8(padapter, REG_APS_FSMCO+2, (u1bTmp&(~BIT0)));
2269 // 3. 0x04[12:11] = 2b'11 // enable suspend
2270 // Done before this function call.
2272 // 4. 0x04[15] = 1 // enable PDN
2273 u1bTmp = rtw_read8(padapter, REG_APS_FSMCO+1);
2274 rtw_write8(padapter, REG_APS_FSMCO+1, (u1bTmp|BIT7));
2278 // Description: RTL8723e card disable power sequence v003 which suggested by Scott.
2279 // First created by tynli. 2011.01.28.
2282 CardDisableRTL8723U(
2287 // PMGNT_INFO pMgntInfo = &(Adapter->MgntInfo);
2289 DBG_8723A("CardDisableRTL8723U\n");
2291 // USB-MF Card Disable Flow
2292 // 1. Run LPS WL RFOFF flow
2293 HalPwrSeqCmdParsing(Adapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, rtl8723A_enter_lps_flow);
2295 // 2. 0x1F[7:0] = 0 // turn off RF
2296 rtw_write8(Adapter, REG_RF_CTRL, 0x00);
2298 // ==== Reset digital sequence ======
2299 if((rtw_read8(Adapter, REG_MCUFWDL)&BIT7) &&
2300 Adapter->bFWReady) //8051 RAM code
2302 rtl8723a_FirmwareSelfReset(Adapter);
2305 // Reset MCU. Suggested by Filen. 2011.01.26. by tynli.
2306 u1bTmp = rtw_read8(Adapter, REG_SYS_FUNC_EN+1);
2307 rtw_write8(Adapter, REG_SYS_FUNC_EN+1, (u1bTmp&(~BIT2)));
2309 // g. MCUFWDL 0x80[1:0]=0 // reset MCU ready status
2310 rtw_write8(Adapter, REG_MCUFWDL, 0x00);
2312 // ==== Reset digital sequence end ======
2313 // if((pMgntInfo->RfOffReason & RF_CHANGE_BY_HW) )
2315 // Card disable power action flow
2316 HalPwrSeqCmdParsing(Adapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, rtl8723A_card_disable_flow);
2319 // Reset MCU IO Wrapper, added by Roger, 2011.08.30.
2320 u1bTmp = rtw_read8(Adapter, REG_RSV_CTRL+1);
2321 rtw_write8(Adapter, REG_RSV_CTRL+1, (u1bTmp&(~BIT0)));
2322 u1bTmp = rtw_read8(Adapter, REG_RSV_CTRL+1);
2323 rtw_write8(Adapter, REG_RSV_CTRL+1, u1bTmp|BIT0);
2325 // 7. RSV_CTRL 0x1C[7:0] = 0x0E // lock ISO/CLK/Power control register
2326 rtw_write8(Adapter, REG_RSV_CTRL, 0x0e);
2331 u32 rtl8723au_hal_deinit(PADAPTER padapter)
2333 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
2336 DBG_8723A("==> %s\n", __FUNCTION__);
2338 #ifdef CONFIG_BT_COEXIST
2339 BT_HaltProcess(padapter);
2341 // 2011/02/18 To Fix RU LNA power leakage problem. We need to execute below below in
2342 // Adapter init and halt sequence. Accordingto EEchou's opinion, we can enable the ability for all
2343 // IC. Accord to johnny's opinion, only RU need the support.
2344 CardDisableRTL8723U(padapter);
2350 unsigned int rtl8723au_inirp_init(PADAPTER Adapter)
2353 struct recv_buf *precvbuf;
2355 struct dvobj_priv *pdev= adapter_to_dvobj(Adapter);
2356 struct intf_hdl * pintfhdl=&Adapter->iopriv.intf;
2357 struct recv_priv *precvpriv = &(Adapter->recvpriv);
2358 u32 (*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
2359 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2360 u32 (*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
2361 HAL_DATA_TYPE *pHalData=GET_HAL_DATA(Adapter);
2362 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2366 _read_port = pintfhdl->io_ops._read_port;
2370 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("===> usb_inirp_init \n"));
2372 precvpriv->ff_hwaddr = RECV_BULK_IN_ADDR;
2374 //issue Rx irp to receive data
2375 precvbuf = (struct recv_buf *)precvpriv->precv_buf;
2376 for(i=0; i<NR_RECVBUFF; i++)
2378 if(_read_port(pintfhdl, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf) == _FALSE )
2380 RT_TRACE(_module_hci_hal_init_c_,_drv_err_,("usb_rx_init: usb_read_port error \n"));
2386 precvpriv->free_recv_buf_queue_cnt--;
2389 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2390 _read_interrupt = pintfhdl->io_ops._read_interrupt;
2391 if(_read_interrupt(pintfhdl, RECV_INT_IN_ADDR) == _FALSE )
2393 RT_TRACE(_module_hci_hal_init_c_,_drv_err_,("usb_rx_init: usb_read_interrupt error \n"));
2396 pHalData->IntrMask[0]=rtw_read32(Adapter, REG_USB_HIMR);
2397 MSG_8723A("pHalData->IntrMask = 0x%04x\n", pHalData->IntrMask[0]);
2398 pHalData->IntrMask[0]|=UHIMR_C2HCMD|UHIMR_CPWM;
2399 rtw_write32(Adapter, REG_USB_HIMR,pHalData->IntrMask[0]);
2400 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2404 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("<=== usb_inirp_init \n"));
2412 unsigned int rtl8723au_inirp_deinit(PADAPTER Adapter)
2414 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2415 u32 (*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
2416 HAL_DATA_TYPE *pHalData=GET_HAL_DATA(Adapter);
2417 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2418 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("\n ===> usb_rx_deinit \n"));
2420 rtw_read_port_cancel(Adapter);
2421 #ifdef CONFIG_USB_INTERRUPT_IN_PIPE
2422 pHalData->IntrMask[0]=rtw_read32(Adapter, REG_USB_HIMR);
2423 MSG_8723A("%s pHalData->IntrMask = 0x%04x\n",__FUNCTION__, pHalData->IntrMask[0]);
2424 pHalData->IntrMask[0]=0x0;
2425 rtw_write32(Adapter, REG_USB_HIMR,pHalData->IntrMask[0]);
2426 RT_TRACE(_module_hci_hal_init_c_,_drv_info_,("\n <=== usb_rx_deinit \n"));
2427 #endif //CONFIG_USB_INTERRUPT_IN_PIPE
2437 //RT_ASSERT((channel < 14), ("Channel %d no is supported!\n"));
2439 if(channel < 3){ // Channel 1~3
2442 else if(channel < 9){ // Channel 4~9
2446 return 2; // Channel 10~14
2450 //-------------------------------------------------------------------
2452 // EEPROM/EFUSE Content Parsing
2454 //-------------------------------------------------------------------
2462 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2464 if(_FALSE == AutoloadFail){
2466 pHalData->EEPROMVID = le16_to_cpu( *(u16 *)&PROMContent[EEPROM_VID]);
2467 pHalData->EEPROMPID = le16_to_cpu( *(u16 *)&PROMContent[EEPROM_PID]);
2469 // Customer ID, 0x00 and 0xff are reserved for Realtek.
2470 pHalData->EEPROMCustomerID = *(u8 *)&PROMContent[EEPROM_CUSTOMER_ID];
2471 pHalData->EEPROMSubCustomerID = *(u8 *)&PROMContent[EEPROM_SUBCUSTOMER_ID];
2475 pHalData->EEPROMVID = EEPROM_Default_VID;
2476 pHalData->EEPROMPID = EEPROM_Default_PID;
2478 // Customer ID, 0x00 and 0xff are reserved for Realtek.
2479 pHalData->EEPROMCustomerID = EEPROM_Default_CustomerID;
2480 pHalData->EEPROMSubCustomerID = EEPROM_Default_SubCustomerID;
2484 // For customized behavior.
2485 if((pHalData->EEPROMVID == 0x103C) || (pHalData->EEPROMVID == 0x1629))// HP Lite-On for RTL8188CUS Slim Combo.
2486 pHalData->CustomerID = RT_CID_819x_HP;
2488 // Decide CustomerID according to VID/DID or EEPROM
2489 switch(pHalData->EEPROMCustomerID)
2491 case EEPROM_CID_DEFAULT:
2492 if((pHalData->EEPROMVID == 0x2001) && (pHalData->EEPROMPID == 0x3308))
2493 pHalData->CustomerID = RT_CID_DLINK;
2494 else if((pHalData->EEPROMVID == 0x2001) && (pHalData->EEPROMPID == 0x3309))
2495 pHalData->CustomerID = RT_CID_DLINK;
2496 else if((pHalData->EEPROMVID == 0x2001) && (pHalData->EEPROMPID == 0x330a))
2497 pHalData->CustomerID = RT_CID_DLINK;
2499 case EEPROM_CID_WHQL:
2501 Adapter->bInHctTest = TRUE;
2503 pMgntInfo->bSupportTurboMode = FALSE;
2504 pMgntInfo->bAutoTurboBy8186 = FALSE;
2506 pMgntInfo->PowerSaveControl.bInactivePs = FALSE;
2507 pMgntInfo->PowerSaveControl.bIPSModeBackup = FALSE;
2508 pMgntInfo->PowerSaveControl.bLeisurePs = FALSE;
2510 pMgntInfo->keepAliveLevel = 0;
2512 Adapter->bUnloadDriverwhenS3S4 = FALSE;
2516 pHalData->CustomerID = RT_CID_DEFAULT;
2521 MSG_8723A("EEPROMVID = 0x%04x\n", pHalData->EEPROMVID);
2522 MSG_8723A("EEPROMPID = 0x%04x\n", pHalData->EEPROMPID);
2523 MSG_8723A("EEPROMCustomerID : 0x%02x\n", pHalData->EEPROMCustomerID);
2524 MSG_8723A("EEPROMSubCustomerID: 0x%02x\n", pHalData->EEPROMSubCustomerID);
2526 MSG_8723A("RT_CustomerID: 0x%02x\n", pHalData->CustomerID);
2538 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(Adapter);
2540 if(_FALSE == AutoloadFail){
2541 //Read Permanent MAC address and set value to hardware
2542 memcpy(pEEPROM->mac_addr, &PROMContent[EEPROM_MAC_ADDR], ETH_ALEN);
2545 //Random assigh MAC address
2546 u8 sMacAddr[MAC_ADDR_LEN] = {0x00, 0xE0, 0x4C, 0x81, 0x92, 0x00};
2547 //sMacAddr[5] = (u8)GetRandomNumber(1, 254);
2548 memcpy(pEEPROM->mac_addr, sMacAddr, ETH_ALEN);
2550 DBG_8723A("%s MAC Address from EFUSE = "MAC_FMT"\n",__FUNCTION__, MAC_ARG(pEEPROM->mac_addr));
2551 //NicIFSetMacAddress(Adapter, Adapter->PermanentAddress);
2552 //RT_PRINT_ADDR(COMP_INIT|COMP_EFUSE, DBG_LOUD, "MAC Addr: %s", Adapter->PermanentAddress);
2563 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2565 u8 boardType = BOARD_USB_DONGLE;
2568 if(IS_8723_SERIES(pHalData->VersionID))
2569 pHalData->rf_type = RF_1T1R;
2571 pHalData->rf_type = RF_2T2R;
2573 pHalData->BoardType = boardType;
2577 boardType = PROMContent[EEPROM_NORMAL_BoardType];
2578 boardType &= BOARD_TYPE_NORMAL_MASK;//bit[7:5]
2581 pHalData->BoardType = boardType;
2582 MSG_8723A("_ReadBoardType(%x)\n",pHalData->BoardType);
2584 if (boardType == BOARD_USB_High_PA)
2585 pHalData->ExternalPA = 1;
2596 struct led_priv *pledpriv = &(Adapter->ledpriv);
2597 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2598 #ifdef CONFIG_SW_LED
2599 pledpriv->bRegUseLed = _TRUE;
2604 switch(pHalData->CustomerID)
2606 case RT_CID_DEFAULT:
2607 pledpriv->LedStrategy = SW_LED_MODE1;
2608 pledpriv->bRegUseLed = _TRUE;
2611 case RT_CID_819x_HP:
2612 pledpriv->LedStrategy = SW_LED_MODE6;
2616 pledpriv->LedStrategy = SW_LED_MODE1;
2620 if( BOARD_MINICARD == pHalData->BoardType )
2622 pledpriv->LedStrategy = SW_LED_MODE6;
2624 pHalData->bLedOpenDrain = _TRUE;// Support Open-drain arrangement for controlling the LED. Added by Roger, 2009.10.16.
2626 pledpriv->LedStrategy = HW_LED;
2627 #endif //CONFIG_SW_LED
2637 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2638 struct dm_priv *pdmpriv = &pHalData->dmpriv;
2642 // ThermalMeter from EEPROM
2645 tempval = PROMContent[EEPROM_THERMAL_METER];
2647 tempval = EEPROM_Default_ThermalMeter;
2649 pHalData->EEPROMThermalMeter = (tempval&0x1f); //[4:0]
2651 if(pHalData->EEPROMThermalMeter == 0x1f || AutoloadFail)
2652 pdmpriv->bAPKThermalMeterIgnore = _TRUE;
2654 pdmpriv->ThermalMeter[0] = pHalData->EEPROMThermalMeter;
2666 // Read HW power down mode selection
2667 static void _ReadPSSetting(PADAPTER Adapter, u8*PROMContent, u8 AutoloadFail)
2670 Adapter->pwrctrlpriv.bHWPowerdown = _FALSE;
2671 Adapter->pwrctrlpriv.bSupportRemoteWakeup = _FALSE;
2674 //if(SUPPORT_HW_RADIO_DETECT(Adapter))
2675 Adapter->pwrctrlpriv.bHWPwrPindetect = Adapter->registrypriv.hwpwrp_detect;
2677 //Adapter->pwrctrlpriv.bHWPwrPindetect = _FALSE;//dongle not support new
2680 //hw power down mode selection , 0:rf-off / 1:power down
2682 if(Adapter->registrypriv.hwpdn_mode==2)
2683 Adapter->pwrctrlpriv.bHWPowerdown = (PROMContent[EEPROM_RF_OPT3] & BIT4);
2685 Adapter->pwrctrlpriv.bHWPowerdown = Adapter->registrypriv.hwpdn_mode;
2687 // decide hw if support remote wakeup function
2688 // if hw supported, 8051 (SIE) will generate WeakUP signal( D+/D- toggle) when autoresume
2689 Adapter->pwrctrlpriv.bSupportRemoteWakeup = (PROMContent[EEPROM_TEST_USB_OPT] & BIT1)?_TRUE :_FALSE;
2691 //if(SUPPORT_HW_RADIO_DETECT(Adapter))
2692 //Adapter->registrypriv.usbss_enable = Adapter->pwrctrlpriv.bSupportRemoteWakeup ;
2694 DBG_8723A("%s...bHWPwrPindetect(%x)-bHWPowerdown(%x) ,bSupportRemoteWakeup(%x)\n",__FUNCTION__,
2695 Adapter->pwrctrlpriv.bHWPwrPindetect,Adapter->pwrctrlpriv.bHWPowerdown ,Adapter->pwrctrlpriv.bSupportRemoteWakeup);
2697 DBG_8723A("### PS params=> power_mgnt(%x),usbss_enable(%x) ###\n",Adapter->registrypriv.power_mgnt,Adapter->registrypriv.usbss_enable);
2709 Hal_EfuseParsePIDVID_8723AU(
2715 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
2719 pHalData->EEPROMVID = 0;
2720 pHalData->EEPROMPID = 0;
2725 pHalData->EEPROMVID = le16_to_cpu(*(u16*)&hwinfo[EEPROM_VID_8723AU]);
2726 pHalData->EEPROMPID = le16_to_cpu(*(u16*)&hwinfo[EEPROM_PID_8723AU]);
2730 MSG_8723A("EEPROM VID = 0x%4x\n", pHalData->EEPROMVID);
2731 MSG_8723A("EEPROM PID = 0x%4x\n", pHalData->EEPROMPID);
2736 Hal_EfuseParseMACAddr_8723AU(
2743 u8 sMacAddr[6] = {0x00, 0xE0, 0x4C, 0x87, 0x23, 0x00};
2744 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
2748 // sMacAddr[5] = (u8)GetRandomNumber(1, 254);
2750 pEEPROM->mac_addr[i] = sMacAddr[i];
2754 //Read Permanent MAC address
2756 memcpy(pEEPROM->mac_addr, &hwinfo[EEPROM_MAC_ADDR_8723AU], ETH_ALEN);
2760 usValue = *(u16*)&hwinfo[EEPROM_MAC_ADDR_8723S+i];
2761 *((u16*)(&pEEPROM->mac_addr[i])) = usValue;
2765 // NicIFSetMacAddress(pAdapter, pAdapter->PermanentAddress);
2767 RT_TRACE(_module_hci_hal_init_c_, _drv_notice_,
2768 ("Hal_EfuseParseMACAddr_8723AU: Permanent Address=%02x:%02x:%02x:%02x:%02x:%02x\n",
2769 pEEPROM->mac_addr[0], pEEPROM->mac_addr[1],
2770 pEEPROM->mac_addr[2], pEEPROM->mac_addr[3],
2771 pEEPROM->mac_addr[4], pEEPROM->mac_addr[5]));
2775 #ifdef CONFIG_EFUSE_CONFIG_FILE
2776 static u32 Hal_readPGDataFromConfigFile(
2784 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
2785 u8 *PROMContent = pEEPROM->efuse_eeprom_data;
2788 temp[2] = 0; // add end of string '\0'
2790 fp = filp_open("/system/etc/wifi/wifi_efuse.map", O_RDWR, 0644);
2792 pEEPROM->bloadfile_fail_flag= _TRUE;
2793 DBG_8723A("Error, Efuse configure file doesn't exist.\n");
2800 DBG_8723A("Efuse configure file:\n");
2801 for (i=0; i<HWSET_MAX_SIZE_88E; i++) {
2802 vfs_read(fp, temp, 2, &pos);
2803 PROMContent[i] = simple_strtoul(temp, NULL, 16 );
2804 pos += 1; // Filter the space character
2805 DBG_8723A("%02X \n", PROMContent[i]);
2810 filp_close(fp, NULL);
2812 pEEPROM->bloadfile_fail_flag= _FALSE;
2818 Hal_ReadMACAddrFromFile_8723AU(
2827 u32 curtime = rtw_get_current_time();
2828 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
2831 u8 null_mac_addr[ETH_ALEN] = {0, 0, 0,0, 0, 0};
2832 u8 multi_mac_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
2834 memset(source_addr, 0, 18);
2835 memset(pEEPROM->mac_addr, 0, ETH_ALEN);
2837 fp = filp_open("/data/wifimac.txt", O_RDWR, 0644);
2839 pEEPROM->bloadmac_fail_flag = _TRUE;
2840 DBG_8723A("Error, wifi mac address file doesn't exist.\n");
2845 DBG_8723A("wifi mac address:\n");
2846 vfs_read(fp, source_addr, 18, &pos);
2847 source_addr[17] = ':';
2849 head = end = source_addr;
2850 for (i=0; i<ETH_ALEN; i++) {
2851 while (end && (*end != ':') )
2854 if (end && (*end == ':') )
2857 pEEPROM->mac_addr[i] = simple_strtoul(head, NULL, 16 );
2863 DBG_8723A("%02x \n", pEEPROM->mac_addr[i]);
2868 filp_close(fp, NULL);
2871 if ((!memcmp(pEEPROM->mac_addr, null_mac_addr, ETH_ALEN)) ||
2872 (!memcmp(pEEPROM->mac_addr, multi_mac_addr, ETH_ALEN)) ) {
2873 pEEPROM->mac_addr[0] = 0x00;
2874 pEEPROM->mac_addr[1] = 0xe0;
2875 pEEPROM->mac_addr[2] = 0x4c;
2876 pEEPROM->mac_addr[3] = (u8)(curtime & 0xff) ;
2877 pEEPROM->mac_addr[4] = (u8)((curtime>>8) & 0xff) ;
2878 pEEPROM->mac_addr[5] = (u8)((curtime>>16) & 0xff) ;
2881 pEEPROM->bloadmac_fail_flag = _FALSE;
2883 DBG_8723A("Hal_ReadMACAddrFromFile_8188ES: Permanent Address = %02x-%02x-%02x-%02x-%02x-%02x\n",
2884 pEEPROM->mac_addr[0], pEEPROM->mac_addr[1],
2885 pEEPROM->mac_addr[2], pEEPROM->mac_addr[3],
2886 pEEPROM->mac_addr[4], pEEPROM->mac_addr[5]);
2888 #endif //CONFIG_EFUSE_CONFIG_FILE
2896 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
2897 //PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
2898 u8 hwinfo[HWSET_MAX_SIZE];
2900 #ifdef CONFIG_EFUSE_CONFIG_FILE
2901 Hal_readPGDataFromConfigFile(padapter);
2902 #else //CONFIG_EFUSE_CONFIG_FILE
2903 Hal_InitPGData(padapter, hwinfo);
2904 #endif //CONFIG_EFUSE_CONFIG_FILE
2905 Hal_EfuseParseIDCode(padapter, hwinfo);
2906 Hal_EfuseParsePIDVID_8723AU(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2907 Hal_EfuseParseEEPROMVer(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2908 #ifdef CONFIG_EFUSE_CONFIG_FILE
2909 Hal_ReadMACAddrFromFile_8723AU(padapter);
2910 #else //CONFIG_EFUSE_CONFIG_FILE
2911 Hal_EfuseParseMACAddr_8723AU(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2913 Hal_EfuseParseTxPowerInfo_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2914 _ReadBoardType(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2915 Hal_EfuseParseBTCoexistInfo_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2917 rtl8723a_EfuseParseChnlPlan(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2918 Hal_EfuseParseThermalMeter_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2919 _ReadLEDSetting(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2920 // _ReadRFSetting(Adapter, PROMContent, pEEPROM->bautoload_fail_flag);
2921 // _ReadPSSetting(Adapter, PROMContent, pEEPROM->bautoload_fail_flag);
2922 Hal_EfuseParseAntennaDiversity(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2924 Hal_EfuseParseEEPROMVer(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2925 Hal_EfuseParseCustomerID(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2926 Hal_EfuseParseRateIndicationOption(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2927 Hal_EfuseParseXtal_8723A(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
2929 // The following part initialize some vars by PG info.
2931 Hal_InitChannelPlan(padapter);
2935 //hal_CustomizedBehavior_8723U(Adapter);
2937 // Adapter->bDongle = (PROMContent[EEPROM_EASY_REPLACEMENT] == 1)? 0: 1;
2938 DBG_8723A("%s(): REPLACEMENT = %x\n",__FUNCTION__,padapter->bDongle);
2941 static void _ReadPROMContent(
2945 EEPROM_EFUSE_PRIV *pEEPROM = GET_EEPROM_EFUSE_PRIV(Adapter);
2946 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2947 u8 PROMContent[HWSET_MAX_SIZE]={0};
2952 eeValue = rtw_read8(Adapter, REG_9346CR);
2953 // To check system boot selection.
2954 pEEPROM->EepromOrEfuse = (eeValue & BOOT_FROM_EEPROM) ? _TRUE : _FALSE;
2955 pEEPROM->bautoload_fail_flag = (eeValue & EEPROM_EN) ? _FALSE : _TRUE;
2958 DBG_8723A("Boot from %s, Autoload %s !\n", (pEEPROM->EepromOrEfuse ? "EEPROM" : "EFUSE"),
2959 (pEEPROM->bautoload_fail_flag ? "Fail" : "OK") );
2961 readAdapterInfo(Adapter);
2970 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2973 //if(Adapter->bInHctTest){
2974 // pMgntInfo->PowerSaveControl.bInactivePs = FALSE;
2975 // pMgntInfo->PowerSaveControl.bIPSModeBackup = FALSE;
2976 // pMgntInfo->PowerSaveControl.bLeisurePs = FALSE;
2977 // pMgntInfo->keepAliveLevel = 0;
2988 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
2991 pHalData->rf_chip = RF_PSEUDO_11N;
2993 pHalData->rf_chip = RF_6052;
2997 void _ReadSilmComboMode(PADAPTER Adapter)
2999 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3001 pHalData->SlimComboDbg = _FALSE; // Default is not debug mode.
3006 // We should set Efuse cell selection to WiFi cell in default.
3011 // Added by Roger, 2010.11.23.
3020 value32 = rtw_read32(Adapter, EFUSE_TEST);
3021 value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_WIFI_SEL_0);
3022 rtw_write32(Adapter, EFUSE_TEST, value32);
3025 static int _ReadAdapterInfo8723AU(PADAPTER Adapter)
3027 //HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3028 u32 start=rtw_get_current_time();
3030 MSG_8723A("====> _ReadAdapterInfo8723AU\n");
3032 //Efuse_InitSomeVar(Adapter);
3034 hal_EfuseCellSel(Adapter);
3036 _ReadRFType(Adapter);//rf_chip -> _InitRFType()
3037 _ReadPROMContent(Adapter);
3039 // 2010/10/25 MH THe function must be called after borad_type & IC-Version recognize.
3040 _ReadSilmComboMode(Adapter);
3042 _InitOtherVariable(Adapter);
3044 //MSG_8723A("%s()(done), rf_chip=0x%x, rf_type=0x%x\n", __FUNCTION__, pHalData->rf_chip, pHalData->rf_type);
3046 MSG_8723A("<==== _ReadAdapterInfo8723AU in %d ms\n", rtw_get_passing_time_ms(start));
3052 static void ReadAdapterInfo8723AU(PADAPTER Adapter)
3054 // Read EEPROM size before call any EEPROM function
3055 Adapter->EepromAddressSize = GetEEPROMSize8723A(Adapter);
3057 _ReadAdapterInfo8723AU(Adapter);
3061 #define GPIO_DEBUG_PORT_NUM 0
3062 static void rtl8192cu_trigger_gpio_0(_adapter *padapter)
3066 DBG_8723A("==> trigger_gpio_0...\n");
3067 rtw_write16_async(padapter,REG_GPIO_PIN_CTRL,0);
3068 rtw_write8_async(padapter,REG_GPIO_PIN_CTRL+2,0xFF);
3069 gpioctrl = (BIT(GPIO_DEBUG_PORT_NUM)<<24 )|(BIT(GPIO_DEBUG_PORT_NUM)<<16);
3070 rtw_write32_async(padapter,REG_GPIO_PIN_CTRL,gpioctrl);
3071 gpioctrl |= (BIT(GPIO_DEBUG_PORT_NUM)<<8);
3072 rtw_write32_async(padapter,REG_GPIO_PIN_CTRL,gpioctrl);
3073 DBG_8723A("<=== trigger_gpio_0...\n");
3078 * If variable not handled here,
3079 * some variables will be processed in SetHwReg8723A()
3081 void SetHwReg8723AU(PADAPTER Adapter, u8 variable, u8* val)
3083 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
3089 case HW_VAR_RXDMA_AGG_PG_TH:
3090 #ifdef CONFIG_USB_RX_AGGREGATION
3092 u8 threshold = *val;
3094 threshold = pHalData->UsbRxAggPageCount;
3095 SetHwReg8723A(Adapter, HW_VAR_RXDMA_AGG_PG_TH, &threshold);
3100 case HW_VAR_SET_RPWM:
3101 rtw_write8(Adapter, REG_USB_HRPWM, *val);
3104 case HW_VAR_TRIGGER_GPIO_0:
3105 rtl8192cu_trigger_gpio_0(Adapter);
3109 SetHwReg8723A(Adapter, variable, val);
3117 * If variable not handled here,
3118 * some variables will be processed in GetHwReg8723A()
3120 void GetHwReg8723AU(PADAPTER Adapter, u8 variable, u8* val)
3122 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
3129 GetHwReg8723A(Adapter, variable, val);
3138 // Query setting of specified variable.
3141 GetHalDefVar8192CUsb(
3143 HAL_DEF_VARIABLE eVariable,
3147 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3148 u8 bResult = _SUCCESS;
3152 case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB:
3153 *((int *)pValue) = pHalData->dmpriv.UndecoratedSmoothedPWDB;
3155 case HAL_DEF_IS_SUPPORT_ANT_DIV:
3156 #ifdef CONFIG_ANTENNA_DIVERSITY
3157 *((u8 *)pValue) = (IS_92C_SERIAL(pHalData->VersionID) ||(pHalData->AntDivCfg==0))?_FALSE:_TRUE;
3160 case HAL_DEF_CURRENT_ANTENNA:
3161 #ifdef CONFIG_ANTENNA_DIVERSITY
3162 *(( u8*)pValue) = pHalData->CurAntenna;
3165 case HAL_DEF_DRVINFO_SZ:
3166 *(( u32*)pValue) = DRVINFO_SZ;
3168 case HAL_DEF_MAX_RECVBUF_SZ:
3169 *(( u32*)pValue) = MAX_RECVBUF_SZ;
3171 case HAL_DEF_RX_PACKET_OFFSET:
3172 *(( u32*)pValue) = RXDESC_SIZE + DRVINFO_SZ;
3174 case HAL_DEF_DBG_DUMP_RXPKT:
3175 *(( u8*)pValue) = pHalData->bDumpRxPkt;
3177 case HAL_DEF_DBG_DM_FUNC:
3178 *(( u32*)pValue) =pHalData->odmpriv.SupportAbility;
3180 case HW_VAR_MAX_RX_AMPDU_FACTOR:
3181 *(( u32*)pValue) = IEEE80211_HT_MAX_AMPDU_64K;
3183 case HW_DEF_ODM_DBG_FLAG:
3185 u8Byte DebugComponents = *((u32*)pValue);
3186 PDM_ODM_T pDM_Odm = &(pHalData->odmpriv);
3187 printk("pDM_Odm->DebugComponents = 0x%llx \n",pDM_Odm->DebugComponents );
3191 //RT_TRACE(COMP_INIT, DBG_WARNING, ("GetHalDefVar8192CUsb(): Unkown variable: %d!\n", eVariable));
3204 // Change default setting of specified variable.
3207 SetHalDefVar8192CUsb(
3209 HAL_DEF_VARIABLE eVariable,
3213 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
3214 u8 bResult = _SUCCESS;
3218 case HAL_DEF_DBG_DUMP_RXPKT:
3219 pHalData->bDumpRxPkt = *(( u8*)pValue);
3221 case HAL_DEF_DBG_DM_FUNC:
3223 u8 dm_func = *(( u8*)pValue);
3224 struct dm_priv *pdmpriv = &pHalData->dmpriv;
3225 DM_ODM_T *podmpriv = &pHalData->odmpriv;
3227 if(dm_func == 0){ //disable all dynamic func
3228 podmpriv->SupportAbility = DYNAMIC_FUNC_DISABLE;
3229 DBG_8723A("==> Disable all dynamic function...\n");
3231 else if(dm_func == 1){//disable DIG
3232 podmpriv->SupportAbility &= (~DYNAMIC_BB_DIG);
3233 DBG_8723A("==> Disable DIG...\n");
3235 else if(dm_func == 2){//disable High power
3236 podmpriv->SupportAbility &= (~DYNAMIC_BB_DYNAMIC_TXPWR);
3238 else if(dm_func == 3){//disable tx power tracking
3239 podmpriv->SupportAbility &= (~DYNAMIC_RF_CALIBRATION);
3240 DBG_8723A("==> Disable tx power tracking...\n");
3242 else if(dm_func == 4){//disable BT coexistence
3243 pdmpriv->DMFlag &= (~DYNAMIC_FUNC_BT);
3245 else if(dm_func == 5){//disable antenna diversity
3246 podmpriv->SupportAbility &= (~DYNAMIC_BB_ANT_DIV);
3248 else if(dm_func == 6){//turn on all dynamic func
3249 if(!(podmpriv->SupportAbility & DYNAMIC_BB_DIG))
3251 DIG_T *pDigTable = &podmpriv->DM_DigTable;
3252 pDigTable->CurIGValue= rtw_read8(Adapter,0xc50);
3254 pdmpriv->DMFlag |= DYNAMIC_FUNC_BT;
3255 podmpriv->SupportAbility = DYNAMIC_ALL_FUNC_ENABLE;
3256 DBG_8723A("==> Turn on all dynamic function...\n");
3260 case HW_DEF_FA_CNT_DUMP:
3262 u8 bRSSIDump = *((u8*)pValue);
3263 PDM_ODM_T pDM_Odm = &(pHalData->odmpriv);
3265 pDM_Odm->DebugComponents = ODM_COMP_DIG|ODM_COMP_FA_CNT ;
3267 pDM_Odm->DebugComponents = 0;
3271 case HW_DEF_ODM_DBG_FLAG:
3273 u8Byte DebugComponents = *((u8Byte*)pValue);
3274 PDM_ODM_T pDM_Odm = &(pHalData->odmpriv);
3275 pDM_Odm->DebugComponents = DebugComponents;
3279 //RT_TRACE(COMP_INIT, DBG_TRACE, ("SetHalDefVar819xUsb(): Unkown variable: %d!\n", eVariable));
3288 u32 _update_92cu_basic_rate(_adapter *padapter, unsigned int mask)
3290 PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
3291 unsigned int BrateCfg = 0;
3294 if(pHalData->VersionID != VERSION_TEST_CHIP_88C)
3295 BrateCfg = mask & 0x15F;
3296 else //for 88CU 46PING setting, Disable CCK 2M, 5.5M, Others must tuning
3297 BrateCfg = mask & 0x159;
3299 BrateCfg |= 0x01; // default enable 1M ACK rate
3304 void _update_response_rate(_adapter *padapter,unsigned int mask)
3307 // Set RRSR rate table.
3308 rtw_write8(padapter, REG_RRSR, mask&0xff);
3309 rtw_write8(padapter,REG_RRSR+1, (mask>>8)&0xff);
3311 // Set RTS initial rate
3317 rtw_write8(padapter, REG_INIRTS_RATE_SEL, RateIndex);
3320 void UpdateHalRAMask8192CUsb(PADAPTER padapter, u32 mac_id,u8 rssi_level )
3322 //volatile unsigned int result;
3324 u8 networkType, raid;
3325 u32 mask,rate_bitmap;
3326 u8 shortGIrate = _FALSE;
3327 int supportRateNum = 0;
3328 struct sta_info *psta;
3329 HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
3330 struct dm_priv *pdmpriv = &pHalData->dmpriv;
3331 struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
3332 struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
3333 WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
3334 #ifdef CONFIG_CONCURRENT_MODE
3335 if(rtw_buddy_adapter_up(padapter) && padapter->adapter_type > PRIMARY_ADAPTER)
3336 pHalData = GET_HAL_DATA(padapter->pbuddy_adapter);
3337 #endif //CONFIG_CONCURRENT_MODE
3339 if (mac_id >= NUM_STA) //CAM_SIZE
3344 psta = pmlmeinfo->FW_sta_info[mac_id].psta;
3352 case 0:// for infra mode
3353 #ifdef CONFIG_CONCURRENT_MODE
3354 case 2:// first station uses macid=0, second station uses macid=2
3356 supportRateNum = rtw_get_rateset_len(cur_network->SupportedRates);
3357 networkType = judge_network_type(padapter, cur_network->SupportedRates, supportRateNum) & 0xf;
3358 //pmlmeext->cur_wireless_mode = networkType;
3359 raid = networktype_to_raid(networkType);
3361 mask = update_supported_rate(cur_network->SupportedRates, supportRateNum);
3362 mask |= (pmlmeinfo->HT_enable)? update_MSC_rate(&(pmlmeinfo->HT_caps)): 0;
3365 if (support_short_GI(padapter, &(pmlmeinfo->HT_caps)))
3367 shortGIrate = _TRUE;
3372 case 1://for broadcast/multicast
3373 supportRateNum = rtw_get_rateset_len(pmlmeinfo->FW_sta_info[mac_id].SupportedRates);
3374 if(pmlmeext->cur_wireless_mode & WIRELESS_11B)
3375 networkType = WIRELESS_11B;
3377 networkType = WIRELESS_11G;
3378 raid = networktype_to_raid(networkType);
3380 mask = update_basic_rate(cur_network->SupportedRates, supportRateNum);
3384 default: //for each sta in IBSS
3385 supportRateNum = rtw_get_rateset_len(pmlmeinfo->FW_sta_info[mac_id].SupportedRates);
3386 networkType = judge_network_type(padapter, pmlmeinfo->FW_sta_info[mac_id].SupportedRates, supportRateNum) & 0xf;
3387 //pmlmeext->cur_wireless_mode = networkType;
3388 raid = networktype_to_raid(networkType);
3390 mask = update_supported_rate(cur_network->SupportedRates, supportRateNum);
3393 //todo: support HT in IBSS
3398 //mask &=0x0fffffff;
3399 rate_bitmap = 0x0fffffff;
3400 #ifdef CONFIG_ODM_REFRESH_RAMASK
3402 rate_bitmap = ODM_Get_Rate_Bitmap(&pHalData->odmpriv,mac_id,mask,rssi_level);
3403 printk("%s => mac_id:%d, networkType:0x%02x, mask:0x%08x\n\t ==> rssi_level:%d, rate_bitmap:0x%08x\n",
3404 __FUNCTION__,mac_id,networkType,mask,rssi_level,rate_bitmap);
3408 mask &= rate_bitmap;
3409 mask |= ((raid<<28)&0xf0000000);
3412 init_rate = get_highest_rate_idx(mask)&0x3f;
3414 if(pHalData->fw_ractrl == _TRUE)
3418 //arg = (cam_idx-4)&0x1f;//MACID
3419 arg = mac_id&0x1f;//MACID
3423 if (shortGIrate==_TRUE)
3426 DBG_8723A("update raid entry, mask=0x%x, arg=0x%x\n", mask, arg);
3428 rtl8192c_set_raid_cmd(padapter, mask, arg);
3433 if (shortGIrate==_TRUE)
3434 init_rate |= BIT(6);
3436 rtw_write8(padapter, (REG_INIDATA_RATE_SEL+mac_id), init_rate);
3442 psta->init_rate = init_rate;
3444 //set correct initial date rate for each mac_id
3445 pdmpriv->INIDATA_RATE[mac_id] = init_rate;
3448 static void rtl8723au_init_default_value(PADAPTER padapter)
3450 rtl8723a_init_default_value(padapter);
3453 static u8 rtl8192cu_ps_func(PADAPTER Adapter,HAL_INTF_PS_FUNC efunc_id, u8 *val)
3458 #if defined(CONFIG_AUTOSUSPEND) && defined(SUPPORT_HW_RFOFF_DETECTED)
3459 case HAL_USB_SELECT_SUSPEND:
3461 u8 bfwpoll = *(( u8*)val);
3462 rtl8192c_set_FwSelectSuspend_cmd(Adapter,bfwpoll ,500);//note fw to support hw power down ping detect
3465 #endif //CONFIG_AUTOSUSPEND && SUPPORT_HW_RFOFF_DETECTED
3473 void rtl8723au_set_hal_ops(_adapter * padapter)
3475 struct hal_ops *pHalFunc = &padapter->HalFunc;
3479 padapter->HalData = kzalloc(sizeof(HAL_DATA_TYPE), GFP_KERNEL);
3480 if(padapter->HalData == NULL){
3481 DBG_8723A("cant not alloc memory for HAL DATA \n");
3483 //memset(padapter->HalData, 0, sizeof(HAL_DATA_TYPE));
3484 padapter->hal_data_sz = sizeof(HAL_DATA_TYPE);
3486 pHalFunc->hal_init = &rtl8723au_hal_init;
3487 pHalFunc->hal_deinit = &rtl8723au_hal_deinit;
3489 //pHalFunc->free_hal_data = &rtl8192c_free_hal_data;
3491 pHalFunc->inirp_init = &rtl8723au_inirp_init;
3492 pHalFunc->inirp_deinit = &rtl8723au_inirp_deinit;
3494 pHalFunc->init_xmit_priv = &rtl8192cu_init_xmit_priv;
3495 pHalFunc->free_xmit_priv = &rtl8192cu_free_xmit_priv;
3497 pHalFunc->init_recv_priv = &rtl8192cu_init_recv_priv;
3498 pHalFunc->free_recv_priv = &rtl8192cu_free_recv_priv;
3499 #ifdef CONFIG_SW_LED
3500 pHalFunc->InitSwLeds = &rtl8723au_InitSwLeds;
3501 pHalFunc->DeInitSwLeds = &rtl8723au_DeInitSwLeds;
3502 #else //case of hw led or no led
3503 pHalFunc->InitSwLeds = NULL;
3504 pHalFunc->DeInitSwLeds = NULL;
3505 #endif//CONFIG_SW_LED
3507 pHalFunc->init_default_value = &rtl8723au_init_default_value;
3508 pHalFunc->intf_chip_configure = &rtl8192cu_interface_configure;
3509 pHalFunc->read_adapter_info = &ReadAdapterInfo8723AU;
3511 //pHalFunc->set_bwmode_handler = &PHY_SetBWMode8192C;
3512 //pHalFunc->set_channel_handler = &PHY_SwChnl8192C;
3514 //pHalFunc->hal_dm_watchdog = &rtl8192c_HalDmWatchDog;
3516 pHalFunc->SetHwRegHandler = &SetHwReg8723AU;
3517 pHalFunc->GetHwRegHandler = &GetHwReg8723AU;
3518 pHalFunc->GetHalDefVarHandler = &GetHalDefVar8192CUsb;
3519 pHalFunc->SetHalDefVarHandler = &SetHalDefVar8192CUsb;
3521 pHalFunc->UpdateRAMaskHandler = &UpdateHalRAMask8192CUsb;
3523 pHalFunc->hal_xmit = &rtl8192cu_hal_xmit;
3524 pHalFunc->mgnt_xmit = &rtl8192cu_mgnt_xmit;
3525 pHalFunc->hal_xmitframe_enqueue = &rtl8723au_hal_xmitframe_enqueue;
3527 #ifdef CONFIG_HOSTAPD_MLME
3528 pHalFunc->hostap_mgnt_xmit_entry = &rtl8192cu_hostap_mgnt_xmit_entry;
3530 pHalFunc->interface_ps_func = &rtl8192cu_ps_func;
3532 rtl8723a_set_hal_ops(pHalFunc);