| // SPDX-License-Identifier: GPL-2.0 |
| /****************************************************************************** |
| * |
| * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved. |
| * |
| ******************************************************************************/ |
| |
| #include "odm_precomp.h" |
| |
| static u32 edca_setting_DL_GMode[HT_IOT_PEER_MAX] = { |
| /*UNKNOWN, REALTEK_90, ALTEK_92SE BROADCOM, LINK ATHEROS, |
| *CISCO, MERU, MARVELL, 92U_AP, SELF_AP |
| */ |
| 0x4322, 0xa44f, 0x5e4322, 0xa42b, 0x5e4322, 0x4322, |
| 0xa42b, 0x5ea42b, 0xa44f, 0x5e4322, 0x5ea42b |
| }; |
| |
| static u32 edca_setting_UL[HT_IOT_PEER_MAX] = { |
| /*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM, RALINK, ATHEROS, |
| *CISCO, MERU, MARVELL, 92U_AP, SELF_AP(DownLink/Tx) |
| */ |
| 0x5e4322, 0xa44f, 0x5e4322, 0x5ea32b, 0x5ea422, 0x5ea322, |
| 0x3ea430, 0x5ea42b, 0x5ea44f, 0x5e4322, 0x5e4322}; |
| |
| static u32 edca_setting_DL[HT_IOT_PEER_MAX] = { |
| /*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM, RALINK, ATHEROS, |
| *CISCO, MERU, MARVELL, 92U_AP, SELF_AP(UpLink/Rx) |
| */ |
| 0xa44f, 0x5ea44f, 0x5e4322, 0x5ea42b, 0xa44f, 0xa630, |
| 0x5ea630, 0x5ea42b, 0xa44f, 0xa42b, 0xa42b}; |
| |
| void ODM_EdcaTurboInit(void *pDM_VOID) |
| { |
| PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID; |
| struct adapter *Adapter = pDM_Odm->Adapter; |
| |
| pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = false; |
| pDM_Odm->DM_EDCA_Table.bIsCurRDLState = false; |
| Adapter->recvpriv.bIsAnyNonBEPkts = false; |
| |
| ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD, |
| ("Original VO PARAM: 0x%x\n", |
| rtw_read32(pDM_Odm->Adapter, ODM_EDCA_VO_PARAM))); |
| ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD, |
| ("Original VI PARAM: 0x%x\n", |
| rtw_read32(pDM_Odm->Adapter, ODM_EDCA_VI_PARAM))); |
| ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD, |
| ("Original BE PARAM: 0x%x\n", |
| rtw_read32(pDM_Odm->Adapter, ODM_EDCA_BE_PARAM))); |
| ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD, |
| ("Original BK PARAM: 0x%x\n", |
| rtw_read32(pDM_Odm->Adapter, ODM_EDCA_BK_PARAM))); |
| } /* ODM_InitEdcaTurbo */ |
| |
| void odm_EdcaTurboCheck(void *pDM_VOID) |
| { |
| /* In HW integration first stage, we provide 4 different handles to |
| * operate at the same time. In stage2/3, we need to prove universal |
| * interface and merge all HW dynamic mechanism. |
| */ |
| PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID; |
| |
| ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD, |
| ("odm_EdcaTurboCheck ========================>\n")); |
| |
| if (!(pDM_Odm->SupportAbility & ODM_MAC_EDCA_TURBO)) |
| return; |
| |
| odm_EdcaTurboCheckCE(pDM_Odm); |
| ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD, |
| ("<========================odm_EdcaTurboCheck\n")); |
| } /* odm_CheckEdcaTurbo */ |
| |
| void odm_EdcaTurboCheckCE(void *pDM_VOID) |
| { |
| PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID; |
| struct adapter *Adapter = pDM_Odm->Adapter; |
| struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(Adapter); |
| struct recv_priv *precvpriv = &(Adapter->recvpriv); |
| struct registry_priv *pregpriv = &Adapter->registrypriv; |
| struct mlme_ext_priv *pmlmeext = &(Adapter->mlmeextpriv); |
| struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info); |
| u32 EDCA_BE_UL = 0x5ea42b; |
| u32 EDCA_BE_DL = 0x5ea42b; |
| u32 iot_peer = 0; |
| u8 wirelessmode = 0xFF; /* invalid value */ |
| u32 trafficIndex; |
| u32 edca_param; |
| u64 cur_tx_bytes = 0; |
| u64 cur_rx_bytes = 0; |
| u8 bbtchange = false; |
| u8 biasonrx = false; |
| struct hal_com_data *pHalData = GET_HAL_DATA(Adapter); |
| |
| if (!pDM_Odm->bLinked) { |
| precvpriv->bIsAnyNonBEPkts = false; |
| return; |
| } |
| |
| if (pregpriv->wifi_spec == 1) { |
| precvpriv->bIsAnyNonBEPkts = false; |
| return; |
| } |
| |
| if (pDM_Odm->pwirelessmode) |
| wirelessmode = *(pDM_Odm->pwirelessmode); |
| |
| iot_peer = pmlmeinfo->assoc_AP_vendor; |
| |
| if (iot_peer >= HT_IOT_PEER_MAX) { |
| precvpriv->bIsAnyNonBEPkts = false; |
| return; |
| } |
| |
| /* Check if the status needs to be changed. */ |
| if ((bbtchange) || (!precvpriv->bIsAnyNonBEPkts)) { |
| cur_tx_bytes = pdvobjpriv->traffic_stat.cur_tx_bytes; |
| cur_rx_bytes = pdvobjpriv->traffic_stat.cur_rx_bytes; |
| |
| /* traffic, TX or RX */ |
| if (biasonrx) { |
| if (cur_tx_bytes > (cur_rx_bytes << 2)) { |
| /* Uplink TP is present. */ |
| trafficIndex = UP_LINK; |
| } else { /* Balance TP is present. */ |
| trafficIndex = DOWN_LINK; |
| } |
| } else { |
| if (cur_rx_bytes > (cur_tx_bytes << 2)) { |
| /* Downlink TP is present. */ |
| trafficIndex = DOWN_LINK; |
| } else { /* Balance TP is present. */ |
| trafficIndex = UP_LINK; |
| } |
| } |
| |
| /* 92D txop can't be set to 0x3e for cisco1250 */ |
| if ((iot_peer == HT_IOT_PEER_CISCO) && |
| (wirelessmode == ODM_WM_N24G)) { |
| EDCA_BE_DL = edca_setting_DL[iot_peer]; |
| EDCA_BE_UL = edca_setting_UL[iot_peer]; |
| } else if ((iot_peer == HT_IOT_PEER_CISCO) && |
| ((wirelessmode == ODM_WM_G) || |
| (wirelessmode == (ODM_WM_B | ODM_WM_G)) || |
| (wirelessmode == ODM_WM_A) || |
| (wirelessmode == ODM_WM_B))) { |
| EDCA_BE_DL = edca_setting_DL_GMode[iot_peer]; |
| } else if ((iot_peer == HT_IOT_PEER_AIRGO) && |
| ((wirelessmode == ODM_WM_G) || |
| (wirelessmode == ODM_WM_A))) { |
| EDCA_BE_DL = 0xa630; |
| } else if (iot_peer == HT_IOT_PEER_MARVELL) { |
| EDCA_BE_DL = edca_setting_DL[iot_peer]; |
| EDCA_BE_UL = edca_setting_UL[iot_peer]; |
| } else if (iot_peer == HT_IOT_PEER_ATHEROS) { |
| /* Set DL EDCA for Atheros peer to 0x3ea42b. */ |
| EDCA_BE_DL = edca_setting_DL[iot_peer]; |
| } |
| |
| if (trafficIndex == DOWN_LINK) |
| edca_param = EDCA_BE_DL; |
| else |
| edca_param = EDCA_BE_UL; |
| |
| rtw_write32(Adapter, REG_EDCA_BE_PARAM, edca_param); |
| |
| pDM_Odm->DM_EDCA_Table.prv_traffic_idx = trafficIndex; |
| |
| pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = true; |
| } else { |
| /* Turn Off EDCA turbo here. */ |
| /* Restore original EDCA according to the declaration of AP. */ |
| if (pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA) { |
| rtw_write32(Adapter, REG_EDCA_BE_PARAM, pHalData->AcParam_BE); |
| pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = false; |
| } |
| } |
| } |