net: wireless: rockchip_wlan: add rtl8723cs support
[firefly-linux-kernel-4.4.55.git] / drivers / net / wireless / rockchip_wlan / rtl8723cs / hal / hal_dm.c
1 /******************************************************************************
2  *
3  * Copyright(c) 2014 Realtek Corporation. All rights reserved.
4  *
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.
8  *
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
12  * more details.
13  *
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
17  *
18  *
19  ******************************************************************************/
20
21 #include <drv_types.h>
22 #include <hal_data.h>
23
24 /* A mapping from HalData to ODM. */
25 enum odm_board_type_e boardType(u8 InterfaceSel)
26 {
27         enum odm_board_type_e        board      = ODM_BOARD_DEFAULT;
28
29 #ifdef CONFIG_PCI_HCI
30         INTERFACE_SELECT_PCIE   pcie    = (INTERFACE_SELECT_PCIE)InterfaceSel;
31         switch (pcie) {
32         case INTF_SEL0_SOLO_MINICARD:
33                 board |= ODM_BOARD_MINICARD;
34                 break;
35         case INTF_SEL1_BT_COMBO_MINICARD:
36                 board |= ODM_BOARD_BT;
37                 board |= ODM_BOARD_MINICARD;
38                 break;
39         default:
40                 board = ODM_BOARD_DEFAULT;
41                 break;
42         }
43
44 #elif defined(CONFIG_USB_HCI)
45         INTERFACE_SELECT_USB    usb     = (INTERFACE_SELECT_USB)InterfaceSel;
46         switch (usb) {
47         case INTF_SEL1_USB_High_Power:
48                 board |= ODM_BOARD_EXT_LNA;
49                 board |= ODM_BOARD_EXT_PA;
50                 break;
51         case INTF_SEL2_MINICARD:
52                 board |= ODM_BOARD_MINICARD;
53                 break;
54         case INTF_SEL4_USB_Combo:
55                 board |= ODM_BOARD_BT;
56                 break;
57         case INTF_SEL5_USB_Combo_MF:
58                 board |= ODM_BOARD_BT;
59                 break;
60         case INTF_SEL0_USB:
61         case INTF_SEL3_USB_Solo:
62         default:
63                 board = ODM_BOARD_DEFAULT;
64                 break;
65         }
66
67 #endif
68         /* RTW_INFO("===> boardType(): (pHalData->InterfaceSel, pDM_Odm->BoardType) = (%d, %d)\n", InterfaceSel, board); */
69
70         return board;
71 }
72
73 void Init_ODM_ComInfo(_adapter *adapter)
74 {
75         struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
76         PHAL_DATA_TYPE  pHalData = GET_HAL_DATA(adapter);
77         struct PHY_DM_STRUCT            *pDM_Odm = &(pHalData->odmpriv);
78         struct mlme_ext_priv    *pmlmeext = &adapter->mlmeextpriv;
79         struct mlme_priv        *pmlmepriv = &adapter->mlmepriv;
80         struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
81         int i;
82
83         _rtw_memset(pDM_Odm, 0, sizeof(*pDM_Odm));
84
85         pDM_Odm->adapter = adapter;
86
87         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_PLATFORM, ODM_CE);
88
89         rtw_odm_init_ic_type(adapter);
90
91         if (rtw_get_intf_type(adapter) == RTW_GSPI)
92                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_INTERFACE, ODM_ITRF_SDIO);
93         else
94                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_INTERFACE, rtw_get_intf_type(adapter));
95
96         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_MP_TEST_CHIP, IS_NORMAL_CHIP(pHalData->version_id));
97
98         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_PATCH_ID, pHalData->CustomerID);
99
100         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BWIFI_TEST, adapter->registrypriv.wifi_spec);
101
102
103         if (pHalData->rf_type == RF_1T1R)
104                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_1T1R);
105         else if (pHalData->rf_type == RF_1T2R)
106                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_1T2R);
107         else if (pHalData->rf_type == RF_2T2R)
108                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T2R);
109         else if (pHalData->rf_type == RF_2T2R_GREEN)
110                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T2R_GREEN);
111         else if (pHalData->rf_type == RF_2T3R)
112                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T3R);
113         else if (pHalData->rf_type == RF_2T4R)
114                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T4R);
115         else if (pHalData->rf_type == RF_3T3R)
116                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_3T3R);
117         else if (pHalData->rf_type == RF_3T4R)
118                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_3T4R);
119         else if (pHalData->rf_type == RF_4T4R)
120                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_4T4R);
121         else
122                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_XTXR);
123
124
125         {
126                 /* 1 ======= BoardType: ODM_CMNINFO_BOARD_TYPE ======= */
127                 u8 odm_board_type = ODM_BOARD_DEFAULT;
128
129                 if (pHalData->ExternalLNA_2G != 0) {
130                         odm_board_type |= ODM_BOARD_EXT_LNA;
131                         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_LNA, 1);
132                 }
133                 if (pHalData->external_lna_5g != 0) {
134                         odm_board_type |= ODM_BOARD_EXT_LNA_5G;
135                         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_5G_EXT_LNA, 1);
136                 }
137                 if (pHalData->ExternalPA_2G != 0) {
138                         odm_board_type |= ODM_BOARD_EXT_PA;
139                         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_PA, 1);
140                 }
141                 if (pHalData->external_pa_5g != 0) {
142                         odm_board_type |= ODM_BOARD_EXT_PA_5G;
143                         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_5G_EXT_PA, 1);
144                 }
145                 if (pHalData->EEPROMBluetoothCoexist)
146                         odm_board_type |= ODM_BOARD_BT;
147
148                 odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BOARD_TYPE, odm_board_type);
149                 /* 1 ============== End of BoardType ============== */
150         }
151
152         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_DOMAIN_CODE_2G, pHalData->Regulation2_4G);
153         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_DOMAIN_CODE_5G, pHalData->Regulation5G);
154
155 #ifdef CONFIG_DFS_MASTER
156         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_DFS_REGION_DOMAIN, adapter->registrypriv.dfs_region_domain);
157         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_DFS_MASTER_ENABLE, &(adapter_to_rfctl(adapter)->dfs_master_enabled));
158 #endif
159
160         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_GPA, pHalData->TypeGPA);
161         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_APA, pHalData->TypeAPA);
162         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_GLNA, pHalData->TypeGLNA);
163         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_ALNA, pHalData->TypeALNA);
164
165         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RFE_TYPE, pHalData->rfe_type);
166
167         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_TRSW, 0);
168
169         /*Add by YuChen for kfree init*/
170         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_REGRFKFREEENABLE, adapter->registrypriv.RegPwrTrimEnable);
171         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RFKFREEENABLE, pHalData->RfKFreeEnable);
172
173         /*Antenna diversity relative parameters*/
174         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ANT_DIV, &(pHalData->AntDivCfg));
175         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_ANTENNA_TYPE, pHalData->TRxAntDivType);
176         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BE_FIX_TX_ANT, pHalData->b_fix_tx_ant);
177         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH, pHalData->with_extenal_ant_switch);
178
179         /*Add by YuChen for adaptivity init*/
180         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ADAPTIVITY, &(adapter->registrypriv.adaptivity_en));
181         phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE, (adapter->registrypriv.adaptivity_mode != 0) ? TRUE : FALSE);
182         phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_DCBACKOFF, adapter->registrypriv.adaptivity_dc_backoff);
183         phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY, (adapter->registrypriv.adaptivity_dml != 0) ? TRUE : FALSE);
184         phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_L2H_INI, adapter->registrypriv.adaptivity_th_l2h_ini);
185         phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF, adapter->registrypriv.adaptivity_th_edcca_hl_diff);
186
187 #ifdef CONFIG_IQK_PA_OFF
188         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_IQKPAOFF, 1);
189 #endif
190         odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_IQKFWOFFLOAD, pHalData->RegIQKFWOffload);
191
192         /* Pointer reference */
193         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_TX_UNI, &(dvobj->traffic_stat.tx_bytes));
194         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RX_UNI, &(dvobj->traffic_stat.rx_bytes));
195         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_WM_MODE, &(pmlmeext->cur_wireless_mode));
196         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BAND, &(pHalData->current_band_type));
197         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_FORCED_RATE, &(pHalData->ForcedDataRate));
198         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_FORCED_IGI_LB, &(pHalData->u1ForcedIgiLb));
199
200         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SEC_CHNL_OFFSET, &(pHalData->nCur40MhzPrimeSC));
201         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SEC_MODE, &(adapter->securitypriv.dot11PrivacyAlgrthm));
202         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BW, &(pHalData->current_channel_bw));
203         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_CHNL, &(pHalData->current_channel));
204         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_NET_CLOSED, &(adapter->net_closed));
205         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_FORCED_IGI_LB, &(pHalData->u1ForcedIgiLb));
206
207         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SCAN, &(pmlmepriv->bScanInProcess));
208         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_POWER_SAVING, &(pwrctl->bpower_saving));
209         /*Add by Yuchen for phydm beamforming*/
210         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_TX_TP, &(dvobj->traffic_stat.cur_tx_tp));
211         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RX_TP, &(dvobj->traffic_stat.cur_rx_tp));
212         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ANT_TEST, &(pHalData->antenna_test));
213 #ifdef CONFIG_USB_HCI
214         odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_HUBUSBMODE, &(dvobj->usb_speed));
215 #endif
216         for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
217                 odm_cmn_info_ptr_array_hook(pDM_Odm, ODM_CMNINFO_STA_STATUS, i, NULL);
218
219         phydm_init_debug_setting(pDM_Odm);
220
221         /* TODO */
222         /* odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BT_OPERATION, _FALSE); */
223         /* odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BT_DISABLE_EDCA, _FALSE); */
224 }