int rtl8723e_init_sw_vars( struct ieee80211_hw *hw ) { int err = 0; struct rtl_priv *rtlpriv = rtl_priv( hw ); struct rtl_pci *rtlpci = rtl_pcidev( rtl_pcipriv( hw ) ); const struct firmware *firmware; struct rtl_hal *rtlhal = rtl_hal( rtl_priv( hw ) ); char *fw_name = NULL; rtl8723e_bt_reg_init( hw ); rtlpriv->dm.b_dm_initialgain_enable = 1; rtlpriv->dm.dm_flag = 0; rtlpriv->dm.b_disable_framebursting = 0;; rtlpriv->dm.thermalvalue = 0; rtlpci->transmit_config = CFENDFORM | BIT( 12 ) | BIT( 13 ); /* compatible 5G band 88ce just 2.4G band & smsp */ rtlpriv->rtlhal.current_bandtype = BAND_ON_2_4G; rtlpriv->rtlhal.bandset = BAND_ON_2_4G; rtlpriv->rtlhal.macphymode = SINGLEMAC_SINGLEPHY; rtlpci->receive_config = ( RCR_APPFCS | RCR_APP_MIC | RCR_APP_ICV | RCR_APP_PHYST_RXFF | RCR_HTC_LOC_CTRL | RCR_AMF | RCR_ACF | RCR_ADF | RCR_AICV | RCR_AB | RCR_AM | RCR_APM | 0 ); rtlpci->irq_mask[0] = ( u32 ) ( PHIMR_ROK | PHIMR_RDU | PHIMR_VODOK | PHIMR_VIDOK | PHIMR_BEDOK | PHIMR_BKDOK | PHIMR_MGNTDOK | PHIMR_HIGHDOK | PHIMR_C2HCMD | PHIMR_HISRE_IND | PHIMR_TSF_BIT32_TOGGLE | PHIMR_TXBCNOK | PHIMR_PSTIMEOUT | 0 ); rtlpci->irq_mask[1] = ( u32 )( PHIMR_RXFOVW | 0 ); /* for LPS & IPS */ rtlpriv->psc.b_inactiveps = rtlpriv->cfg->mod_params->b_inactiveps; rtlpriv->psc.b_swctrl_lps = rtlpriv->cfg->mod_params->b_swctrl_lps; rtlpriv->psc.b_fwctrl_lps = rtlpriv->cfg->mod_params->b_fwctrl_lps; rtlpriv->psc.b_reg_fwctrl_lps = 3; rtlpriv->psc.reg_max_lps_awakeintvl = 5; /* for ASPM, you can close aspm through * set const_support_pciaspm = 0 */ rtl8723e_init_aspm_vars( hw ); if ( rtlpriv->psc.b_reg_fwctrl_lps == 1 ) rtlpriv->psc.fwctrl_psmode = FW_PS_MIN_MODE; else if ( rtlpriv->psc.b_reg_fwctrl_lps == 2 ) rtlpriv->psc.fwctrl_psmode = FW_PS_MAX_MODE; else if ( rtlpriv->psc.b_reg_fwctrl_lps == 3 ) rtlpriv->psc.fwctrl_psmode = FW_PS_DTIM_MODE; /* for firmware buf */ rtlpriv->rtlhal.pfirmware = ( u8 * ) vmalloc( 0x7000 ); if ( !rtlpriv->rtlhal.pfirmware ) { RT_TRACE( COMP_ERR, DBG_EMERG, ( "Can't alloc buffer for fw.\n" ) ); return 1; } if ( IS_VENDOR_8723_A_CUT( rtlhal->version ) ) fw_name = "rtlwifi/rtl8723fw.bin"; else if ( IS_81xxC_VENDOR_UMC_B_CUT( rtlhal->version ) ) { printk( "firemare: rtl8723fw_B.bin\n" ); fw_name = "rtlwifi/rtl8723fw_B.bin"; } err = request_firmware( &firmware, fw_name, rtlpriv->io.dev ); if ( err ) { RT_TRACE( COMP_ERR, DBG_EMERG, ( "Failed to request firmware!\n" ) ); return 1; } if ( firmware->size > 0x6000 ) { RT_TRACE( COMP_ERR, DBG_EMERG, ( "Firmware is too big!\n" ) ); release_firmware( firmware ); return 1; } memcpy( rtlpriv->rtlhal.pfirmware, firmware->data, firmware->size ); rtlpriv->rtlhal.fwsize = firmware->size; release_firmware( firmware ); RT_TRACE( COMP_INIT, DBG_LOUD, ( " FirmwareDownload OK\n" ) ); return err; }
int rtl8723e_init_sw_vars(struct ieee80211_hw *hw) { struct rtl_priv *rtlpriv = rtl_priv(hw); struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw)); struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw)); int err = 0; rtl8723e_bt_reg_init(hw); rtlpriv->btcoexist.btc_ops = rtl_btc_get_ops_pointer(); rtlpriv->dm.dm_initialgain_enable = 1; rtlpriv->dm.dm_flag = 0; rtlpriv->dm.disable_framebursting = 0; rtlpriv->dm.thermalvalue = 0; rtlpci->transmit_config = CFENDFORM | BIT(12) | BIT(13); /* compatible 5G band 88ce just 2.4G band & smsp */ rtlpriv->rtlhal.current_bandtype = BAND_ON_2_4G; rtlpriv->rtlhal.bandset = BAND_ON_2_4G; rtlpriv->rtlhal.macphymode = SINGLEMAC_SINGLEPHY; rtlpci->receive_config = (RCR_APPFCS | RCR_APP_MIC | RCR_APP_ICV | RCR_APP_PHYST_RXFF | RCR_HTC_LOC_CTRL | RCR_AMF | RCR_ACF | RCR_ADF | RCR_AICV | RCR_AB | RCR_AM | RCR_APM | 0); rtlpci->irq_mask[0] = (u32) (PHIMR_ROK | PHIMR_RDU | PHIMR_VODOK | PHIMR_VIDOK | PHIMR_BEDOK | PHIMR_BKDOK | PHIMR_MGNTDOK | PHIMR_HIGHDOK | PHIMR_C2HCMD | PHIMR_HISRE_IND | PHIMR_TSF_BIT32_TOGGLE | PHIMR_TXBCNOK | PHIMR_PSTIMEOUT | 0); rtlpci->irq_mask[1] = (u32)(PHIMR_RXFOVW | 0); /* for debug level */ rtlpriv->dbg.global_debuglevel = rtlpriv->cfg->mod_params->debug; /* for LPS & IPS */ rtlpriv->psc.inactiveps = rtlpriv->cfg->mod_params->inactiveps; rtlpriv->psc.swctrl_lps = rtlpriv->cfg->mod_params->swctrl_lps; rtlpriv->psc.fwctrl_lps = rtlpriv->cfg->mod_params->fwctrl_lps; if (rtlpriv->cfg->mod_params->disable_watchdog) pr_info("watchdog disabled\n"); rtlpriv->psc.reg_fwctrl_lps = 3; rtlpriv->psc.reg_max_lps_awakeintvl = 5; rtl8723e_init_aspm_vars(hw); if (rtlpriv->psc.reg_fwctrl_lps == 1) rtlpriv->psc.fwctrl_psmode = FW_PS_MIN_MODE; else if (rtlpriv->psc.reg_fwctrl_lps == 2) rtlpriv->psc.fwctrl_psmode = FW_PS_MAX_MODE; else if (rtlpriv->psc.reg_fwctrl_lps == 3) rtlpriv->psc.fwctrl_psmode = FW_PS_DTIM_MODE; /* for firmware buf */ rtlpriv->rtlhal.pfirmware = vzalloc(0x6000); if (!rtlpriv->rtlhal.pfirmware) { RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "Can't alloc buffer for fw.\n"); return 1; } if (IS_VENDOR_8723_A_CUT(rtlhal->version)) rtlpriv->cfg->fw_name = "rtlwifi/rtl8723fw.bin"; else if (IS_81xxC_VENDOR_UMC_B_CUT(rtlhal->version)) rtlpriv->cfg->fw_name = "rtlwifi/rtl8723fw_B.bin"; rtlpriv->max_fw_size = 0x6000; pr_info("Using firmware %s\n", rtlpriv->cfg->fw_name); err = request_firmware_nowait(THIS_MODULE, 1, rtlpriv->cfg->fw_name, rtlpriv->io.dev, GFP_KERNEL, hw, rtl_fw_cb); if (err) { RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "Failed to request firmware!\n"); return 1; } return 0; }