1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16#include "odm_precomp.h"
17
18static u32 edca_setting_DL_GMode[HT_IOT_PEER_MAX] = {
19
20
21
22 0x4322, 0xa44f, 0x5e4322, 0xa42b, 0x5e4322, 0x4322,
23 0xa42b, 0x5ea42b, 0xa44f, 0x5e4322, 0x5ea42b
24};
25
26static u32 edca_setting_UL[HT_IOT_PEER_MAX] = {
27
28
29
30 0x5e4322, 0xa44f, 0x5e4322, 0x5ea32b, 0x5ea422, 0x5ea322,
31 0x3ea430, 0x5ea42b, 0x5ea44f, 0x5e4322, 0x5e4322};
32
33static u32 edca_setting_DL[HT_IOT_PEER_MAX] = {
34
35
36
37 0xa44f, 0x5ea44f, 0x5e4322, 0x5ea42b, 0xa44f, 0xa630,
38 0x5ea630, 0x5ea42b, 0xa44f, 0xa42b, 0xa42b};
39
40void ODM_EdcaTurboInit(void *pDM_VOID)
41{
42 PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID;
43 struct adapter *Adapter = pDM_Odm->Adapter;
44
45 pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = false;
46 pDM_Odm->DM_EDCA_Table.bIsCurRDLState = false;
47 Adapter->recvpriv.bIsAnyNonBEPkts = false;
48
49 ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
50 ("Orginial VO PARAM: 0x%x\n",
51 rtw_read32(pDM_Odm->Adapter, ODM_EDCA_VO_PARAM)));
52 ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
53 ("Orginial VI PARAM: 0x%x\n",
54 rtw_read32(pDM_Odm->Adapter, ODM_EDCA_VI_PARAM)));
55 ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
56 ("Orginial BE PARAM: 0x%x\n",
57 rtw_read32(pDM_Odm->Adapter, ODM_EDCA_BE_PARAM)));
58 ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
59 ("Orginial BK PARAM: 0x%x\n",
60 rtw_read32(pDM_Odm->Adapter, ODM_EDCA_BK_PARAM)));
61}
62
63void odm_EdcaTurboCheck(void *pDM_VOID)
64{
65
66
67
68
69 PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID;
70
71 ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
72 ("odm_EdcaTurboCheck ========================>\n"));
73
74 if (!(pDM_Odm->SupportAbility & ODM_MAC_EDCA_TURBO))
75 return;
76
77 odm_EdcaTurboCheckCE(pDM_Odm);
78 ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
79 ("<========================odm_EdcaTurboCheck\n"));
80}
81
82void odm_EdcaTurboCheckCE(void *pDM_VOID)
83{
84 PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID;
85 struct adapter *Adapter = pDM_Odm->Adapter;
86 struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(Adapter);
87 struct recv_priv *precvpriv = &(Adapter->recvpriv);
88 struct registry_priv *pregpriv = &Adapter->registrypriv;
89 struct mlme_ext_priv *pmlmeext = &(Adapter->mlmeextpriv);
90 struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
91 u32 EDCA_BE_UL = 0x5ea42b;
92 u32 EDCA_BE_DL = 0x5ea42b;
93 u32 iot_peer = 0;
94 u8 wirelessmode = 0xFF;
95 u32 trafficIndex;
96 u32 edca_param;
97 u64 cur_tx_bytes = 0;
98 u64 cur_rx_bytes = 0;
99 u8 bbtchange = false;
100 u8 biasonrx = false;
101 struct hal_com_data *pHalData = GET_HAL_DATA(Adapter);
102
103 if (!pDM_Odm->bLinked) {
104 precvpriv->bIsAnyNonBEPkts = false;
105 return;
106 }
107
108 if ((pregpriv->wifi_spec == 1)) {
109 precvpriv->bIsAnyNonBEPkts = false;
110 return;
111 }
112
113 if (pDM_Odm->pwirelessmode)
114 wirelessmode = *(pDM_Odm->pwirelessmode);
115
116 iot_peer = pmlmeinfo->assoc_AP_vendor;
117
118 if (iot_peer >= HT_IOT_PEER_MAX) {
119 precvpriv->bIsAnyNonBEPkts = false;
120 return;
121 }
122
123
124 if ((bbtchange) || (!precvpriv->bIsAnyNonBEPkts)) {
125 cur_tx_bytes = pdvobjpriv->traffic_stat.cur_tx_bytes;
126 cur_rx_bytes = pdvobjpriv->traffic_stat.cur_rx_bytes;
127
128
129 if (biasonrx) {
130 if (cur_tx_bytes > (cur_rx_bytes << 2)) {
131
132 trafficIndex = UP_LINK;
133 } else {
134 trafficIndex = DOWN_LINK;
135 }
136 } else {
137 if (cur_rx_bytes > (cur_tx_bytes << 2)) {
138
139 trafficIndex = DOWN_LINK;
140 } else {
141 trafficIndex = UP_LINK;
142 }
143 }
144
145
146 if ((iot_peer == HT_IOT_PEER_CISCO) &&
147 (wirelessmode == ODM_WM_N24G)) {
148 EDCA_BE_DL = edca_setting_DL[iot_peer];
149 EDCA_BE_UL = edca_setting_UL[iot_peer];
150 } else if ((iot_peer == HT_IOT_PEER_CISCO) &&
151 ((wirelessmode == ODM_WM_G) ||
152 (wirelessmode == (ODM_WM_B | ODM_WM_G)) ||
153 (wirelessmode == ODM_WM_A) ||
154 (wirelessmode == ODM_WM_B))) {
155 EDCA_BE_DL = edca_setting_DL_GMode[iot_peer];
156 } else if ((iot_peer == HT_IOT_PEER_AIRGO) &&
157 ((wirelessmode == ODM_WM_G) ||
158 (wirelessmode == ODM_WM_A))) {
159 EDCA_BE_DL = 0xa630;
160 } else if (iot_peer == HT_IOT_PEER_MARVELL) {
161 EDCA_BE_DL = edca_setting_DL[iot_peer];
162 EDCA_BE_UL = edca_setting_UL[iot_peer];
163 } else if (iot_peer == HT_IOT_PEER_ATHEROS) {
164
165 EDCA_BE_DL = edca_setting_DL[iot_peer];
166 }
167
168 if (trafficIndex == DOWN_LINK)
169 edca_param = EDCA_BE_DL;
170 else
171 edca_param = EDCA_BE_UL;
172
173 rtw_write32(Adapter, REG_EDCA_BE_PARAM, edca_param);
174
175 pDM_Odm->DM_EDCA_Table.prv_traffic_idx = trafficIndex;
176
177 pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = true;
178 } else {
179
180
181 if (pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA) {
182 rtw_write32(Adapter, REG_EDCA_BE_PARAM, pHalData->AcParam_BE);
183 pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = false;
184 }
185 }
186}
187