mirror of
https://github.com/Mange/rtl8192eu-linux-driver
synced 2024-11-21 21:15:01 +00:00
The official RTL8192EU linux driver from D-Link Australia
Version information: 20140812_rtl8192EU_linux_v4.3.1.1_11320 2014-08-12 version 4.3.1.1_11320 Source: ftp://files.dlink.com.au/products/DWA-131/REV_E/Drivers/DWA-131_Linux_driver_v4.3.1.1.zip This version does not currently work on newer kernels, but it does contain USB ID 2001:3319, which a lot of other repos in GitHub does not.
This commit is contained in:
commit
1387cf623d
6
Kconfig
Normal file
6
Kconfig
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
config RTL8192EU
|
||||||
|
tristate "Realtek 8192E USB WiFi"
|
||||||
|
depends on USB
|
||||||
|
---help---
|
||||||
|
Help message of RTL8192EU
|
||||||
|
|
5
clean
Normal file
5
clean
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
rmmod 8192cu
|
||||||
|
rmmod 8192ce
|
||||||
|
rmmod 8192du
|
||||||
|
rmmod 8192de
|
1436
core/efuse/rtw_efuse.c
Normal file
1436
core/efuse/rtw_efuse.c
Normal file
File diff suppressed because it is too large
Load Diff
3476
core/rtw_ap.c
Normal file
3476
core/rtw_ap.c
Normal file
File diff suppressed because it is too large
Load Diff
1010
core/rtw_beamforming.c
Normal file
1010
core/rtw_beamforming.c
Normal file
File diff suppressed because it is too large
Load Diff
1698
core/rtw_br_ext.c
Normal file
1698
core/rtw_br_ext.c
Normal file
File diff suppressed because it is too large
Load Diff
1779
core/rtw_bt_mp.c
Normal file
1779
core/rtw_bt_mp.c
Normal file
File diff suppressed because it is too large
Load Diff
338
core/rtw_btcoex.c
Normal file
338
core/rtw_btcoex.c
Normal file
@ -0,0 +1,338 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2013 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifdef CONFIG_BT_COEXIST
|
||||||
|
|
||||||
|
#include <rtw_btcoex.h>
|
||||||
|
#include <hal_btcoex.h>
|
||||||
|
|
||||||
|
|
||||||
|
void rtw_btcoex_Initialize(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
hal_btcoex_Initialize(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_HAL_Initialize(PADAPTER padapter, u8 bWifiOnly)
|
||||||
|
{
|
||||||
|
hal_btcoex_InitHwConfig(padapter, bWifiOnly);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_IpsNotify(PADAPTER padapter, u8 type)
|
||||||
|
{
|
||||||
|
hal_btcoex_IpsNotify(padapter, type);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_LpsNotify(PADAPTER padapter, u8 type)
|
||||||
|
{
|
||||||
|
hal_btcoex_LpsNotify(padapter, type);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_ScanNotify(PADAPTER padapter, u8 type)
|
||||||
|
{
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
if ((_FALSE == type) && (padapter->pbuddy_adapter))
|
||||||
|
{
|
||||||
|
PADAPTER pbuddy = padapter->pbuddy_adapter;
|
||||||
|
if (check_fwstate(&pbuddy->mlmepriv, WIFI_SITE_MONITOR) == _TRUE)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
hal_btcoex_ScanNotify(padapter, type);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_ConnectNotify(PADAPTER padapter, u8 action)
|
||||||
|
{
|
||||||
|
#ifdef DBG_CONFIG_ERROR_RESET
|
||||||
|
if (_TRUE == rtw_hal_sreset_inprogress(padapter))
|
||||||
|
{
|
||||||
|
DBG_8192C(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
|
||||||
|
FUNC_ADPT_ARG(padapter));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif // DBG_CONFIG_ERROR_RESET
|
||||||
|
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
if ((_FALSE == action) && (padapter->pbuddy_adapter))
|
||||||
|
{
|
||||||
|
PADAPTER pbuddy = padapter->pbuddy_adapter;
|
||||||
|
if (check_fwstate(&pbuddy->mlmepriv, WIFI_UNDER_LINKING) == _TRUE)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
hal_btcoex_ConnectNotify(padapter, action);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus)
|
||||||
|
{
|
||||||
|
#ifdef DBG_CONFIG_ERROR_RESET
|
||||||
|
if (_TRUE == rtw_hal_sreset_inprogress(padapter))
|
||||||
|
{
|
||||||
|
DBG_8192C(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
|
||||||
|
FUNC_ADPT_ARG(padapter));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif // DBG_CONFIG_ERROR_RESET
|
||||||
|
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
if ((RT_MEDIA_DISCONNECT == mediaStatus) && (padapter->pbuddy_adapter))
|
||||||
|
{
|
||||||
|
PADAPTER pbuddy = padapter->pbuddy_adapter;
|
||||||
|
if (check_fwstate(&pbuddy->mlmepriv, WIFI_ASOC_STATE) == _TRUE)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif // CONFIG_CONCURRENT_MODE
|
||||||
|
|
||||||
|
if ((RT_MEDIA_CONNECT == mediaStatus)
|
||||||
|
&& (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE))
|
||||||
|
{
|
||||||
|
rtw_hal_set_hwreg(padapter, HW_VAR_DL_RSVD_PAGE, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
hal_btcoex_MediaStatusNotify(padapter, mediaStatus);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SpecialPacketNotify(PADAPTER padapter, u8 pktType)
|
||||||
|
{
|
||||||
|
hal_btcoex_SpecialPacketNotify(padapter, pktType);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_IQKNotify(PADAPTER padapter, u8 state)
|
||||||
|
{
|
||||||
|
hal_btcoex_IQKNotify(padapter, state);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
|
||||||
|
{
|
||||||
|
hal_btcoex_BtInfoNotify(padapter, length, tmpBuf);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SuspendNotify(PADAPTER padapter, u8 state)
|
||||||
|
{
|
||||||
|
hal_btcoex_SuspendNotify(padapter, state);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_HaltNotify(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
if (_FALSE == padapter->bup)
|
||||||
|
{
|
||||||
|
DBG_871X(FUNC_ADPT_FMT ": bup=%d Skip!\n",
|
||||||
|
FUNC_ADPT_ARG(padapter), padapter->bup);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_TRUE == padapter->bSurpriseRemoved)
|
||||||
|
{
|
||||||
|
DBG_871X(FUNC_ADPT_FMT ": bSurpriseRemoved=%d Skip!\n",
|
||||||
|
FUNC_ADPT_ARG(padapter), padapter->bSurpriseRemoved);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
hal_btcoex_HaltNotify(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SwitchBtTRxMask(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
hal_btcoex_SwitchBtTRxMask(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_Switch(PADAPTER padapter, u8 enable)
|
||||||
|
{
|
||||||
|
hal_btcoex_SetBTCoexist(padapter, enable);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_IsBtDisabled(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_IsBtDisabled(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_Handler(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
#if defined(CONFIG_CONCURRENT_MODE)
|
||||||
|
if (padapter->adapter_type != PRIMARY_ADAPTER)
|
||||||
|
return;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
hal_btcoex_Hanlder(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
s32 rtw_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
s32 coexctrl;
|
||||||
|
|
||||||
|
coexctrl = hal_btcoex_IsBTCoexCtrlAMPDUSize(padapter);
|
||||||
|
|
||||||
|
return coexctrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 rtw_btcoex_GetAMPDUSize(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
u32 size;
|
||||||
|
|
||||||
|
size = hal_btcoex_GetAMPDUSize(padapter);
|
||||||
|
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SetManualControl(PADAPTER padapter, u8 manual)
|
||||||
|
{
|
||||||
|
if (_TRUE == manual)
|
||||||
|
{
|
||||||
|
hal_btcoex_SetManualControl(padapter, _TRUE);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hal_btcoex_SetManualControl(padapter, _FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_1Ant(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_1Ant(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_IsBtControlLps(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_IsBtControlLps(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_IsLpsOn(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_IsLpsOn(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_RpwmVal(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_RpwmVal(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_LpsVal(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_LpsVal(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SetBTCoexist(PADAPTER padapter, u8 bBtExist)
|
||||||
|
{
|
||||||
|
hal_btcoex_SetBTCoexist(padapter, bBtExist);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SetChipType(PADAPTER padapter, u8 chipType)
|
||||||
|
{
|
||||||
|
hal_btcoex_SetChipType(padapter, chipType);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SetPGAntNum(PADAPTER padapter, u8 antNum, u8 antInverse)
|
||||||
|
{
|
||||||
|
hal_btcoex_SetPgAntNum(padapter, antNum, antInverse);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_GetPGAntNum(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_GetPgAntNum(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 rtw_btcoex_GetRaMask(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_GetRaMask(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_RecordPwrMode(PADAPTER padapter, u8 *pCmdBuf, u8 cmdLen)
|
||||||
|
{
|
||||||
|
hal_btcoex_RecordPwrMode(padapter, pCmdBuf, cmdLen);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_DisplayBtCoexInfo(PADAPTER padapter, u8 *pbuf, u32 bufsize)
|
||||||
|
{
|
||||||
|
hal_btcoex_DisplayBtCoexInfo(padapter, pbuf, bufsize);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_SetDBG(PADAPTER padapter, u32 *pDbgModule)
|
||||||
|
{
|
||||||
|
hal_btcoex_SetDBG(padapter, pDbgModule);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 rtw_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)
|
||||||
|
{
|
||||||
|
return hal_btcoex_GetDBG(padapter, pStrBuf, bufSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_IncreaseScanDeviceNum(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_IncreaseScanDeviceNum(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_btcoex_IsBtLinkExist(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
return hal_btcoex_IsBtLinkExist(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ==================================================
|
||||||
|
// Below Functions are called by BT-Coex
|
||||||
|
// ==================================================
|
||||||
|
void rtw_btcoex_RejectApAggregatedPacket(PADAPTER padapter, u8 enable)
|
||||||
|
{
|
||||||
|
struct mlme_ext_info *pmlmeinfo;
|
||||||
|
struct sta_info *psta;
|
||||||
|
|
||||||
|
pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
|
||||||
|
psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
|
||||||
|
|
||||||
|
if (_TRUE == enable)
|
||||||
|
{
|
||||||
|
pmlmeinfo->bAcceptAddbaReq = _FALSE;
|
||||||
|
send_delba(padapter, 0, psta->hwaddr);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pmlmeinfo->bAcceptAddbaReq = _TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_LPS_Enter(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
struct pwrctrl_priv *pwrpriv;
|
||||||
|
u8 lpsVal;
|
||||||
|
|
||||||
|
|
||||||
|
pwrpriv = adapter_to_pwrctl(padapter);
|
||||||
|
|
||||||
|
pwrpriv->bpower_saving = _TRUE;
|
||||||
|
lpsVal = rtw_btcoex_LpsVal(padapter);
|
||||||
|
rtw_set_ps_mode(padapter, PS_MODE_MIN, 0, lpsVal, "BTCOEX");
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_btcoex_LPS_Leave(PADAPTER padapter)
|
||||||
|
{
|
||||||
|
struct pwrctrl_priv *pwrpriv;
|
||||||
|
|
||||||
|
|
||||||
|
pwrpriv = adapter_to_pwrctl(padapter);
|
||||||
|
|
||||||
|
if (pwrpriv->pwr_mode != PS_MODE_ACTIVE)
|
||||||
|
{
|
||||||
|
rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "BTCOEX");
|
||||||
|
LPS_RF_ON_check(padapter, 100);
|
||||||
|
pwrpriv->bpower_saving = _FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif // CONFIG_BT_COEXIST
|
||||||
|
|
3647
core/rtw_cmd.c
Normal file
3647
core/rtw_cmd.c
Normal file
File diff suppressed because it is too large
Load Diff
1390
core/rtw_debug.c
Normal file
1390
core/rtw_debug.c
Normal file
File diff suppressed because it is too large
Load Diff
423
core/rtw_eeprom.c
Normal file
423
core/rtw_eeprom.c
Normal file
@ -0,0 +1,423 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#define _RTW_EEPROM_C_
|
||||||
|
|
||||||
|
#include <drv_conf.h>
|
||||||
|
#include <osdep_service.h>
|
||||||
|
#include <drv_types.h>
|
||||||
|
|
||||||
|
void up_clk(_adapter* padapter, u16 *x)
|
||||||
|
{
|
||||||
|
_func_enter_;
|
||||||
|
*x = *x | _EESK;
|
||||||
|
rtw_write8(padapter, EE_9346CR, (u8)*x);
|
||||||
|
rtw_udelay_os(CLOCK_RATE);
|
||||||
|
|
||||||
|
_func_exit_;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void down_clk(_adapter * padapter, u16 *x )
|
||||||
|
{
|
||||||
|
_func_enter_;
|
||||||
|
*x = *x & ~_EESK;
|
||||||
|
rtw_write8(padapter, EE_9346CR, (u8)*x);
|
||||||
|
rtw_udelay_os(CLOCK_RATE);
|
||||||
|
_func_exit_;
|
||||||
|
}
|
||||||
|
|
||||||
|
void shift_out_bits(_adapter * padapter, u16 data, u16 count)
|
||||||
|
{
|
||||||
|
u16 x,mask;
|
||||||
|
_func_enter_;
|
||||||
|
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
mask = 0x01 << (count - 1);
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
|
||||||
|
x &= ~(_EEDO | _EEDI);
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
x &= ~_EEDI;
|
||||||
|
if(data & mask)
|
||||||
|
x |= _EEDI;
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
rtw_write8(padapter, EE_9346CR, (u8)x);
|
||||||
|
rtw_udelay_os(CLOCK_RATE);
|
||||||
|
up_clk(padapter, &x);
|
||||||
|
down_clk(padapter, &x);
|
||||||
|
mask = mask >> 1;
|
||||||
|
} while(mask);
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
x &= ~_EEDI;
|
||||||
|
rtw_write8(padapter, EE_9346CR, (u8)x);
|
||||||
|
out:
|
||||||
|
_func_exit_;
|
||||||
|
}
|
||||||
|
|
||||||
|
u16 shift_in_bits (_adapter * padapter)
|
||||||
|
{
|
||||||
|
u16 x,d=0,i;
|
||||||
|
_func_enter_;
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
|
||||||
|
x &= ~( _EEDO | _EEDI);
|
||||||
|
d = 0;
|
||||||
|
|
||||||
|
for(i=0; i<16; i++)
|
||||||
|
{
|
||||||
|
d = d << 1;
|
||||||
|
up_clk(padapter, &x);
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
|
||||||
|
x &= ~(_EEDI);
|
||||||
|
if(x & _EEDO)
|
||||||
|
d |= 1;
|
||||||
|
|
||||||
|
down_clk(padapter, &x);
|
||||||
|
}
|
||||||
|
out:
|
||||||
|
_func_exit_;
|
||||||
|
|
||||||
|
return d;
|
||||||
|
}
|
||||||
|
|
||||||
|
void standby(_adapter * padapter )
|
||||||
|
{
|
||||||
|
u8 x;
|
||||||
|
_func_enter_;
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
|
||||||
|
x &= ~(_EECS | _EESK);
|
||||||
|
rtw_write8(padapter, EE_9346CR,x);
|
||||||
|
|
||||||
|
rtw_udelay_os(CLOCK_RATE);
|
||||||
|
x |= _EECS;
|
||||||
|
rtw_write8(padapter, EE_9346CR, x);
|
||||||
|
rtw_udelay_os(CLOCK_RATE);
|
||||||
|
_func_exit_;
|
||||||
|
}
|
||||||
|
|
||||||
|
u16 wait_eeprom_cmd_done(_adapter* padapter)
|
||||||
|
{
|
||||||
|
u8 x;
|
||||||
|
u16 i,res=_FALSE;
|
||||||
|
_func_enter_;
|
||||||
|
standby(padapter );
|
||||||
|
for (i=0; i<200; i++)
|
||||||
|
{
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
if (x & _EEDO){
|
||||||
|
res=_TRUE;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
rtw_udelay_os(CLOCK_RATE);
|
||||||
|
}
|
||||||
|
exit:
|
||||||
|
_func_exit_;
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
void eeprom_clean(_adapter * padapter)
|
||||||
|
{
|
||||||
|
u16 x;
|
||||||
|
_func_enter_;
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
x &= ~(_EECS | _EEDI);
|
||||||
|
rtw_write8(padapter, EE_9346CR, (u8)x);
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
up_clk(padapter, &x);
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
down_clk(padapter, &x);
|
||||||
|
out:
|
||||||
|
_func_exit_;
|
||||||
|
}
|
||||||
|
|
||||||
|
void eeprom_write16(_adapter * padapter, u16 reg, u16 data)
|
||||||
|
{
|
||||||
|
u8 x;
|
||||||
|
#ifdef CONFIG_RTL8712
|
||||||
|
u8 tmp8_ori,tmp8_new,tmp8_clk_ori,tmp8_clk_new;
|
||||||
|
tmp8_ori=rtw_read8(padapter, 0x102502f1);
|
||||||
|
tmp8_new=tmp8_ori & 0xf7;
|
||||||
|
if(tmp8_ori != tmp8_new){
|
||||||
|
rtw_write8(padapter, 0x102502f1, tmp8_new);
|
||||||
|
RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x102502f1=====\n"));
|
||||||
|
}
|
||||||
|
tmp8_clk_ori=rtw_read8(padapter,0x10250003);
|
||||||
|
tmp8_clk_new=tmp8_clk_ori|0x20;
|
||||||
|
if(tmp8_clk_new!=tmp8_clk_ori){
|
||||||
|
RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x10250003=====\n"));
|
||||||
|
rtw_write8(padapter, 0x10250003, tmp8_clk_new);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
_func_enter_;
|
||||||
|
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
|
||||||
|
x &= ~(_EEDI | _EEDO | _EESK | _EEM0);
|
||||||
|
x |= _EEM1 | _EECS;
|
||||||
|
rtw_write8(padapter, EE_9346CR, x);
|
||||||
|
|
||||||
|
shift_out_bits(padapter, EEPROM_EWEN_OPCODE, 5);
|
||||||
|
|
||||||
|
if(padapter->EepromAddressSize==8) //CF+ and SDIO
|
||||||
|
shift_out_bits(padapter, 0, 6);
|
||||||
|
else //USB
|
||||||
|
shift_out_bits(padapter, 0, 4);
|
||||||
|
|
||||||
|
standby( padapter);
|
||||||
|
|
||||||
|
// Commented out by rcnjko, 2004.0
|
||||||
|
// // Erase this particular word. Write the erase opcode and register
|
||||||
|
// // number in that order. The opcode is 3bits in length; reg is 6 bits long.
|
||||||
|
// shift_out_bits(Adapter, EEPROM_ERASE_OPCODE, 3);
|
||||||
|
// shift_out_bits(Adapter, reg, Adapter->EepromAddressSize);
|
||||||
|
//
|
||||||
|
// if (wait_eeprom_cmd_done(Adapter ) == FALSE)
|
||||||
|
// {
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
|
|
||||||
|
standby(padapter );
|
||||||
|
|
||||||
|
// write the new word to the EEPROM
|
||||||
|
|
||||||
|
// send the write opcode the EEPORM
|
||||||
|
shift_out_bits(padapter, EEPROM_WRITE_OPCODE, 3);
|
||||||
|
|
||||||
|
// select which word in the EEPROM that we are writing to.
|
||||||
|
shift_out_bits(padapter, reg, padapter->EepromAddressSize);
|
||||||
|
|
||||||
|
// write the data to the selected EEPROM word.
|
||||||
|
shift_out_bits(padapter, data, 16);
|
||||||
|
|
||||||
|
if (wait_eeprom_cmd_done(padapter ) == _FALSE)
|
||||||
|
{
|
||||||
|
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
standby(padapter );
|
||||||
|
|
||||||
|
shift_out_bits(padapter, EEPROM_EWDS_OPCODE, 5);
|
||||||
|
shift_out_bits(padapter, reg, 4);
|
||||||
|
|
||||||
|
eeprom_clean(padapter );
|
||||||
|
exit:
|
||||||
|
#ifdef CONFIG_RTL8712
|
||||||
|
if(tmp8_clk_new!=tmp8_clk_ori)
|
||||||
|
rtw_write8(padapter, 0x10250003, tmp8_clk_ori);
|
||||||
|
if(tmp8_new!=tmp8_ori)
|
||||||
|
rtw_write8(padapter, 0x102502f1, tmp8_ori);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
_func_exit_;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
u16 eeprom_read16(_adapter * padapter, u16 reg) //ReadEEprom
|
||||||
|
{
|
||||||
|
|
||||||
|
u16 x;
|
||||||
|
u16 data=0;
|
||||||
|
#ifdef CONFIG_RTL8712
|
||||||
|
u8 tmp8_ori,tmp8_new,tmp8_clk_ori,tmp8_clk_new;
|
||||||
|
tmp8_ori= rtw_read8(padapter, 0x102502f1);
|
||||||
|
tmp8_new = tmp8_ori & 0xf7;
|
||||||
|
if(tmp8_ori != tmp8_new){
|
||||||
|
rtw_write8(padapter, 0x102502f1, tmp8_new);
|
||||||
|
RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x102502f1=====\n"));
|
||||||
|
}
|
||||||
|
tmp8_clk_ori=rtw_read8(padapter,0x10250003);
|
||||||
|
tmp8_clk_new=tmp8_clk_ori|0x20;
|
||||||
|
if(tmp8_clk_new!=tmp8_clk_ori){
|
||||||
|
RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x10250003=====\n"));
|
||||||
|
rtw_write8(padapter, 0x10250003, tmp8_clk_new);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
_func_enter_;
|
||||||
|
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
// select EEPROM, reset bits, set _EECS
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
x &= ~(_EEDI | _EEDO | _EESK | _EEM0);
|
||||||
|
x |= _EEM1 | _EECS;
|
||||||
|
rtw_write8(padapter, EE_9346CR, (unsigned char)x);
|
||||||
|
|
||||||
|
// write the read opcode and register number in that order
|
||||||
|
// The opcode is 3bits in length, reg is 6 bits long
|
||||||
|
shift_out_bits(padapter, EEPROM_READ_OPCODE, 3);
|
||||||
|
shift_out_bits(padapter, reg, padapter->EepromAddressSize);
|
||||||
|
|
||||||
|
// Now read the data (16 bits) in from the selected EEPROM word
|
||||||
|
data = shift_in_bits(padapter);
|
||||||
|
|
||||||
|
eeprom_clean(padapter);
|
||||||
|
out:
|
||||||
|
#ifdef CONFIG_RTL8712
|
||||||
|
if(tmp8_clk_new!=tmp8_clk_ori)
|
||||||
|
rtw_write8(padapter, 0x10250003, tmp8_clk_ori);
|
||||||
|
if(tmp8_new!=tmp8_ori)
|
||||||
|
rtw_write8(padapter, 0x102502f1, tmp8_ori);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
_func_exit_;
|
||||||
|
return data;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//From even offset
|
||||||
|
void eeprom_read_sz(_adapter * padapter, u16 reg, u8* data, u32 sz)
|
||||||
|
{
|
||||||
|
|
||||||
|
u16 x, data16;
|
||||||
|
u32 i;
|
||||||
|
_func_enter_;
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
// select EEPROM, reset bits, set _EECS
|
||||||
|
x = rtw_read8(padapter, EE_9346CR);
|
||||||
|
|
||||||
|
if(padapter->bSurpriseRemoved==_TRUE){
|
||||||
|
RT_TRACE(_module_rtl871x_eeprom_c_,_drv_err_,("padapter->bSurpriseRemoved==_TRUE"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
x &= ~(_EEDI | _EEDO | _EESK | _EEM0);
|
||||||
|
x |= _EEM1 | _EECS;
|
||||||
|
rtw_write8(padapter, EE_9346CR, (unsigned char)x);
|
||||||
|
|
||||||
|
// write the read opcode and register number in that order
|
||||||
|
// The opcode is 3bits in length, reg is 6 bits long
|
||||||
|
shift_out_bits(padapter, EEPROM_READ_OPCODE, 3);
|
||||||
|
shift_out_bits(padapter, reg, padapter->EepromAddressSize);
|
||||||
|
|
||||||
|
|
||||||
|
for(i=0; i<sz; i+=2)
|
||||||
|
{
|
||||||
|
data16 = shift_in_bits(padapter);
|
||||||
|
data[i] = data16 & 0xff;
|
||||||
|
data[i+1] = data16 >>8;
|
||||||
|
}
|
||||||
|
|
||||||
|
eeprom_clean(padapter);
|
||||||
|
out:
|
||||||
|
_func_exit_;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//addr_off : address offset of the entry in eeprom (not the tuple number of eeprom (reg); that is addr_off !=reg)
|
||||||
|
u8 eeprom_read(_adapter * padapter, u32 addr_off, u8 sz, u8* rbuf)
|
||||||
|
{
|
||||||
|
u8 quotient, remainder, addr_2align_odd;
|
||||||
|
u16 reg, stmp , i=0, idx = 0;
|
||||||
|
_func_enter_;
|
||||||
|
reg = (u16)(addr_off >> 1);
|
||||||
|
addr_2align_odd = (u8)(addr_off & 0x1);
|
||||||
|
|
||||||
|
if(addr_2align_odd) //read that start at high part: e.g 1,3,5,7,9,...
|
||||||
|
{
|
||||||
|
stmp = eeprom_read16(padapter, reg);
|
||||||
|
rbuf[idx++] = (u8) ((stmp>>8)&0xff); //return hogh-part of the short
|
||||||
|
reg++; sz--;
|
||||||
|
}
|
||||||
|
|
||||||
|
quotient = sz >> 1;
|
||||||
|
remainder = sz & 0x1;
|
||||||
|
|
||||||
|
for( i=0 ; i < quotient; i++)
|
||||||
|
{
|
||||||
|
stmp = eeprom_read16(padapter, reg+i);
|
||||||
|
rbuf[idx++] = (u8) (stmp&0xff);
|
||||||
|
rbuf[idx++] = (u8) ((stmp>>8)&0xff);
|
||||||
|
}
|
||||||
|
|
||||||
|
reg = reg+i;
|
||||||
|
if(remainder){ //end of read at lower part of short : 0,2,4,6,...
|
||||||
|
stmp = eeprom_read16(padapter, reg);
|
||||||
|
rbuf[idx] = (u8)(stmp & 0xff);
|
||||||
|
}
|
||||||
|
_func_exit_;
|
||||||
|
return _TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
VOID read_eeprom_content(_adapter * padapter)
|
||||||
|
{
|
||||||
|
|
||||||
|
_func_enter_;
|
||||||
|
|
||||||
|
|
||||||
|
_func_exit_;
|
||||||
|
}
|
||||||
|
|
2220
core/rtw_ieee80211.c
Normal file
2220
core/rtw_ieee80211.c
Normal file
File diff suppressed because it is too large
Load Diff
513
core/rtw_io.c
Normal file
513
core/rtw_io.c
Normal file
File diff suppressed because it is too large
Load Diff
192
core/rtw_ioctl_query.c
Normal file
192
core/rtw_ioctl_query.c
Normal file
@ -0,0 +1,192 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#define _RTW_IOCTL_QUERY_C_
|
||||||
|
|
||||||
|
#include <drv_types.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef PLATFORM_WINDOWS
|
||||||
|
//
|
||||||
|
// Added for WPA2-PSK, by Annie, 2005-09-20.
|
||||||
|
//
|
||||||
|
u8
|
||||||
|
query_802_11_capability(
|
||||||
|
_adapter* Adapter,
|
||||||
|
u8* pucBuf,
|
||||||
|
u32 * pulOutLen
|
||||||
|
)
|
||||||
|
{
|
||||||
|
static NDIS_802_11_AUTHENTICATION_ENCRYPTION szAuthEnc[] =
|
||||||
|
{
|
||||||
|
{Ndis802_11AuthModeOpen, Ndis802_11EncryptionDisabled},
|
||||||
|
{Ndis802_11AuthModeOpen, Ndis802_11Encryption1Enabled},
|
||||||
|
{Ndis802_11AuthModeShared, Ndis802_11EncryptionDisabled},
|
||||||
|
{Ndis802_11AuthModeShared, Ndis802_11Encryption1Enabled},
|
||||||
|
{Ndis802_11AuthModeWPA, Ndis802_11Encryption2Enabled},
|
||||||
|
{Ndis802_11AuthModeWPA, Ndis802_11Encryption3Enabled},
|
||||||
|
{Ndis802_11AuthModeWPAPSK, Ndis802_11Encryption2Enabled},
|
||||||
|
{Ndis802_11AuthModeWPAPSK, Ndis802_11Encryption3Enabled},
|
||||||
|
{Ndis802_11AuthModeWPANone, Ndis802_11Encryption2Enabled},
|
||||||
|
{Ndis802_11AuthModeWPANone, Ndis802_11Encryption3Enabled},
|
||||||
|
{Ndis802_11AuthModeWPA2, Ndis802_11Encryption2Enabled},
|
||||||
|
{Ndis802_11AuthModeWPA2, Ndis802_11Encryption3Enabled},
|
||||||
|
{Ndis802_11AuthModeWPA2PSK, Ndis802_11Encryption2Enabled},
|
||||||
|
{Ndis802_11AuthModeWPA2PSK, Ndis802_11Encryption3Enabled}
|
||||||
|
};
|
||||||
|
static ULONG ulNumOfPairSupported = sizeof(szAuthEnc)/sizeof(NDIS_802_11_AUTHENTICATION_ENCRYPTION);
|
||||||
|
NDIS_802_11_CAPABILITY * pCap = (NDIS_802_11_CAPABILITY *)pucBuf;
|
||||||
|
u8* pucAuthEncryptionSupported = (u8*) pCap->AuthenticationEncryptionSupported;
|
||||||
|
|
||||||
|
|
||||||
|
pCap->Length = sizeof(NDIS_802_11_CAPABILITY);
|
||||||
|
if(ulNumOfPairSupported > 1 )
|
||||||
|
pCap->Length += (ulNumOfPairSupported-1) * sizeof(NDIS_802_11_AUTHENTICATION_ENCRYPTION);
|
||||||
|
|
||||||
|
pCap->Version = 2;
|
||||||
|
pCap->NoOfPMKIDs = NUM_PMKID_CACHE;
|
||||||
|
pCap->NoOfAuthEncryptPairsSupported = ulNumOfPairSupported;
|
||||||
|
|
||||||
|
if( sizeof (szAuthEnc) <= 240 ) // 240 = 256 - 4*4 // SecurityInfo.szCapability: only 256 bytes in size.
|
||||||
|
{
|
||||||
|
_rtw_memcpy( pucAuthEncryptionSupported, (u8*)szAuthEnc, sizeof (szAuthEnc) );
|
||||||
|
*pulOutLen = pCap->Length;
|
||||||
|
return _TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
*pulOutLen = 0;
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("_query_802_11_capability(): szAuthEnc size is too large.\n"));
|
||||||
|
return _FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 query_802_11_association_information( _adapter *padapter,PNDIS_802_11_ASSOCIATION_INFORMATION pAssocInfo)
|
||||||
|
{
|
||||||
|
struct wlan_network *tgt_network;
|
||||||
|
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
|
||||||
|
struct security_priv *psecuritypriv=&(padapter->securitypriv);
|
||||||
|
WLAN_BSSID_EX *psecnetwork=(WLAN_BSSID_EX*)&(psecuritypriv->sec_bss);
|
||||||
|
u8 * pDest = (u8 *)pAssocInfo + sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
|
||||||
|
unsigned char i,*auth_ie,*supp_ie;
|
||||||
|
|
||||||
|
//NdisZeroMemory(pAssocInfo, sizeof(NDIS_802_11_ASSOCIATION_INFORMATION));
|
||||||
|
_rtw_memset(pAssocInfo, 0, sizeof(NDIS_802_11_ASSOCIATION_INFORMATION));
|
||||||
|
//pAssocInfo->Length = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
|
||||||
|
|
||||||
|
//------------------------------------------------------
|
||||||
|
// Association Request related information
|
||||||
|
//------------------------------------------------------
|
||||||
|
// Req_1. AvailableRequestFixedIEs
|
||||||
|
if(psecnetwork!=NULL){
|
||||||
|
|
||||||
|
pAssocInfo->AvailableRequestFixedIEs |= NDIS_802_11_AI_REQFI_CAPABILITIES|NDIS_802_11_AI_REQFI_CURRENTAPADDRESS;
|
||||||
|
pAssocInfo->RequestFixedIEs.Capabilities = (unsigned short)* & psecnetwork->IEs[10];
|
||||||
|
_rtw_memcpy(pAssocInfo->RequestFixedIEs.CurrentAPAddress,
|
||||||
|
& psecnetwork->MacAddress, 6);
|
||||||
|
|
||||||
|
pAssocInfo->OffsetRequestIEs = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
|
||||||
|
|
||||||
|
if(check_fwstate( pmlmepriv, _FW_UNDER_LINKING|_FW_LINKED)==_TRUE)
|
||||||
|
{
|
||||||
|
|
||||||
|
if(psecuritypriv->ndisauthtype>=Ndis802_11AuthModeWPA2)
|
||||||
|
pDest[0] =48; //RSN Information Element
|
||||||
|
else
|
||||||
|
pDest[0] =221; //WPA(SSN) Information Element
|
||||||
|
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n Adapter->ndisauthtype==Ndis802_11AuthModeWPA)?0xdd:0x30 [%d]",pDest[0]));
|
||||||
|
supp_ie=&psecuritypriv->supplicant_ie[0];
|
||||||
|
for(i=0;i<supp_ie[0];i++)
|
||||||
|
{
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("IEs [%d] = 0x%x \n\n", i,supp_ie[i]));
|
||||||
|
}
|
||||||
|
|
||||||
|
i=13; //0~11 is fixed information element
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("i= %d tgt_network->network.IELength=%d\n\n", i,(int)psecnetwork->IELength));
|
||||||
|
while((i<supp_ie[0]) && (i<256)){
|
||||||
|
if((unsigned char)supp_ie[i]==pDest[0]){
|
||||||
|
_rtw_memcpy((u8 *)(pDest),
|
||||||
|
&supp_ie[i],
|
||||||
|
supp_ie[1+i]+2);
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
i=i+supp_ie[i+1]+2;
|
||||||
|
if(supp_ie[1+i]==0)
|
||||||
|
i=i+1;
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("iteration i=%d IEs [%d] = 0x%x \n\n", i,i,supp_ie[i+1]));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
pAssocInfo->RequestIELength += (2 + supp_ie[1+i]);// (2 + psecnetwork->IEs[1+i]+4);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n psecnetwork != NULL,fwstate==_FW_UNDER_LINKING \n"));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//------------------------------------------------------
|
||||||
|
// Association Response related information
|
||||||
|
//------------------------------------------------------
|
||||||
|
|
||||||
|
if(check_fwstate( pmlmepriv, _FW_LINKED)==_TRUE)
|
||||||
|
{
|
||||||
|
tgt_network =&(pmlmepriv->cur_network);
|
||||||
|
if(tgt_network!=NULL){
|
||||||
|
pAssocInfo->AvailableResponseFixedIEs =
|
||||||
|
NDIS_802_11_AI_RESFI_CAPABILITIES
|
||||||
|
|NDIS_802_11_AI_RESFI_ASSOCIATIONID
|
||||||
|
;
|
||||||
|
|
||||||
|
pAssocInfo->ResponseFixedIEs.Capabilities =(unsigned short)* & tgt_network->network.IEs[10];
|
||||||
|
pAssocInfo->ResponseFixedIEs.StatusCode = 0;
|
||||||
|
pAssocInfo->ResponseFixedIEs.AssociationId =(unsigned short) tgt_network->aid;
|
||||||
|
|
||||||
|
pDest = (u8 *)pAssocInfo + sizeof(NDIS_802_11_ASSOCIATION_INFORMATION)+pAssocInfo->RequestIELength;
|
||||||
|
auth_ie=&psecuritypriv->authenticator_ie[0];
|
||||||
|
|
||||||
|
for(i=0;i<auth_ie[0];i++)
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("IEs [%d] = 0x%x \n\n", i,auth_ie[i]));
|
||||||
|
|
||||||
|
i=auth_ie[0]-12;
|
||||||
|
if(i>0){
|
||||||
|
_rtw_memcpy((u8 *)&pDest[0],&auth_ie[1],i);
|
||||||
|
pAssocInfo->ResponseIELength =i;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
pAssocInfo->OffsetResponseIEs = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION) + pAssocInfo->RequestIELength;
|
||||||
|
|
||||||
|
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n tgt_network != NULL,fwstate==_FW_LINKED \n"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n exit query_802_11_association_information \n"));
|
||||||
|
_func_exit_;
|
||||||
|
|
||||||
|
return _TRUE;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
1023
core/rtw_ioctl_rtl.c
Normal file
1023
core/rtw_ioctl_rtl.c
Normal file
File diff suppressed because it is too large
Load Diff
1483
core/rtw_ioctl_set.c
Normal file
1483
core/rtw_ioctl_set.c
Normal file
File diff suppressed because it is too large
Load Diff
390
core/rtw_iol.c
Normal file
390
core/rtw_iol.c
Normal file
@ -0,0 +1,390 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#include <drv_types.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_IOL
|
||||||
|
struct xmit_frame *rtw_IOL_accquire_xmit_frame(ADAPTER *adapter)
|
||||||
|
{
|
||||||
|
struct xmit_frame *xmit_frame;
|
||||||
|
struct xmit_buf *xmitbuf;
|
||||||
|
struct pkt_attrib *pattrib;
|
||||||
|
struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
if ((xmit_frame = rtw_alloc_xmitframe(pxmitpriv)) == NULL)
|
||||||
|
{
|
||||||
|
DBG_871X("%s rtw_alloc_xmitframe return null\n", __FUNCTION__);
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((xmitbuf = rtw_alloc_xmitbuf(pxmitpriv)) == NULL)
|
||||||
|
{
|
||||||
|
DBG_871X("%s rtw_alloc_xmitbuf return null\n", __FUNCTION__);
|
||||||
|
rtw_free_xmitframe(pxmitpriv, xmit_frame);
|
||||||
|
xmit_frame=NULL;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
xmit_frame->frame_tag = MGNT_FRAMETAG;
|
||||||
|
xmit_frame->pxmitbuf = xmitbuf;
|
||||||
|
xmit_frame->buf_addr = xmitbuf->pbuf;
|
||||||
|
xmitbuf->priv_data = xmit_frame;
|
||||||
|
|
||||||
|
pattrib = &xmit_frame->attrib;
|
||||||
|
update_mgntframe_attrib(adapter, pattrib);
|
||||||
|
pattrib->qsel = 0x10;//Beacon
|
||||||
|
pattrib->subtype = WIFI_BEACON;
|
||||||
|
pattrib->pktlen = pattrib->last_txcmdsz = 0;
|
||||||
|
|
||||||
|
#else
|
||||||
|
if ((xmit_frame = alloc_mgtxmitframe(pxmitpriv)) == NULL)
|
||||||
|
{
|
||||||
|
DBG_871X("%s alloc_mgtxmitframe return null\n", __FUNCTION__);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
pattrib = &xmit_frame->attrib;
|
||||||
|
update_mgntframe_attrib(adapter, pattrib);
|
||||||
|
pattrib->qsel = 0x10;
|
||||||
|
pattrib->pktlen = pattrib->last_txcmdsz = 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
exit:
|
||||||
|
return xmit_frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len)
|
||||||
|
{
|
||||||
|
struct pkt_attrib *pattrib = &xmit_frame->attrib;
|
||||||
|
u16 buf_offset;
|
||||||
|
u32 ori_len;
|
||||||
|
|
||||||
|
buf_offset = TXDESC_OFFSET;
|
||||||
|
ori_len = buf_offset+pattrib->pktlen;
|
||||||
|
|
||||||
|
//check if the io_buf can accommodate new cmds
|
||||||
|
if(ori_len + cmd_len + 8 > MAX_XMITBUF_SZ) {
|
||||||
|
DBG_871X("%s %u is large than MAX_XMITBUF_SZ:%u, can't accommodate new cmds\n", __FUNCTION__
|
||||||
|
, ori_len + cmd_len + 8, MAX_XMITBUF_SZ);
|
||||||
|
return _FAIL;
|
||||||
|
}
|
||||||
|
|
||||||
|
_rtw_memcpy(xmit_frame->buf_addr + buf_offset + pattrib->pktlen, IOL_cmds, cmd_len);
|
||||||
|
pattrib->pktlen += cmd_len;
|
||||||
|
pattrib->last_txcmdsz += cmd_len;
|
||||||
|
|
||||||
|
//DBG_871X("%s ori:%u + cmd_len:%u = %u\n", __FUNCTION__, ori_len, cmd_len, buf_offset+pattrib->pktlen);
|
||||||
|
|
||||||
|
return _SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool rtw_IOL_applied(ADAPTER *adapter)
|
||||||
|
{
|
||||||
|
if(1 == adapter->registrypriv.fw_iol)
|
||||||
|
return _TRUE;
|
||||||
|
|
||||||
|
#ifdef CONFIG_USB_HCI
|
||||||
|
if((2 == adapter->registrypriv.fw_iol) && (IS_FULL_SPEED_USB(adapter)))
|
||||||
|
return _TRUE;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return _FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
int rtw_IOL_exec_cmds_sync(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt)
|
||||||
|
{
|
||||||
|
return rtw_hal_iol_cmd(adapter, xmit_frame, max_wating_ms,bndy_cnt);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_IOL_NEW_GENERATION
|
||||||
|
int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary)
|
||||||
|
{
|
||||||
|
return _SUCCESS;
|
||||||
|
}
|
||||||
|
int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, u8 mask)
|
||||||
|
{
|
||||||
|
struct ioreg_cfg cmd = {8,IOREG_CMD_WB_REG,0x0, 0x0,0x0};
|
||||||
|
|
||||||
|
//RTW_PUT_LE16((u8*)&cmd.address, addr);
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);
|
||||||
|
cmd.address = cpu_to_le16(addr);
|
||||||
|
cmd.data = cpu_to_le32(value);
|
||||||
|
|
||||||
|
if(mask!=0xFF)
|
||||||
|
{
|
||||||
|
cmd.length = 12;
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);
|
||||||
|
cmd.mask = cpu_to_le32(mask);
|
||||||
|
}
|
||||||
|
|
||||||
|
//DBG_871X("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
|
||||||
|
|
||||||
|
}
|
||||||
|
int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, u16 mask)
|
||||||
|
{
|
||||||
|
struct ioreg_cfg cmd = {8,IOREG_CMD_WW_REG,0x0, 0x0,0x0};
|
||||||
|
|
||||||
|
//RTW_PUT_LE16((u8*)&cmd.address, addr);
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);
|
||||||
|
cmd.address = cpu_to_le16(addr);
|
||||||
|
cmd.data = cpu_to_le32(value);
|
||||||
|
|
||||||
|
if(mask!=0xFFFF)
|
||||||
|
{
|
||||||
|
cmd.length = 12;
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);
|
||||||
|
cmd.mask = cpu_to_le32(mask);
|
||||||
|
}
|
||||||
|
|
||||||
|
//DBG_871X("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
|
||||||
|
|
||||||
|
}
|
||||||
|
int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, u32 mask)
|
||||||
|
{
|
||||||
|
struct ioreg_cfg cmd = {8,IOREG_CMD_WD_REG,0x0, 0x0,0x0};
|
||||||
|
|
||||||
|
//RTW_PUT_LE16((u8*)&cmd.address, addr);
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);
|
||||||
|
cmd.address = cpu_to_le16(addr);
|
||||||
|
cmd.data = cpu_to_le32(value);
|
||||||
|
|
||||||
|
if(mask!=0xFFFFFFFF)
|
||||||
|
{
|
||||||
|
cmd.length = 12;
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);
|
||||||
|
cmd.mask = cpu_to_le32(mask);
|
||||||
|
}
|
||||||
|
|
||||||
|
//DBG_871X("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__, addr,value,mask);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int _rtw_IOL_append_WRF_cmd(struct xmit_frame *xmit_frame, u8 rf_path, u16 addr, u32 value, u32 mask)
|
||||||
|
{
|
||||||
|
struct ioreg_cfg cmd = {8,IOREG_CMD_W_RF,0x0, 0x0,0x0};
|
||||||
|
|
||||||
|
//RTW_PUT_LE16((u8*)&cmd.address, addr);
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);
|
||||||
|
cmd.address = (rf_path<<8) |((addr) &0xFF);
|
||||||
|
cmd.data = cpu_to_le32(value);
|
||||||
|
|
||||||
|
if(mask!=0x000FFFFF)
|
||||||
|
{
|
||||||
|
cmd.length = 12;
|
||||||
|
//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);
|
||||||
|
cmd.mask = cpu_to_le32(mask);
|
||||||
|
}
|
||||||
|
|
||||||
|
//DBG_871X("%s rf_path:0x%02x addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__,rf_path, addr,value,mask);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us)
|
||||||
|
{
|
||||||
|
struct ioreg_cfg cmd = {4,IOREG_CMD_DELAY_US,0x0, 0x0,0x0};
|
||||||
|
//RTW_PUT_LE16((u8*)&cmd.address, us);
|
||||||
|
cmd.address = cpu_to_le16(us);
|
||||||
|
|
||||||
|
//DBG_871X("%s %u\n", __FUNCTION__, us);
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms)
|
||||||
|
{
|
||||||
|
struct ioreg_cfg cmd = {4,IOREG_CMD_DELAY_US,0x0, 0x0,0x0};
|
||||||
|
|
||||||
|
//RTW_PUT_LE16((u8*)&cmd.address, ms);
|
||||||
|
cmd.address = cpu_to_le16(ms);
|
||||||
|
|
||||||
|
//DBG_871X("%s %u\n", __FUNCTION__, ms);
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 4);
|
||||||
|
}
|
||||||
|
int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame)
|
||||||
|
{
|
||||||
|
struct ioreg_cfg cmd = {4,IOREG_CMD_END,0xFFFF, 0xFF,0x0};
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 4);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 rtw_IOL_cmd_boundary_handle(struct xmit_frame *pxmit_frame)
|
||||||
|
{
|
||||||
|
u8 is_cmd_bndy = _FALSE;
|
||||||
|
if(((pxmit_frame->attrib.pktlen+32)%256) + 8 >= 256){
|
||||||
|
rtw_IOL_append_END_cmd(pxmit_frame);
|
||||||
|
pxmit_frame->attrib.pktlen = ((((pxmit_frame->attrib.pktlen+32)/256)+1)*256 );
|
||||||
|
|
||||||
|
//printk("==> %s, pktlen(%d)\n",__FUNCTION__,pxmit_frame->attrib.pktlen);
|
||||||
|
pxmit_frame->attrib.last_txcmdsz = pxmit_frame->attrib.pktlen;
|
||||||
|
is_cmd_bndy = _TRUE;
|
||||||
|
}
|
||||||
|
return is_cmd_bndy;
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_IOL_cmd_buf_dump(ADAPTER *Adapter,int buf_len,u8 *pbuf)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int j=1;
|
||||||
|
|
||||||
|
printk("###### %s ######\n",__FUNCTION__);
|
||||||
|
for(i=0;i< buf_len;i++){
|
||||||
|
printk("%02x-",*(pbuf+i));
|
||||||
|
|
||||||
|
if(j%32 ==0) printk("\n");j++;
|
||||||
|
}
|
||||||
|
printk("\n");
|
||||||
|
printk("============= ioreg_cmd len = %d =============== \n",buf_len);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#else //CONFIG_IOL_NEW_GENERATION
|
||||||
|
int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary)
|
||||||
|
{
|
||||||
|
IOL_CMD cmd = {0x0, IOL_CMD_LLT, 0x0, 0x0};
|
||||||
|
|
||||||
|
RTW_PUT_BE32((u8*)&cmd.value, (u32)page_boundary);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value)
|
||||||
|
{
|
||||||
|
IOL_CMD cmd = {0x0, IOL_CMD_WB_REG, 0x0, 0x0};
|
||||||
|
|
||||||
|
RTW_PUT_BE16((u8*)&cmd.address, (u16)addr);
|
||||||
|
RTW_PUT_BE32((u8*)&cmd.value, (u32)value);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value)
|
||||||
|
{
|
||||||
|
IOL_CMD cmd = {0x0, IOL_CMD_WW_REG, 0x0, 0x0};
|
||||||
|
|
||||||
|
RTW_PUT_BE16((u8*)&cmd.address, (u16)addr);
|
||||||
|
RTW_PUT_BE32((u8*)&cmd.value, (u32)value);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value)
|
||||||
|
{
|
||||||
|
IOL_CMD cmd = {0x0, IOL_CMD_WD_REG, 0x0, 0x0};
|
||||||
|
u8* pos = (u8 *)&cmd;
|
||||||
|
|
||||||
|
RTW_PUT_BE16((u8*)&cmd.address, (u16)addr);
|
||||||
|
RTW_PUT_BE32((u8*)&cmd.value, (u32)value);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef DBG_IO
|
||||||
|
int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line)
|
||||||
|
{
|
||||||
|
if (match_write_sniff_ranges(addr, 1))
|
||||||
|
DBG_871X("DBG_IO %s:%d IOL_WB(0x%04x, 0x%02x)\n", caller, line, addr, value);
|
||||||
|
|
||||||
|
return _rtw_IOL_append_WB_cmd(xmit_frame, addr, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line)
|
||||||
|
{
|
||||||
|
if (match_write_sniff_ranges(addr, 2))
|
||||||
|
DBG_871X("DBG_IO %s:%d IOL_WW(0x%04x, 0x%04x)\n", caller, line, addr, value);
|
||||||
|
|
||||||
|
return _rtw_IOL_append_WW_cmd(xmit_frame, addr, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line)
|
||||||
|
{
|
||||||
|
if (match_write_sniff_ranges(addr, 4))
|
||||||
|
DBG_871X("DBG_IO %s:%d IOL_WD(0x%04x, 0x%08x)\n", caller, line, addr, value);
|
||||||
|
|
||||||
|
return _rtw_IOL_append_WD_cmd(xmit_frame, addr, value);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us)
|
||||||
|
{
|
||||||
|
IOL_CMD cmd = {0x0, IOL_CMD_DELAY_US, 0x0, 0x0};
|
||||||
|
|
||||||
|
RTW_PUT_BE32((u8*)&cmd.value, (u32)us);
|
||||||
|
|
||||||
|
//DBG_871X("%s %u\n", __FUNCTION__, us);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms)
|
||||||
|
{
|
||||||
|
IOL_CMD cmd = {0x0, IOL_CMD_DELAY_MS, 0x0, 0x0};
|
||||||
|
|
||||||
|
RTW_PUT_BE32((u8*)&cmd.value, (u32)ms);
|
||||||
|
|
||||||
|
//DBG_871X("%s %u\n", __FUNCTION__, ms);
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame)
|
||||||
|
{
|
||||||
|
IOL_CMD end_cmd = {0x0, IOL_CMD_END, 0x0, 0x0};
|
||||||
|
|
||||||
|
|
||||||
|
return rtw_IOL_append_cmds(xmit_frame, (u8*)&end_cmd, 8);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int rtw_IOL_exec_cmd_array_sync(PADAPTER adapter, u8 *IOL_cmds, u32 cmd_num, u32 max_wating_ms)
|
||||||
|
{
|
||||||
|
struct xmit_frame *xmit_frame;
|
||||||
|
|
||||||
|
if((xmit_frame=rtw_IOL_accquire_xmit_frame(adapter)) == NULL)
|
||||||
|
return _FAIL;
|
||||||
|
|
||||||
|
if(rtw_IOL_append_cmds(xmit_frame, IOL_cmds, cmd_num<<3) == _FAIL)
|
||||||
|
return _FAIL;
|
||||||
|
|
||||||
|
return rtw_IOL_exec_cmds_sync(adapter, xmit_frame, max_wating_ms,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int rtw_IOL_exec_empty_cmds_sync(ADAPTER *adapter, u32 max_wating_ms)
|
||||||
|
{
|
||||||
|
IOL_CMD end_cmd = {0x0, IOL_CMD_END, 0x0, 0x0};
|
||||||
|
return rtw_IOL_exec_cmd_array_sync(adapter, (u8*)&end_cmd, 1, max_wating_ms);
|
||||||
|
}
|
||||||
|
#endif //CONFIG_IOL_NEW_GENERATION
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif //CONFIG_IOL
|
||||||
|
|
4474
core/rtw_mlme.c
Normal file
4474
core/rtw_mlme.c
Normal file
File diff suppressed because it is too large
Load Diff
14545
core/rtw_mlme_ext.c
Normal file
14545
core/rtw_mlme_ext.c
Normal file
File diff suppressed because it is too large
Load Diff
2454
core/rtw_mp.c
Normal file
2454
core/rtw_mp.c
Normal file
File diff suppressed because it is too large
Load Diff
2948
core/rtw_mp_ioctl.c
Normal file
2948
core/rtw_mp_ioctl.c
Normal file
File diff suppressed because it is too large
Load Diff
207
core/rtw_odm.c
Normal file
207
core/rtw_odm.c
Normal file
@ -0,0 +1,207 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2013 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#include <rtw_odm.h>
|
||||||
|
#include <hal_data.h>
|
||||||
|
|
||||||
|
const char *odm_comp_str[] = {
|
||||||
|
/* BIT0 */"ODM_COMP_DIG",
|
||||||
|
/* BIT1 */"ODM_COMP_RA_MASK",
|
||||||
|
/* BIT2 */"ODM_COMP_DYNAMIC_TXPWR",
|
||||||
|
/* BIT3 */"ODM_COMP_FA_CNT",
|
||||||
|
/* BIT4 */"ODM_COMP_RSSI_MONITOR",
|
||||||
|
/* BIT5 */"ODM_COMP_CCK_PD",
|
||||||
|
/* BIT6 */"ODM_COMP_ANT_DIV",
|
||||||
|
/* BIT7 */"ODM_COMP_PWR_SAVE",
|
||||||
|
/* BIT8 */"ODM_COMP_PWR_TRAIN",
|
||||||
|
/* BIT9 */"ODM_COMP_RATE_ADAPTIVE",
|
||||||
|
/* BIT10 */"ODM_COMP_PATH_DIV",
|
||||||
|
/* BIT11 */"ODM_COMP_PSD",
|
||||||
|
/* BIT12 */"ODM_COMP_DYNAMIC_PRICCA",
|
||||||
|
/* BIT13 */"ODM_COMP_RXHP",
|
||||||
|
/* BIT14 */"ODM_COMP_MP",
|
||||||
|
/* BIT15 */"ODM_COMP_DYNAMIC_ATC",
|
||||||
|
/* BIT16 */"ODM_COMP_EDCA_TURBO",
|
||||||
|
/* BIT17 */"ODM_COMP_EARLY_MODE",
|
||||||
|
/* BIT18 */NULL,
|
||||||
|
/* BIT19 */NULL,
|
||||||
|
/* BIT20 */NULL,
|
||||||
|
/* BIT21 */NULL,
|
||||||
|
/* BIT22 */NULL,
|
||||||
|
/* BIT23 */NULL,
|
||||||
|
/* BIT24 */"ODM_COMP_TX_PWR_TRACK",
|
||||||
|
/* BIT25 */"ODM_COMP_RX_GAIN_TRACK",
|
||||||
|
/* BIT26 */"ODM_COMP_CALIBRATION",
|
||||||
|
/* BIT27 */NULL,
|
||||||
|
/* BIT28 */NULL,
|
||||||
|
/* BIT29 */NULL,
|
||||||
|
/* BIT30 */"ODM_COMP_COMMON",
|
||||||
|
/* BIT31 */"ODM_COMP_INIT",
|
||||||
|
};
|
||||||
|
|
||||||
|
#define RTW_ODM_COMP_MAX 32
|
||||||
|
|
||||||
|
const char *odm_ability_str[] = {
|
||||||
|
/* BIT0 */"ODM_BB_DIG",
|
||||||
|
/* BIT1 */"ODM_BB_RA_MASK",
|
||||||
|
/* BIT2 */"ODM_BB_DYNAMIC_TXPWR",
|
||||||
|
/* BIT3 */"ODM_BB_FA_CNT",
|
||||||
|
/* BIT4 */"ODM_BB_RSSI_MONITOR",
|
||||||
|
/* BIT5 */"ODM_BB_CCK_PD",
|
||||||
|
/* BIT6 */"ODM_BB_ANT_DIV",
|
||||||
|
/* BIT7 */"ODM_BB_PWR_SAVE",
|
||||||
|
/* BIT8 */"ODM_BB_PWR_TRAIN",
|
||||||
|
/* BIT9 */"ODM_BB_RATE_ADAPTIVE",
|
||||||
|
/* BIT10 */"ODM_BB_PATH_DIV",
|
||||||
|
/* BIT11 */"ODM_BB_PSD",
|
||||||
|
/* BIT12 */"ODM_BB_RXHP",
|
||||||
|
/* BIT13 */"ODM_BB_ADAPTIVITY",
|
||||||
|
/* BIT14 */"ODM_BB_DYNAMIC_ATC",
|
||||||
|
/* BIT15 */NULL,
|
||||||
|
/* BIT16 */"ODM_MAC_EDCA_TURBO",
|
||||||
|
/* BIT17 */"ODM_MAC_EARLY_MODE",
|
||||||
|
/* BIT18 */NULL,
|
||||||
|
/* BIT19 */NULL,
|
||||||
|
/* BIT20 */NULL,
|
||||||
|
/* BIT21 */NULL,
|
||||||
|
/* BIT22 */NULL,
|
||||||
|
/* BIT23 */NULL,
|
||||||
|
/* BIT24 */"ODM_RF_TX_PWR_TRACK",
|
||||||
|
/* BIT25 */"ODM_RF_RX_GAIN_TRACK",
|
||||||
|
/* BIT26 */"ODM_RF_CALIBRATION",
|
||||||
|
};
|
||||||
|
|
||||||
|
#define RTW_ODM_ABILITY_MAX 27
|
||||||
|
|
||||||
|
const char *odm_dbg_level_str[] = {
|
||||||
|
NULL,
|
||||||
|
"ODM_DBG_OFF",
|
||||||
|
"ODM_DBG_SERIOUS",
|
||||||
|
"ODM_DBG_WARNING",
|
||||||
|
"ODM_DBG_LOUD",
|
||||||
|
"ODM_DBG_TRACE",
|
||||||
|
};
|
||||||
|
|
||||||
|
#define RTW_ODM_DBG_LEVEL_NUM 6
|
||||||
|
|
||||||
|
void rtw_odm_dbg_comp_msg(void *sel, _adapter *adapter)
|
||||||
|
{
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
|
||||||
|
DM_ODM_T *odm = &pHalData->odmpriv;
|
||||||
|
int cnt = 0;
|
||||||
|
u64 dbg_comp;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
rtw_hal_get_def_var(adapter, HW_DEF_ODM_DBG_FLAG, &dbg_comp);
|
||||||
|
DBG_871X_SEL_NL(sel, "odm.DebugComponents = 0x%016llx \n", dbg_comp);
|
||||||
|
for (i=0;i<RTW_ODM_COMP_MAX;i++) {
|
||||||
|
if (odm_comp_str[i])
|
||||||
|
DBG_871X_SEL_NL(sel, "%cBIT%-2d %s\n",
|
||||||
|
(BIT0 << i) & dbg_comp ? '+' : ' ', i, odm_comp_str[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void rtw_odm_dbg_comp_set(_adapter *adapter, u64 comps)
|
||||||
|
{
|
||||||
|
rtw_hal_set_def_var(adapter, HW_DEF_ODM_DBG_FLAG, &comps);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_odm_dbg_level_msg(void *sel, _adapter *adapter)
|
||||||
|
{
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
|
||||||
|
DM_ODM_T *odm = &pHalData->odmpriv;
|
||||||
|
int cnt = 0;
|
||||||
|
u32 dbg_level;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
rtw_hal_get_def_var(adapter, HW_DEF_ODM_DBG_LEVEL, &dbg_level);
|
||||||
|
DBG_871X_SEL_NL(sel, "odm.DebugDebugLevel = %u\n", dbg_level);
|
||||||
|
for (i=0;i<RTW_ODM_DBG_LEVEL_NUM;i++) {
|
||||||
|
if (odm_dbg_level_str[i])
|
||||||
|
DBG_871X_SEL_NL(sel, "%u %s\n", i, odm_dbg_level_str[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void rtw_odm_dbg_level_set(_adapter *adapter, u32 level)
|
||||||
|
{
|
||||||
|
rtw_hal_set_def_var(adapter, HW_DEF_ODM_DBG_LEVEL, &level);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_odm_ability_msg(void *sel, _adapter *adapter)
|
||||||
|
{
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
|
||||||
|
DM_ODM_T *odm = &pHalData->odmpriv;
|
||||||
|
int cnt = 0;
|
||||||
|
u32 ability = 0;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
rtw_hal_get_hwreg(adapter, HW_VAR_DM_FLAG, (u8*)&ability);
|
||||||
|
DBG_871X_SEL_NL(sel, "odm.SupportAbility = 0x%08x\n", ability);
|
||||||
|
for (i=0;i<RTW_ODM_ABILITY_MAX;i++) {
|
||||||
|
if (odm_ability_str[i])
|
||||||
|
DBG_871X_SEL_NL(sel, "%cBIT%-2d %s\n",
|
||||||
|
(BIT0 << i) & ability ? '+' : ' ', i, odm_ability_str[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void rtw_odm_ability_set(_adapter *adapter, u32 ability)
|
||||||
|
{
|
||||||
|
rtw_hal_set_hwreg(adapter, HW_VAR_DM_FLAG, (u8*)&ability);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter)
|
||||||
|
{
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
|
||||||
|
DM_ODM_T *odm = &pHalData->odmpriv;
|
||||||
|
|
||||||
|
DBG_871X_SEL_NL(sel, "%10s %16s %8s %10s %11s %14s\n"
|
||||||
|
, "TH_L2H_ini", "TH_EDCCA_HL_diff", "IGI_Base", "ForceEDCCA", "AdapEn_RSSI", "IGI_LowerBound");
|
||||||
|
DBG_871X_SEL_NL(sel, "0x%-8x %-16d 0x%-6x %-10d %-11u %-14u\n"
|
||||||
|
, (u8)odm->TH_L2H_ini
|
||||||
|
, odm->TH_EDCCA_HL_diff
|
||||||
|
, odm->IGI_Base
|
||||||
|
, odm->ForceEDCCA
|
||||||
|
, odm->AdapEn_RSSI
|
||||||
|
, odm->IGI_LowerBound
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 TH_L2H_ini, s8 TH_EDCCA_HL_diff,
|
||||||
|
s8 IGI_Base, bool ForceEDCCA, u8 AdapEn_RSSI, u8 IGI_LowerBound)
|
||||||
|
{
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
|
||||||
|
DM_ODM_T *odm = &pHalData->odmpriv;
|
||||||
|
|
||||||
|
odm->TH_L2H_ini = TH_L2H_ini;
|
||||||
|
odm->TH_EDCCA_HL_diff = TH_EDCCA_HL_diff;
|
||||||
|
odm->IGI_Base = IGI_Base;
|
||||||
|
odm->ForceEDCCA = ForceEDCCA;
|
||||||
|
odm->AdapEn_RSSI = AdapEn_RSSI;
|
||||||
|
odm->IGI_LowerBound = IGI_LowerBound;
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter)
|
||||||
|
{
|
||||||
|
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
|
||||||
|
DM_ODM_T *odm = &(hal_data->odmpriv);
|
||||||
|
|
||||||
|
DBG_871X_SEL_NL(sel,"RxRate = %s, RSSI_A = %d(%%), RSSI_B = %d(%%)\n",
|
||||||
|
HDATA_RATE(odm->RxRate), odm->RSSI_A, odm->RSSI_B);
|
||||||
|
}
|
5330
core/rtw_p2p.c
Normal file
5330
core/rtw_p2p.c
Normal file
File diff suppressed because it is too large
Load Diff
2651
core/rtw_pwrctrl.c
Normal file
2651
core/rtw_pwrctrl.c
Normal file
File diff suppressed because it is too large
Load Diff
4009
core/rtw_recv.c
Normal file
4009
core/rtw_recv.c
Normal file
File diff suppressed because it is too large
Load Diff
91
core/rtw_rf.c
Normal file
91
core/rtw_rf.c
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#define _RTW_RF_C_
|
||||||
|
|
||||||
|
#include <drv_types.h>
|
||||||
|
|
||||||
|
|
||||||
|
struct ch_freq {
|
||||||
|
u32 channel;
|
||||||
|
u32 frequency;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct ch_freq ch_freq_map[] = {
|
||||||
|
{1, 2412},{2, 2417},{3, 2422},{4, 2427},{5, 2432},
|
||||||
|
{6, 2437},{7, 2442},{8, 2447},{9, 2452},{10, 2457},
|
||||||
|
{11, 2462},{12, 2467},{13, 2472},{14, 2484},
|
||||||
|
/* UNII */
|
||||||
|
{36, 5180},{40, 5200},{44, 5220},{48, 5240},{52, 5260},
|
||||||
|
{56, 5280},{60, 5300},{64, 5320},{149, 5745},{153, 5765},
|
||||||
|
{157, 5785},{161, 5805},{165, 5825},{167, 5835},{169, 5845},
|
||||||
|
{171, 5855},{173, 5865},
|
||||||
|
/* HiperLAN2 */
|
||||||
|
{100, 5500},{104, 5520},{108, 5540},{112, 5560},{116, 5580},
|
||||||
|
{120, 5600},{124, 5620},{128, 5640},{132, 5660},{136, 5680},
|
||||||
|
{140, 5700},
|
||||||
|
/* Japan MMAC */
|
||||||
|
{34, 5170},{38, 5190},{42, 5210},{46, 5230},
|
||||||
|
/* Japan */
|
||||||
|
{184, 4920},{188, 4940},{192, 4960},{196, 4980},
|
||||||
|
{208, 5040},/* Japan, means J08 */
|
||||||
|
{212, 5060},/* Japan, means J12 */
|
||||||
|
{216, 5080},/* Japan, means J16 */
|
||||||
|
};
|
||||||
|
|
||||||
|
int ch_freq_map_num = (sizeof(ch_freq_map) / sizeof(struct ch_freq));
|
||||||
|
|
||||||
|
u32 rtw_ch2freq(u32 channel)
|
||||||
|
{
|
||||||
|
u8 i;
|
||||||
|
u32 freq = 0;
|
||||||
|
|
||||||
|
for (i = 0; i < ch_freq_map_num; i++)
|
||||||
|
{
|
||||||
|
if (channel == ch_freq_map[i].channel)
|
||||||
|
{
|
||||||
|
freq = ch_freq_map[i].frequency;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (i == ch_freq_map_num)
|
||||||
|
freq = 2412;
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 rtw_freq2ch(u32 freq)
|
||||||
|
{
|
||||||
|
u8 i;
|
||||||
|
u32 ch = 0;
|
||||||
|
|
||||||
|
for (i = 0; i < ch_freq_map_num; i++)
|
||||||
|
{
|
||||||
|
if (freq == ch_freq_map[i].frequency)
|
||||||
|
{
|
||||||
|
ch = ch_freq_map[i].channel;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (i == ch_freq_map_num)
|
||||||
|
ch = 1;
|
||||||
|
|
||||||
|
return ch;
|
||||||
|
}
|
||||||
|
|
3173
core/rtw_security.c
Normal file
3173
core/rtw_security.c
Normal file
File diff suppressed because it is too large
Load Diff
367
core/rtw_sreset.c
Normal file
367
core/rtw_sreset.c
Normal file
@ -0,0 +1,367 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#include <drv_types.h>
|
||||||
|
#include <hal_data.h>
|
||||||
|
#include <rtw_sreset.h>
|
||||||
|
|
||||||
|
void sreset_init_value(_adapter *padapter)
|
||||||
|
{
|
||||||
|
#if defined(DBG_CONFIG_ERROR_DETECT)
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
|
||||||
|
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
|
||||||
|
|
||||||
|
_rtw_mutex_init(&psrtpriv->silentreset_mutex);
|
||||||
|
psrtpriv->silent_reset_inprogress = _FALSE;
|
||||||
|
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
|
||||||
|
psrtpriv->last_tx_time =0;
|
||||||
|
psrtpriv->last_tx_complete_time =0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
void sreset_reset_value(_adapter *padapter)
|
||||||
|
{
|
||||||
|
#if defined(DBG_CONFIG_ERROR_DETECT)
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
|
||||||
|
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
|
||||||
|
|
||||||
|
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
|
||||||
|
psrtpriv->last_tx_time =0;
|
||||||
|
psrtpriv->last_tx_complete_time =0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 sreset_get_wifi_status(_adapter *padapter)
|
||||||
|
{
|
||||||
|
#if defined(DBG_CONFIG_ERROR_DETECT)
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
|
||||||
|
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
|
||||||
|
|
||||||
|
u8 status = WIFI_STATUS_SUCCESS;
|
||||||
|
u32 val32 = 0;
|
||||||
|
_irqL irqL;
|
||||||
|
if(psrtpriv->silent_reset_inprogress == _TRUE)
|
||||||
|
{
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
val32 =rtw_read32(padapter,REG_TXDMA_STATUS);
|
||||||
|
if(val32==0xeaeaeaea){
|
||||||
|
psrtpriv->Wifi_Error_Status = WIFI_IF_NOT_EXIST;
|
||||||
|
}
|
||||||
|
else if(val32!=0){
|
||||||
|
DBG_8192C("txdmastatu(%x)\n",val32);
|
||||||
|
psrtpriv->Wifi_Error_Status = WIFI_MAC_TXDMA_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(WIFI_STATUS_SUCCESS !=psrtpriv->Wifi_Error_Status)
|
||||||
|
{
|
||||||
|
DBG_8192C("==>%s error_status(0x%x) \n",__FUNCTION__,psrtpriv->Wifi_Error_Status);
|
||||||
|
status = (psrtpriv->Wifi_Error_Status &( ~(USB_READ_PORT_FAIL|USB_WRITE_PORT_FAIL)));
|
||||||
|
}
|
||||||
|
DBG_8192C("==> %s wifi_status(0x%x)\n",__FUNCTION__,status);
|
||||||
|
|
||||||
|
//status restore
|
||||||
|
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
return status;
|
||||||
|
#else
|
||||||
|
return WIFI_STATUS_SUCCESS;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void sreset_set_wifi_error_status(_adapter *padapter, u32 status)
|
||||||
|
{
|
||||||
|
#if defined(DBG_CONFIG_ERROR_DETECT)
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
|
||||||
|
pHalData->srestpriv.Wifi_Error_Status = status;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void sreset_set_trigger_point(_adapter *padapter, s32 tgp)
|
||||||
|
{
|
||||||
|
#if defined(DBG_CONFIG_ERROR_DETECT)
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
|
||||||
|
pHalData->srestpriv.dbg_trigger_point = tgp;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
bool sreset_inprogress(_adapter *padapter)
|
||||||
|
{
|
||||||
|
#if defined(DBG_CONFIG_ERROR_RESET)
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
|
||||||
|
return pHalData->srestpriv.silent_reset_inprogress;
|
||||||
|
#else
|
||||||
|
return _FALSE;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void sreset_restore_security_station(_adapter *padapter)
|
||||||
|
{
|
||||||
|
u8 EntryId = 0;
|
||||||
|
struct mlme_priv *mlmepriv = &padapter->mlmepriv;
|
||||||
|
struct sta_priv * pstapriv = &padapter->stapriv;
|
||||||
|
struct sta_info *psta;
|
||||||
|
struct security_priv* psecuritypriv=&(padapter->securitypriv);
|
||||||
|
struct mlme_ext_info *pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
|
||||||
|
|
||||||
|
{
|
||||||
|
u8 val8;
|
||||||
|
|
||||||
|
if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X) {
|
||||||
|
val8 = 0xcc;
|
||||||
|
#ifdef CONFIG_WAPI_SUPPORT
|
||||||
|
} else if (padapter->wapiInfo.bWapiEnable && pmlmeinfo->auth_algo == dot11AuthAlgrthm_WAPI) {
|
||||||
|
//Disable TxUseDefaultKey, RxUseDefaultKey, RxBroadcastUseDefaultKey.
|
||||||
|
val8 = 0x4c;
|
||||||
|
#endif
|
||||||
|
} else {
|
||||||
|
val8 = 0xcf;
|
||||||
|
}
|
||||||
|
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
if ( ( padapter->securitypriv.dot11PrivacyAlgrthm == _WEP40_ ) ||
|
||||||
|
( padapter->securitypriv.dot11PrivacyAlgrthm == _WEP104_ ))
|
||||||
|
{
|
||||||
|
|
||||||
|
for(EntryId=0; EntryId<4; EntryId++)
|
||||||
|
{
|
||||||
|
if(EntryId == psecuritypriv->dot11PrivacyKeyIndex)
|
||||||
|
rtw_set_key(padapter,&padapter->securitypriv, EntryId, 1,_FALSE);
|
||||||
|
else
|
||||||
|
rtw_set_key(padapter,&padapter->securitypriv, EntryId, 0,_FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
if((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
|
||||||
|
(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_))
|
||||||
|
{
|
||||||
|
psta = rtw_get_stainfo(pstapriv, get_bssid(mlmepriv));
|
||||||
|
if (psta == NULL) {
|
||||||
|
//DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail \n"));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//pairwise key
|
||||||
|
rtw_setstakey_cmd(padapter, (unsigned char *)psta, _TRUE,_FALSE);
|
||||||
|
//group key
|
||||||
|
rtw_set_key(padapter,&padapter->securitypriv,padapter->securitypriv.dot118021XGrpKeyid, 0,_FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void sreset_restore_network_station(_adapter *padapter)
|
||||||
|
{
|
||||||
|
struct mlme_priv *mlmepriv = &padapter->mlmepriv;
|
||||||
|
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||||
|
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
{
|
||||||
|
//=======================================================
|
||||||
|
// reset related register of Beacon control
|
||||||
|
|
||||||
|
//set MSR to nolink
|
||||||
|
Set_MSR(padapter, _HW_STATE_NOLINK_);
|
||||||
|
// reject all data frame
|
||||||
|
rtw_write16(padapter, REG_RXFLTMAP2,0x00);
|
||||||
|
//reset TSF
|
||||||
|
rtw_write8(padapter, REG_DUAL_TSF_RST, (BIT(0)|BIT(1)));
|
||||||
|
|
||||||
|
// disable update TSF
|
||||||
|
SetBcnCtrlReg(padapter, BIT(4), 0);
|
||||||
|
|
||||||
|
//=======================================================
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure,_FALSE);
|
||||||
|
|
||||||
|
{
|
||||||
|
u8 threshold;
|
||||||
|
#ifdef CONFIG_USB_HCI
|
||||||
|
// TH=1 => means that invalidate usb rx aggregation
|
||||||
|
// TH=0 => means that validate usb rx aggregation, use init value.
|
||||||
|
if(mlmepriv->htpriv.ht_option) {
|
||||||
|
if(padapter->registrypriv.wifi_spec==1)
|
||||||
|
threshold = 1;
|
||||||
|
else
|
||||||
|
threshold = 0;
|
||||||
|
rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
|
||||||
|
} else {
|
||||||
|
threshold = 1;
|
||||||
|
rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK, NULL);
|
||||||
|
|
||||||
|
set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
|
||||||
|
|
||||||
|
//disable dynamic functions, such as high power, DIG
|
||||||
|
//Switch_DM_Func(padapter, DYNAMIC_FUNC_DISABLE, _FALSE);
|
||||||
|
|
||||||
|
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmlmeinfo->network.MacAddress);
|
||||||
|
|
||||||
|
{
|
||||||
|
u8 join_type = 0;
|
||||||
|
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
|
||||||
|
}
|
||||||
|
|
||||||
|
Set_MSR(padapter, (pmlmeinfo->state & 0x3));
|
||||||
|
|
||||||
|
mlmeext_joinbss_event_callback(padapter, 1);
|
||||||
|
//restore Sequence No.
|
||||||
|
rtw_write8(padapter,0x4dc,padapter->xmitpriv.nqos_ssn);
|
||||||
|
|
||||||
|
sreset_restore_security_station(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void sreset_restore_network_status(_adapter *padapter)
|
||||||
|
{
|
||||||
|
struct mlme_priv *mlmepriv = &padapter->mlmepriv;
|
||||||
|
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||||
|
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
|
||||||
|
|
||||||
|
if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
|
||||||
|
DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
||||||
|
sreset_restore_network_station(padapter);
|
||||||
|
} else if (check_fwstate(mlmepriv, WIFI_AP_STATE)) {
|
||||||
|
DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_AP_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
||||||
|
rtw_ap_restore_network(padapter);
|
||||||
|
} else if (check_fwstate(mlmepriv, WIFI_ADHOC_STATE)) {
|
||||||
|
DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
||||||
|
} else {
|
||||||
|
DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void sreset_stop_adapter(_adapter *padapter)
|
||||||
|
{
|
||||||
|
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
|
||||||
|
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||||
|
|
||||||
|
if (padapter == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
|
||||||
|
|
||||||
|
if (!rtw_netif_queue_stopped(padapter->pnetdev))
|
||||||
|
rtw_netif_stop_queue(padapter->pnetdev);
|
||||||
|
|
||||||
|
rtw_cancel_all_timer(padapter);
|
||||||
|
|
||||||
|
/* TODO: OS and HCI independent */
|
||||||
|
#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
|
||||||
|
tasklet_kill(&pxmitpriv->xmit_tasklet);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
|
||||||
|
rtw_scan_abort(padapter);
|
||||||
|
|
||||||
|
if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING))
|
||||||
|
{
|
||||||
|
rtw_set_to_roam(padapter, 0);
|
||||||
|
_rtw_join_timeout_handler(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void sreset_start_adapter(_adapter *padapter)
|
||||||
|
{
|
||||||
|
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
|
||||||
|
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||||
|
|
||||||
|
if (padapter == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
|
||||||
|
|
||||||
|
if (check_fwstate(pmlmepriv, _FW_LINKED)) {
|
||||||
|
sreset_restore_network_status(padapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* TODO: OS and HCI independent */
|
||||||
|
#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
|
||||||
|
tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 2000);
|
||||||
|
|
||||||
|
if (rtw_netif_queue_stopped(padapter->pnetdev))
|
||||||
|
rtw_netif_wake_queue(padapter->pnetdev);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void sreset_reset(_adapter *padapter)
|
||||||
|
{
|
||||||
|
#ifdef DBG_CONFIG_ERROR_RESET
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
|
||||||
|
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
|
||||||
|
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
|
||||||
|
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
|
||||||
|
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||||
|
_irqL irqL;
|
||||||
|
u32 start = rtw_get_current_time();
|
||||||
|
struct dvobj_priv *psdpriv = padapter->dvobj;
|
||||||
|
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
|
||||||
|
|
||||||
|
DBG_871X("%s\n", __FUNCTION__);
|
||||||
|
|
||||||
|
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_POWER_SAVING
|
||||||
|
rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "SRESET");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
_enter_pwrlock(&pwrpriv->lock);
|
||||||
|
|
||||||
|
psrtpriv->silent_reset_inprogress = _TRUE;
|
||||||
|
pwrpriv->change_rfpwrstate = rf_off;
|
||||||
|
|
||||||
|
sreset_stop_adapter(padapter);
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
sreset_stop_adapter(padapter->pbuddy_adapter);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_IPS
|
||||||
|
_ips_enter(padapter);
|
||||||
|
_ips_leave(padapter);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
sreset_start_adapter(padapter);
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
sreset_start_adapter(padapter->pbuddy_adapter);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
psrtpriv->silent_reset_inprogress = _FALSE;
|
||||||
|
|
||||||
|
_exit_pwrlock(&pwrpriv->lock);
|
||||||
|
|
||||||
|
DBG_871X("%s done in %d ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
|
||||||
|
pdbgpriv->dbg_sreset_cnt++;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
848
core/rtw_sta_mgt.c
Normal file
848
core/rtw_sta_mgt.c
Normal file
File diff suppressed because it is too large
Load Diff
2969
core/rtw_tdls.c
Normal file
2969
core/rtw_tdls.c
Normal file
File diff suppressed because it is too large
Load Diff
733
core/rtw_vht.c
Normal file
733
core/rtw_vht.c
Normal file
File diff suppressed because it is too large
Load Diff
1326
core/rtw_wapi.c
Normal file
1326
core/rtw_wapi.c
Normal file
File diff suppressed because it is too large
Load Diff
923
core/rtw_wapi_sms4.c
Normal file
923
core/rtw_wapi_sms4.c
Normal file
File diff suppressed because it is too large
Load Diff
3603
core/rtw_wlan_util.c
Normal file
3603
core/rtw_wlan_util.c
Normal file
File diff suppressed because it is too large
Load Diff
4764
core/rtw_xmit.c
Normal file
4764
core/rtw_xmit.c
Normal file
File diff suppressed because it is too large
Load Diff
183
hal/HalPwrSeqCmd.c
Normal file
183
hal/HalPwrSeqCmd.c
Normal file
@ -0,0 +1,183 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
/*++
|
||||||
|
Copyright (c) Realtek Semiconductor Corp. All rights reserved.
|
||||||
|
|
||||||
|
Module Name:
|
||||||
|
HalPwrSeqCmd.c
|
||||||
|
|
||||||
|
Abstract:
|
||||||
|
Implement HW Power sequence configuration CMD handling routine for Realtek devices.
|
||||||
|
|
||||||
|
Major Change History:
|
||||||
|
When Who What
|
||||||
|
---------- --------------- -------------------------------
|
||||||
|
2011-10-26 Lucas Modify to be compatible with SD4-CE driver.
|
||||||
|
2011-07-07 Roger Create.
|
||||||
|
|
||||||
|
--*/
|
||||||
|
#include <HalPwrSeqCmd.h>
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Description:
|
||||||
|
// This routine deal with the Power Configuration CMDs parsing for RTL8723/RTL8188E Series IC.
|
||||||
|
//
|
||||||
|
// Assumption:
|
||||||
|
// We should follow specific format which was released from HW SD.
|
||||||
|
//
|
||||||
|
// 2011.07.07, added by Roger.
|
||||||
|
//
|
||||||
|
u8 HalPwrSeqCmdParsing(
|
||||||
|
PADAPTER padapter,
|
||||||
|
u8 CutVersion,
|
||||||
|
u8 FabVersion,
|
||||||
|
u8 InterfaceType,
|
||||||
|
WLAN_PWR_CFG PwrSeqCmd[])
|
||||||
|
{
|
||||||
|
WLAN_PWR_CFG PwrCfgCmd = {0};
|
||||||
|
u8 bPollingBit = _FALSE;
|
||||||
|
u32 AryIdx = 0;
|
||||||
|
u8 value = 0;
|
||||||
|
u32 offset = 0;
|
||||||
|
u32 pollingCount = 0; // polling autoload done.
|
||||||
|
u32 maxPollingCnt = 5000;
|
||||||
|
|
||||||
|
do {
|
||||||
|
PwrCfgCmd = PwrSeqCmd[AryIdx];
|
||||||
|
|
||||||
|
RT_TRACE(_module_hal_init_c_ , _drv_info_,
|
||||||
|
("HalPwrSeqCmdParsing: offset(%#x) cut_msk(%#x) fab_msk(%#x) interface_msk(%#x) base(%#x) cmd(%#x) msk(%#x) value(%#x)\n",
|
||||||
|
GET_PWR_CFG_OFFSET(PwrCfgCmd),
|
||||||
|
GET_PWR_CFG_CUT_MASK(PwrCfgCmd),
|
||||||
|
GET_PWR_CFG_FAB_MASK(PwrCfgCmd),
|
||||||
|
GET_PWR_CFG_INTF_MASK(PwrCfgCmd),
|
||||||
|
GET_PWR_CFG_BASE(PwrCfgCmd),
|
||||||
|
GET_PWR_CFG_CMD(PwrCfgCmd),
|
||||||
|
GET_PWR_CFG_MASK(PwrCfgCmd),
|
||||||
|
GET_PWR_CFG_VALUE(PwrCfgCmd)));
|
||||||
|
|
||||||
|
//2 Only Handle the command whose FAB, CUT, and Interface are matched
|
||||||
|
if ((GET_PWR_CFG_FAB_MASK(PwrCfgCmd) & FabVersion) &&
|
||||||
|
(GET_PWR_CFG_CUT_MASK(PwrCfgCmd) & CutVersion) &&
|
||||||
|
(GET_PWR_CFG_INTF_MASK(PwrCfgCmd) & InterfaceType))
|
||||||
|
{
|
||||||
|
switch (GET_PWR_CFG_CMD(PwrCfgCmd))
|
||||||
|
{
|
||||||
|
case PWR_CMD_READ:
|
||||||
|
RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_READ\n"));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PWR_CMD_WRITE:
|
||||||
|
RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_WRITE\n"));
|
||||||
|
offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
|
||||||
|
|
||||||
|
#ifdef CONFIG_SDIO_HCI
|
||||||
|
//
|
||||||
|
// <Roger_Notes> We should deal with interface specific address mapping for some interfaces, e.g., SDIO interface
|
||||||
|
// 2011.07.07.
|
||||||
|
//
|
||||||
|
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
|
||||||
|
{
|
||||||
|
// Read Back SDIO Local value
|
||||||
|
value = SdioLocalCmd52Read1Byte(padapter, offset);
|
||||||
|
|
||||||
|
value &= ~(GET_PWR_CFG_MASK(PwrCfgCmd));
|
||||||
|
value |= (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd));
|
||||||
|
|
||||||
|
// Write Back SDIO Local value
|
||||||
|
SdioLocalCmd52Write1Byte(padapter, offset, value);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
#ifdef CONFIG_GSPI_HCI
|
||||||
|
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
|
||||||
|
offset = SPI_LOCAL_OFFSET | offset;
|
||||||
|
#endif
|
||||||
|
// Read the value from system register
|
||||||
|
value = rtw_read8(padapter, offset);
|
||||||
|
|
||||||
|
value=value&(~(GET_PWR_CFG_MASK(PwrCfgCmd)));
|
||||||
|
value=value|(GET_PWR_CFG_VALUE(PwrCfgCmd)&GET_PWR_CFG_MASK(PwrCfgCmd));
|
||||||
|
|
||||||
|
// Write the value back to sytem register
|
||||||
|
rtw_write8(padapter, offset, value);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PWR_CMD_POLLING:
|
||||||
|
RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_POLLING\n"));
|
||||||
|
|
||||||
|
bPollingBit = _FALSE;
|
||||||
|
offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
|
||||||
|
#ifdef CONFIG_GSPI_HCI
|
||||||
|
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
|
||||||
|
offset = SPI_LOCAL_OFFSET | offset;
|
||||||
|
#endif
|
||||||
|
do {
|
||||||
|
#ifdef CONFIG_SDIO_HCI
|
||||||
|
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
|
||||||
|
value = SdioLocalCmd52Read1Byte(padapter, offset);
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
value = rtw_read8(padapter, offset);
|
||||||
|
|
||||||
|
value=value&GET_PWR_CFG_MASK(PwrCfgCmd);
|
||||||
|
if (value == (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd)))
|
||||||
|
bPollingBit = _TRUE;
|
||||||
|
else
|
||||||
|
rtw_udelay_os(10);
|
||||||
|
|
||||||
|
if (pollingCount++ > maxPollingCnt) {
|
||||||
|
DBG_871X("Fail to polling Offset[%#x]=%02x\n", offset, value);
|
||||||
|
return _FALSE;
|
||||||
|
}
|
||||||
|
} while (!bPollingBit);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PWR_CMD_DELAY:
|
||||||
|
RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_DELAY\n"));
|
||||||
|
if (GET_PWR_CFG_VALUE(PwrCfgCmd) == PWRSEQ_DELAY_US)
|
||||||
|
rtw_udelay_os(GET_PWR_CFG_OFFSET(PwrCfgCmd));
|
||||||
|
else
|
||||||
|
rtw_udelay_os(GET_PWR_CFG_OFFSET(PwrCfgCmd)*1000);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PWR_CMD_END:
|
||||||
|
// When this command is parsed, end the process
|
||||||
|
RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_END\n"));
|
||||||
|
return _TRUE;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
RT_TRACE(_module_hal_init_c_ , _drv_err_, ("HalPwrSeqCmdParsing: Unknown CMD!!\n"));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AryIdx++;//Add Array Index
|
||||||
|
}while(1);
|
||||||
|
|
||||||
|
return _TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
2054
hal/OUTSRC-BTCoexist/HalBtc8188c2Ant.c
Normal file
2054
hal/OUTSRC-BTCoexist/HalBtc8188c2Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
145
hal/OUTSRC-BTCoexist/HalBtc8188c2Ant.h
Normal file
145
hal/OUTSRC-BTCoexist/HalBtc8188c2Ant.h
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8188C 2Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8188C_2ANT 6
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8188C_2ANT{
|
||||||
|
BT_INFO_SRC_8188C_2ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8188C_2ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8188C_2ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8188C_2ANT_MAX
|
||||||
|
}BT_INFO_SRC_8188C_2ANT,*PBT_INFO_SRC_8188C_2ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8188C_2ANT_BT_STATUS{
|
||||||
|
BT_8188C_2ANT_BT_STATUS_IDLE = 0x0,
|
||||||
|
BT_8188C_2ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8188C_2ANT_BT_STATUS_NON_IDLE = 0x2,
|
||||||
|
BT_8188C_2ANT_BT_STATUS_MAX
|
||||||
|
}BT_8188C_2ANT_BT_STATUS,*PBT_8188C_2ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8188C_2ANT_COEX_ALGO{
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_PAN = 0x4,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_HID_A2DP = 0x5,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_HID_PAN = 0x6,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_PAN_A2DP = 0x7,
|
||||||
|
BT_8188C_2ANT_COEX_ALGO_MAX
|
||||||
|
}BT_8188C_2ANT_COEX_ALGO,*PBT_8188C_2ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8188C_2ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bPreBalanceOn;
|
||||||
|
BOOLEAN bCurBalanceOn;
|
||||||
|
|
||||||
|
// diminishWifi
|
||||||
|
BOOLEAN bPreDacOn;
|
||||||
|
BOOLEAN bCurDacOn;
|
||||||
|
BOOLEAN bPreInterruptOn;
|
||||||
|
BOOLEAN bCurInterruptOn;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bPreNavOn;
|
||||||
|
BOOLEAN bCurNavOn;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
BOOLEAN bPreAdcBackOff;
|
||||||
|
BOOLEAN bCurAdcBackOff;
|
||||||
|
BOOLEAN bPreAgcTableEn;
|
||||||
|
BOOLEAN bCurAgcTableEn;
|
||||||
|
//u4Byte preVal0x6c0;
|
||||||
|
//u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u4Byte preVal0x6cc;
|
||||||
|
u4Byte curVal0x6cc;
|
||||||
|
//BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
//u1Byte btStatus;
|
||||||
|
//u1Byte wifiChnlInfo[3];
|
||||||
|
} COEX_DM_8188C_2ANT, *PCOEX_DM_8188C_2ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8188C_2ANT{
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bBtBusy;
|
||||||
|
BOOLEAN bBtUplink;
|
||||||
|
BOOLEAN bBtDownLink;
|
||||||
|
BOOLEAN bA2dpBusy;
|
||||||
|
}COEX_STA_8188C_2ANT, *PCOEX_STA_8188C_2ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8188c2ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
2059
hal/OUTSRC-BTCoexist/HalBtc8192d2Ant.c
Normal file
2059
hal/OUTSRC-BTCoexist/HalBtc8192d2Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
166
hal/OUTSRC-BTCoexist/HalBtc8192d2Ant.h
Normal file
166
hal/OUTSRC-BTCoexist/HalBtc8192d2Ant.h
Normal file
@ -0,0 +1,166 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8192D 2Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8192D_2ANT 6
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8192D_2ANT{
|
||||||
|
BT_INFO_SRC_8192D_2ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8192D_2ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8192D_2ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8192D_2ANT_MAX
|
||||||
|
}BT_INFO_SRC_8192D_2ANT,*PBT_INFO_SRC_8192D_2ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8192D_2ANT_BT_STATUS{
|
||||||
|
BT_8192D_2ANT_BT_STATUS_IDLE = 0x0,
|
||||||
|
BT_8192D_2ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8192D_2ANT_BT_STATUS_NON_IDLE = 0x2,
|
||||||
|
BT_8192D_2ANT_BT_STATUS_MAX
|
||||||
|
}BT_8192D_2ANT_BT_STATUS,*PBT_8192D_2ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8192D_2ANT_COEX_ALGO{
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_PAN = 0x4,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_HID_A2DP = 0x5,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_HID_PAN = 0x6,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_PAN_A2DP = 0x7,
|
||||||
|
BT_8192D_2ANT_COEX_ALGO_MAX
|
||||||
|
}BT_8192D_2ANT_COEX_ALGO,*PBT_8192D_2ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8192D_2ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bPreBalanceOn;
|
||||||
|
BOOLEAN bCurBalanceOn;
|
||||||
|
|
||||||
|
// diminishWifi
|
||||||
|
BOOLEAN bPreDacOn;
|
||||||
|
BOOLEAN bCurDacOn;
|
||||||
|
BOOLEAN bPreInterruptOn;
|
||||||
|
BOOLEAN bCurInterruptOn;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bPreNavOn;
|
||||||
|
BOOLEAN bCurNavOn;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//BOOLEAN bPreDecBtPwr;
|
||||||
|
//BOOLEAN bCurDecBtPwr;
|
||||||
|
|
||||||
|
//u1Byte preFwDacSwingLvl;
|
||||||
|
//u1Byte curFwDacSwingLvl;
|
||||||
|
//BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
//BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
//u1Byte prePsTdma;
|
||||||
|
//u1Byte curPsTdma;
|
||||||
|
//u1Byte psTdmaPara[5];
|
||||||
|
//u1Byte psTdmaDuAdjType;
|
||||||
|
//BOOLEAN bResetTdmaAdjust;
|
||||||
|
//BOOLEAN bPrePsTdmaOn;
|
||||||
|
//BOOLEAN bCurPsTdmaOn;
|
||||||
|
//BOOLEAN bPreBtAutoReport;
|
||||||
|
//BOOLEAN bCurBtAutoReport;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
BOOLEAN bPreAdcBackOff;
|
||||||
|
BOOLEAN bCurAdcBackOff;
|
||||||
|
BOOLEAN bPreAgcTableEn;
|
||||||
|
BOOLEAN bCurAgcTableEn;
|
||||||
|
//u4Byte preVal0x6c0;
|
||||||
|
//u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u4Byte preVal0x6cc;
|
||||||
|
u4Byte curVal0x6cc;
|
||||||
|
//BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
//u1Byte btStatus;
|
||||||
|
//u1Byte wifiChnlInfo[3];
|
||||||
|
} COEX_DM_8192D_2ANT, *PCOEX_DM_8192D_2ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8192D_2ANT{
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bBtBusy;
|
||||||
|
BOOLEAN bBtUplink;
|
||||||
|
BOOLEAN bBtDownLink;
|
||||||
|
BOOLEAN bA2dpBusy;
|
||||||
|
}COEX_STA_8192D_2ANT, *PCOEX_STA_8192D_2ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192d2ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
3282
hal/OUTSRC-BTCoexist/HalBtc8192e1Ant.c
Normal file
3282
hal/OUTSRC-BTCoexist/HalBtc8192e1Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
210
hal/OUTSRC-BTCoexist/HalBtc8192e1Ant.h
Normal file
210
hal/OUTSRC-BTCoexist/HalBtc8192e1Ant.h
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8192E_1ANT BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_AUTO_REPORT_ONLY_8192E_1ANT 0
|
||||||
|
|
||||||
|
#define BT_INFO_8192E_1ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8192E_1ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8192E_1ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8192E_1ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8192E_1ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8192E_1ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8192E_1ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8192E_1ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BT_INFO_8192E_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_) \
|
||||||
|
(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8192E_1ANT{
|
||||||
|
BT_INFO_SRC_8192E_1ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8192E_1ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8192E_1ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8192E_1ANT_MAX
|
||||||
|
}BT_INFO_SRC_8192E_1ANT,*PBT_INFO_SRC_8192E_1ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8192E_1ANT_BT_STATUS{
|
||||||
|
BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8192E_1ANT_BT_STATUS_INQ_PAGE = 0x2,
|
||||||
|
BT_8192E_1ANT_BT_STATUS_ACL_BUSY = 0x3,
|
||||||
|
BT_8192E_1ANT_BT_STATUS_SCO_BUSY = 0x4,
|
||||||
|
BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY = 0x5,
|
||||||
|
BT_8192E_1ANT_BT_STATUS_MAX
|
||||||
|
}BT_8192E_1ANT_BT_STATUS,*PBT_8192E_1ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8192E_1ANT_WIFI_STATUS{
|
||||||
|
BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN = 0x1,
|
||||||
|
BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN = 0x2,
|
||||||
|
BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT = 0x3,
|
||||||
|
BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE = 0x4,
|
||||||
|
BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY = 0x5,
|
||||||
|
BT_8192E_1ANT_WIFI_STATUS_MAX
|
||||||
|
}BT_8192E_1ANT_WIFI_STATUS,*PBT_8192E_1ANT_WIFI_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8192E_1ANT_COEX_ALGO{
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS = 0x4,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_PANEDR = 0x5,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_PANHS = 0x6,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP = 0x7,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_PANEDR_HID = 0x8,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x9,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_HID_A2DP = 0xa,
|
||||||
|
BT_8192E_1ANT_COEX_ALGO_MAX = 0xb,
|
||||||
|
}BT_8192E_1ANT_COEX_ALGO,*PBT_8192E_1ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8192E_1ANT{
|
||||||
|
// fw mechanism
|
||||||
|
u1Byte preBtDecPwrLvl;
|
||||||
|
u1Byte curBtDecPwrLvl;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bAutoTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
u1Byte preLps;
|
||||||
|
u1Byte curLps;
|
||||||
|
u1Byte preRpwm;
|
||||||
|
u1Byte curRpwm;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
|
||||||
|
u1Byte preSsType;
|
||||||
|
u1Byte curSsType;
|
||||||
|
|
||||||
|
u4Byte preRaMask;
|
||||||
|
u4Byte curRaMask;
|
||||||
|
|
||||||
|
u1Byte errorCondition;
|
||||||
|
} COEX_DM_8192E_1ANT, *PCOEX_DM_8192E_1ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8192E_1ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8192E_1ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8192E_1ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8192E_1ANT, *PCOEX_STA_8192E_1ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_PnpNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte pnpState
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e1ant_DbgControl(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte opCode,
|
||||||
|
IN u1Byte opLen,
|
||||||
|
IN pu1Byte pData
|
||||||
|
);
|
4399
hal/OUTSRC-BTCoexist/HalBtc8192e2Ant.c
Normal file
4399
hal/OUTSRC-BTCoexist/HalBtc8192e2Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
202
hal/OUTSRC-BTCoexist/HalBtc8192e2Ant.h
Normal file
202
hal/OUTSRC-BTCoexist/HalBtc8192e2Ant.h
Normal file
@ -0,0 +1,202 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8192E 2Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_AUTO_REPORT_ONLY_8192E_2ANT 0
|
||||||
|
|
||||||
|
#define BT_INFO_8192E_2ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8192E_2ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8192E_2ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8192E_2ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8192E_2ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8192E_2ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8192E_2ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8192E_2ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8192E_2ANT{
|
||||||
|
BT_INFO_SRC_8192E_2ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8192E_2ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8192E_2ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8192E_2ANT_MAX
|
||||||
|
}BT_INFO_SRC_8192E_2ANT,*PBT_INFO_SRC_8192E_2ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8192E_2ANT_BT_STATUS{
|
||||||
|
BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8192E_2ANT_BT_STATUS_INQ_PAGE = 0x2,
|
||||||
|
BT_8192E_2ANT_BT_STATUS_ACL_BUSY = 0x3,
|
||||||
|
BT_8192E_2ANT_BT_STATUS_SCO_BUSY = 0x4,
|
||||||
|
BT_8192E_2ANT_BT_STATUS_ACL_SCO_BUSY = 0x5,
|
||||||
|
BT_8192E_2ANT_BT_STATUS_MAX
|
||||||
|
}BT_8192E_2ANT_BT_STATUS,*PBT_8192E_2ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8192E_2ANT_COEX_ALGO{
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_SCO_PAN = 0x2,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_HID = 0x3,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_A2DP = 0x4,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS = 0x5,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_PANEDR = 0x6,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_PANHS = 0x7,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP = 0x8,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_PANEDR_HID = 0x9,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR = 0xa,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_HID_A2DP = 0xb,
|
||||||
|
BT_8192E_2ANT_COEX_ALGO_MAX = 0xc
|
||||||
|
}BT_8192E_2ANT_COEX_ALGO,*PBT_8192E_2ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8192E_2ANT{
|
||||||
|
// fw mechanism
|
||||||
|
u1Byte preBtDecPwrLvl;
|
||||||
|
u1Byte curBtDecPwrLvl;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bResetTdmaAdjust;
|
||||||
|
BOOLEAN bAutoTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
BOOLEAN bPreAdcBackOff;
|
||||||
|
BOOLEAN bCurAdcBackOff;
|
||||||
|
BOOLEAN bPreAgcTableEn;
|
||||||
|
BOOLEAN bCurAgcTableEn;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
u4Byte backupArfrCnt1; // Auto Rate Fallback Retry cnt
|
||||||
|
u4Byte backupArfrCnt2; // Auto Rate Fallback Retry cnt
|
||||||
|
u2Byte backupRetryLimit;
|
||||||
|
u1Byte backupAmpduMaxTime;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
|
||||||
|
u1Byte preSsType;
|
||||||
|
u1Byte curSsType;
|
||||||
|
|
||||||
|
u4Byte preRaMask;
|
||||||
|
u4Byte curRaMask;
|
||||||
|
u1Byte curRaMaskType;
|
||||||
|
u1Byte preArfrType;
|
||||||
|
u1Byte curArfrType;
|
||||||
|
u1Byte preRetryLimitType;
|
||||||
|
u1Byte curRetryLimitType;
|
||||||
|
u1Byte preAmpduTimeType;
|
||||||
|
u1Byte curAmpduTimeType;
|
||||||
|
} COEX_DM_8192E_2ANT, *PCOEX_DM_8192E_2ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8192E_2ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8192E_2ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8192E_2ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8192E_2ANT, *PCOEX_STA_8192E_2ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8192e2ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
|
1598
hal/OUTSRC-BTCoexist/HalBtc8723a1Ant.c
Normal file
1598
hal/OUTSRC-BTCoexist/HalBtc8723a1Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
171
hal/OUTSRC-BTCoexist/HalBtc8723a1Ant.h
Normal file
171
hal/OUTSRC-BTCoexist/HalBtc8723a1Ant.h
Normal file
@ -0,0 +1,171 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8723A 1Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_INFO_8723A_1ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8723A_1ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8723A_1ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8723A_1ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8723A_1ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8723A_1ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8723A_1ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8723A_1ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
typedef enum _BT_STATE_8723A_1ANT{
|
||||||
|
BT_STATE_8723A_1ANT_DISABLED = 0,
|
||||||
|
BT_STATE_8723A_1ANT_NO_CONNECTION = 1,
|
||||||
|
BT_STATE_8723A_1ANT_CONNECT_IDLE = 2,
|
||||||
|
BT_STATE_8723A_1ANT_INQ_OR_PAG = 3,
|
||||||
|
BT_STATE_8723A_1ANT_ACL_ONLY_BUSY = 4,
|
||||||
|
BT_STATE_8723A_1ANT_SCO_ONLY_BUSY = 5,
|
||||||
|
BT_STATE_8723A_1ANT_ACL_SCO_BUSY = 6,
|
||||||
|
BT_STATE_8723A_1ANT_HID_BUSY = 7,
|
||||||
|
BT_STATE_8723A_1ANT_HID_SCO_BUSY = 8,
|
||||||
|
BT_STATE_8723A_1ANT_MAX
|
||||||
|
}BT_STATE_8723A_1ANT, *PBT_STATE_8723A_1ANT;
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8723A_1ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8723A_1ANT{
|
||||||
|
BT_INFO_SRC_8723A_1ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8723A_1ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8723A_1ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8723A_1ANT_MAX
|
||||||
|
}BT_INFO_SRC_8723A_1ANT,*PBT_INFO_SRC_8723A_1ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8723A_1ANT_BT_STATUS{
|
||||||
|
BT_8723A_1ANT_BT_STATUS_IDLE = 0x0,
|
||||||
|
BT_8723A_1ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8723A_1ANT_BT_STATUS_NON_IDLE = 0x2,
|
||||||
|
BT_8723A_1ANT_BT_STATUS_MAX
|
||||||
|
}BT_8723A_1ANT_BT_STATUS,*PBT_8723A_1ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8723A_1ANT_COEX_ALGO{
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_PANEDR = 0x4,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_PANHS = 0x5,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_PANEDR_A2DP = 0x6,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_PANEDR_HID = 0x7,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x8,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_HID_A2DP = 0x9,
|
||||||
|
BT_8723A_1ANT_COEX_ALGO_MAX
|
||||||
|
}BT_8723A_1ANT_COEX_ALGO,*PBT_8723A_1ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8723A_1ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
u4Byte psTdmaMonitorCnt;
|
||||||
|
u4Byte psTdmaGlobalCnt;
|
||||||
|
BOOLEAN bResetTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
} COEX_DM_8723A_1ANT, *PCOEX_DM_8723A_1ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8723A_1ANT{
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preBtRssiState1;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8723A_1ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8723A_1ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
//BOOLEAN bHoldForStackOperation;
|
||||||
|
//u1Byte bHoldPeriodCnt;
|
||||||
|
// this is for c2h hang work-around
|
||||||
|
u4Byte c2hHangDetectCnt;
|
||||||
|
}COEX_STA_8723A_1ANT, *PCOEX_STA_8723A_1ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a1ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
|
3831
hal/OUTSRC-BTCoexist/HalBtc8723a2Ant.c
Normal file
3831
hal/OUTSRC-BTCoexist/HalBtc8723a2Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
180
hal/OUTSRC-BTCoexist/HalBtc8723a2Ant.h
Normal file
180
hal/OUTSRC-BTCoexist/HalBtc8723a2Ant.h
Normal file
@ -0,0 +1,180 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8723A 2Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_INFO_8723A_2ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8723A_2ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8723A_2ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8723A_2ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8723A_2ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8723A_2ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8723A_2ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8723A_2ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8723A_2ANT{
|
||||||
|
BT_INFO_SRC_8723A_2ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8723A_2ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8723A_2ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8723A_2ANT_MAX
|
||||||
|
}BT_INFO_SRC_8723A_2ANT,*PBT_INFO_SRC_8723A_2ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8723A_2ANT_BT_STATUS{
|
||||||
|
BT_8723A_2ANT_BT_STATUS_IDLE = 0x0,
|
||||||
|
BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8723A_2ANT_BT_STATUS_NON_IDLE = 0x2,
|
||||||
|
BT_8723A_2ANT_BT_STATUS_MAX
|
||||||
|
}BT_8723A_2ANT_BT_STATUS,*PBT_8723A_2ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8723A_2ANT_COEX_ALGO{
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_PANEDR = 0x4,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_PANHS = 0x5,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_PANEDR_A2DP = 0x6,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_PANEDR_HID = 0x7,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x8,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_HID_A2DP = 0x9,
|
||||||
|
BT_8723A_2ANT_COEX_ALGO_MAX
|
||||||
|
}BT_8723A_2ANT_COEX_ALGO,*PBT_8723A_2ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8723A_2ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bPreDecBtPwr;
|
||||||
|
BOOLEAN bCurDecBtPwr;
|
||||||
|
//BOOLEAN bPreBtLnaConstrain;
|
||||||
|
//BOOLEAN bCurBtLnaConstrain;
|
||||||
|
//u1Byte bPreBtPsdMode;
|
||||||
|
//u1Byte bCurBtPsdMode;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bResetTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
//BOOLEAN bPreBtAutoReport;
|
||||||
|
//BOOLEAN bCurBtAutoReport;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
BOOLEAN bPreAdcBackOff;
|
||||||
|
BOOLEAN bCurAdcBackOff;
|
||||||
|
BOOLEAN bPreAgcTableEn;
|
||||||
|
BOOLEAN bCurAgcTableEn;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
} COEX_DM_8723A_2ANT, *PCOEX_DM_8723A_2ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8723A_2ANT{
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preBtRssiState1;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8723A_2ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8723A_2ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
BOOLEAN bHoldForStackOperation;
|
||||||
|
u1Byte bHoldPeriodCnt;
|
||||||
|
// this is for c2h hang work-around
|
||||||
|
u4Byte c2hHangDetectCnt;
|
||||||
|
}COEX_STA_8723A_2ANT, *PCOEX_STA_8723A_2ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_StackOperationNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723a2ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
|
3766
hal/OUTSRC-BTCoexist/HalBtc8723b1Ant.c
Normal file
3766
hal/OUTSRC-BTCoexist/HalBtc8723b1Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
214
hal/OUTSRC-BTCoexist/HalBtc8723b1Ant.h
Normal file
214
hal/OUTSRC-BTCoexist/HalBtc8723b1Ant.h
Normal file
@ -0,0 +1,214 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8723B 1ANT BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_AUTO_REPORT_ONLY_8723B_1ANT 1
|
||||||
|
|
||||||
|
#define BT_INFO_8723B_1ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8723B_1ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8723B_1ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8723B_1ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8723B_1ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8723B_1ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8723B_1ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8723B_1ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_) \
|
||||||
|
(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8723B_1ANT{
|
||||||
|
BT_INFO_SRC_8723B_1ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8723B_1ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8723B_1ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8723B_1ANT_MAX
|
||||||
|
}BT_INFO_SRC_8723B_1ANT,*PBT_INFO_SRC_8723B_1ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8723B_1ANT_BT_STATUS{
|
||||||
|
BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8723B_1ANT_BT_STATUS_INQ_PAGE = 0x2,
|
||||||
|
BT_8723B_1ANT_BT_STATUS_ACL_BUSY = 0x3,
|
||||||
|
BT_8723B_1ANT_BT_STATUS_SCO_BUSY = 0x4,
|
||||||
|
BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY = 0x5,
|
||||||
|
BT_8723B_1ANT_BT_STATUS_MAX
|
||||||
|
}BT_8723B_1ANT_BT_STATUS,*PBT_8723B_1ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8723B_1ANT_WIFI_STATUS{
|
||||||
|
BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN = 0x1,
|
||||||
|
BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN = 0x2,
|
||||||
|
BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT = 0x3,
|
||||||
|
BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE = 0x4,
|
||||||
|
BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY = 0x5,
|
||||||
|
BT_8723B_1ANT_WIFI_STATUS_MAX
|
||||||
|
}BT_8723B_1ANT_WIFI_STATUS,*PBT_8723B_1ANT_WIFI_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8723B_1ANT_COEX_ALGO{
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS = 0x4,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_PANEDR = 0x5,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_PANHS = 0x6,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP = 0x7,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_PANEDR_HID = 0x8,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x9,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_HID_A2DP = 0xa,
|
||||||
|
BT_8723B_1ANT_COEX_ALGO_MAX = 0xb,
|
||||||
|
}BT_8723B_1ANT_COEX_ALGO,*PBT_8723B_1ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8723B_1ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bAutoTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
u1Byte preLps;
|
||||||
|
u1Byte curLps;
|
||||||
|
u1Byte preRpwm;
|
||||||
|
u1Byte curRpwm;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
u4Byte backupArfrCnt1; // Auto Rate Fallback Retry cnt
|
||||||
|
u4Byte backupArfrCnt2; // Auto Rate Fallback Retry cnt
|
||||||
|
u2Byte backupRetryLimit;
|
||||||
|
u1Byte backupAmpduMaxTime;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
|
||||||
|
u4Byte preRaMask;
|
||||||
|
u4Byte curRaMask;
|
||||||
|
u1Byte preArfrType;
|
||||||
|
u1Byte curArfrType;
|
||||||
|
u1Byte preRetryLimitType;
|
||||||
|
u1Byte curRetryLimitType;
|
||||||
|
u1Byte preAmpduTimeType;
|
||||||
|
u1Byte curAmpduTimeType;
|
||||||
|
|
||||||
|
u1Byte errorCondition;
|
||||||
|
} COEX_DM_8723B_1ANT, *PCOEX_DM_8723B_1ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8723B_1ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
BOOLEAN bFinishInitHW;
|
||||||
|
u4Byte specialPktPeriodCnt;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
BOOLEAN bBtTxRxMask;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8723B_1ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8723B_1ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
BOOLEAN bC2hBtPage; //Add for win8.1 page out issue
|
||||||
|
BOOLEAN bWiFiIsHighPriTask; //Add for win8.1 page out issue
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8723B_1ANT, *PCOEX_STA_8723B_1ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_PnpNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte pnpState
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_CoexDmReset(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b1ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
|
4234
hal/OUTSRC-BTCoexist/HalBtc8723b2Ant.c
Normal file
4234
hal/OUTSRC-BTCoexist/HalBtc8723b2Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
193
hal/OUTSRC-BTCoexist/HalBtc8723b2Ant.h
Normal file
193
hal/OUTSRC-BTCoexist/HalBtc8723b2Ant.h
Normal file
@ -0,0 +1,193 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8723B 2Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_AUTO_REPORT_ONLY_8723B_2ANT 1
|
||||||
|
|
||||||
|
|
||||||
|
#define BT_INFO_8723B_2ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8723B_2ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8723B_2ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8723B_2ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8723B_2ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8723B_2ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8723B_2ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8723B_2ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8723B_2ANT{
|
||||||
|
BT_INFO_SRC_8723B_2ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8723B_2ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8723B_2ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8723B_2ANT_MAX
|
||||||
|
}BT_INFO_SRC_8723B_2ANT,*PBT_INFO_SRC_8723B_2ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8723B_2ANT_BT_STATUS{
|
||||||
|
BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8723B_2ANT_BT_STATUS_INQ_PAGE = 0x2,
|
||||||
|
BT_8723B_2ANT_BT_STATUS_ACL_BUSY = 0x3,
|
||||||
|
BT_8723B_2ANT_BT_STATUS_SCO_BUSY = 0x4,
|
||||||
|
BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY = 0x5,
|
||||||
|
BT_8723B_2ANT_BT_STATUS_MAX
|
||||||
|
}BT_8723B_2ANT_BT_STATUS,*PBT_8723B_2ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8723B_2ANT_COEX_ALGO{
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS = 0x4,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_PANEDR = 0x5,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_PANHS = 0x6,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP = 0x7,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_PANEDR_HID = 0x8,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x9,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_HID_A2DP = 0xa,
|
||||||
|
BT_8723B_2ANT_COEX_ALGO_MAX = 0xb,
|
||||||
|
}BT_8723B_2ANT_COEX_ALGO,*PBT_8723B_2ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8723B_2ANT{
|
||||||
|
// fw mechanism
|
||||||
|
u1Byte preBtDecPwrLvl;
|
||||||
|
u1Byte curBtDecPwrLvl;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bResetTdmaAdjust;
|
||||||
|
BOOLEAN bAutoTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
BOOLEAN bPreAdcBackOff;
|
||||||
|
BOOLEAN bCurAdcBackOff;
|
||||||
|
BOOLEAN bPreAgcTableEn;
|
||||||
|
BOOLEAN bCurAgcTableEn;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
|
||||||
|
BOOLEAN bNeedRecover0x948;
|
||||||
|
u4Byte backup0x948;
|
||||||
|
} COEX_DM_8723B_2ANT, *PCOEX_DM_8723B_2ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8723B_2ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
BOOLEAN bBtTxRxMask;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8723B_2ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8723B_2ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8723B_2ANT, *PCOEX_STA_8723B_2ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_PnpNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte pnpState
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8723b2ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
|
2974
hal/OUTSRC-BTCoexist/HalBtc8812a1Ant.c
Normal file
2974
hal/OUTSRC-BTCoexist/HalBtc8812a1Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
202
hal/OUTSRC-BTCoexist/HalBtc8812a1Ant.h
Normal file
202
hal/OUTSRC-BTCoexist/HalBtc8812a1Ant.h
Normal file
@ -0,0 +1,202 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8812A_1ANT BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_INFO_8812A_1ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8812A_1ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8812A_1ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8812A_1ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8812A_1ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8812A_1ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8812A_1ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8812A_1ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BT_INFO_8812A_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_) \
|
||||||
|
(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT 2
|
||||||
|
|
||||||
|
#define BTC_8812A_1ANT_SWITCH_TO_WIFI 0
|
||||||
|
#define BTC_8812A_1ANT_SWITCH_TO_BT 1
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8812A_1ANT{
|
||||||
|
BT_INFO_SRC_8812A_1ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8812A_1ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8812A_1ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8812A_1ANT_MAX
|
||||||
|
}BT_INFO_SRC_8812A_1ANT,*PBT_INFO_SRC_8812A_1ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8812A_1ANT_BT_STATUS{
|
||||||
|
BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8812A_1ANT_BT_STATUS_INQ_PAGE = 0x2,
|
||||||
|
BT_8812A_1ANT_BT_STATUS_ACL_BUSY = 0x3,
|
||||||
|
BT_8812A_1ANT_BT_STATUS_SCO_BUSY = 0x4,
|
||||||
|
BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY = 0x5,
|
||||||
|
BT_8812A_1ANT_BT_STATUS_MAX
|
||||||
|
}BT_8812A_1ANT_BT_STATUS,*PBT_8812A_1ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8812A_1ANT_WIFI_STATUS{
|
||||||
|
BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN = 0x1,
|
||||||
|
BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN = 0x2,
|
||||||
|
BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT = 0x3,
|
||||||
|
BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE = 0x4,
|
||||||
|
BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY = 0x5,
|
||||||
|
BT_8812A_1ANT_WIFI_STATUS_MAX
|
||||||
|
}BT_8812A_1ANT_WIFI_STATUS,*PBT_8812A_1ANT_WIFI_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8812A_1ANT_COEX_ALGO{
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS = 0x4,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_PANEDR = 0x5,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_PANHS = 0x6,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP = 0x7,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_PANEDR_HID = 0x8,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x9,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_HID_A2DP = 0xa,
|
||||||
|
BT_8812A_1ANT_COEX_ALGO_MAX = 0xb,
|
||||||
|
}BT_8812A_1ANT_COEX_ALGO,*PBT_8812A_1ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8812A_1ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bResetTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
u1Byte preLps;
|
||||||
|
u1Byte curLps;
|
||||||
|
u1Byte preRpwm;
|
||||||
|
u1Byte curRpwm;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
|
||||||
|
u4Byte preRaMask;
|
||||||
|
u4Byte curRaMask;
|
||||||
|
|
||||||
|
u1Byte errorCondition;
|
||||||
|
} COEX_DM_8812A_1ANT, *PCOEX_DM_8812A_1ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8812A_1ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8812A_1ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8812A_1ANT_MAX];
|
||||||
|
u4Byte btInfoQueryCnt;
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8812A_1ANT, *PCOEX_STA_8812A_1ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_PnpNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte pnpState
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a1ant_DbgControl(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte opCode,
|
||||||
|
IN u1Byte opLen,
|
||||||
|
IN pu1Byte pData
|
||||||
|
);
|
4827
hal/OUTSRC-BTCoexist/HalBtc8812a2Ant.c
Normal file
4827
hal/OUTSRC-BTCoexist/HalBtc8812a2Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
214
hal/OUTSRC-BTCoexist/HalBtc8812a2Ant.h
Normal file
214
hal/OUTSRC-BTCoexist/HalBtc8812a2Ant.h
Normal file
@ -0,0 +1,214 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8812A 2Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_AUTO_REPORT_ONLY_8812A_2ANT 0
|
||||||
|
|
||||||
|
#define BT_INFO_8812A_2ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8812A_2ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8812A_2ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8812A_2ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8812A_2ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8812A_2ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8812A_2ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8812A_2ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_) \
|
||||||
|
(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8812A_2ANT{
|
||||||
|
BT_INFO_SRC_8812A_2ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8812A_2ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8812A_2ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8812A_2ANT_MAX
|
||||||
|
}BT_INFO_SRC_8812A_2ANT,*PBT_INFO_SRC_8812A_2ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8812A_2ANT_BT_STATUS{
|
||||||
|
BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8812A_2ANT_BT_STATUS_INQ_PAGE = 0x2,
|
||||||
|
BT_8812A_2ANT_BT_STATUS_ACL_BUSY = 0x3,
|
||||||
|
BT_8812A_2ANT_BT_STATUS_SCO_BUSY = 0x4,
|
||||||
|
BT_8812A_2ANT_BT_STATUS_ACL_SCO_BUSY = 0x5,
|
||||||
|
BT_8812A_2ANT_BT_STATUS_MAX
|
||||||
|
}BT_8812A_2ANT_BT_STATUS,*PBT_8812A_2ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8812A_2ANT_COEX_ALGO{
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_SCO_HID = 0x2,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_HID = 0x3,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_A2DP = 0x4,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS = 0x5,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_PANEDR = 0x6,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_PANHS = 0x7,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP = 0x8,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_PANEDR_HID = 0x9,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR = 0xa,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS = 0xb,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_HID_A2DP = 0xc,
|
||||||
|
BT_8812A_2ANT_COEX_ALGO_MAX = 0xd
|
||||||
|
}BT_8812A_2ANT_COEX_ALGO,*PBT_8812A_2ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8812A_2ANT{
|
||||||
|
// fw mechanism
|
||||||
|
u1Byte preBtDecPwrLvl;
|
||||||
|
u1Byte curBtDecPwrLvl;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bAutoTdmaAdjust;
|
||||||
|
BOOLEAN bAutoTdmaAdjustLowRssi;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
u1Byte preLps;
|
||||||
|
u1Byte curLps;
|
||||||
|
u1Byte preRpwm;
|
||||||
|
u1Byte curRpwm;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
BOOLEAN bPreAdcBackOff;
|
||||||
|
BOOLEAN bCurAdcBackOff;
|
||||||
|
BOOLEAN bPreAgcTableEn;
|
||||||
|
BOOLEAN bCurAgcTableEn;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
BOOLEAN bLimitedDig;
|
||||||
|
u4Byte backupArfrCnt1; // Auto Rate Fallback Retry cnt
|
||||||
|
u4Byte backupArfrCnt2; // Auto Rate Fallback Retry cnt
|
||||||
|
u2Byte backupRetryLimit;
|
||||||
|
u1Byte backupAmpduMaxTime;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
|
||||||
|
u4Byte preRaMask;
|
||||||
|
u4Byte curRaMask;
|
||||||
|
u1Byte curRaMaskType;
|
||||||
|
u1Byte preArfrType;
|
||||||
|
u1Byte curArfrType;
|
||||||
|
u1Byte preRetryLimitType;
|
||||||
|
u1Byte curRetryLimitType;
|
||||||
|
u1Byte preAmpduTimeType;
|
||||||
|
u1Byte curAmpduTimeType;
|
||||||
|
} COEX_DM_8812A_2ANT, *PCOEX_DM_8812A_2ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8812A_2ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8812A_2ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8812A_2ANT_MAX];
|
||||||
|
u4Byte btInfoQueryCnt;
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8812A_2ANT, *PCOEX_STA_8812A_2ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8812a2ant_DbgControl(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte opCode,
|
||||||
|
IN u1Byte opLen,
|
||||||
|
IN pu1Byte pData
|
||||||
|
);
|
||||||
|
|
3200
hal/OUTSRC-BTCoexist/HalBtc8821a1Ant.c
Normal file
3200
hal/OUTSRC-BTCoexist/HalBtc8821a1Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
211
hal/OUTSRC-BTCoexist/HalBtc8821a1Ant.h
Normal file
211
hal/OUTSRC-BTCoexist/HalBtc8821a1Ant.h
Normal file
@ -0,0 +1,211 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8821A 1ANT BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_AUTO_REPORT_ONLY_8821A_1ANT 0
|
||||||
|
|
||||||
|
#define BT_INFO_8821A_1ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8821A_1ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8821A_1ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8821A_1ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8821A_1ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8821A_1ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8821A_1ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8821A_1ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BT_INFO_8821A_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_) \
|
||||||
|
(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8821A_1ANT{
|
||||||
|
BT_INFO_SRC_8821A_1ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8821A_1ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8821A_1ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8821A_1ANT_MAX
|
||||||
|
}BT_INFO_SRC_8821A_1ANT,*PBT_INFO_SRC_8821A_1ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8821A_1ANT_BT_STATUS{
|
||||||
|
BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8821A_1ANT_BT_STATUS_INQ_PAGE = 0x2,
|
||||||
|
BT_8821A_1ANT_BT_STATUS_ACL_BUSY = 0x3,
|
||||||
|
BT_8821A_1ANT_BT_STATUS_SCO_BUSY = 0x4,
|
||||||
|
BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY = 0x5,
|
||||||
|
BT_8821A_1ANT_BT_STATUS_MAX
|
||||||
|
}BT_8821A_1ANT_BT_STATUS,*PBT_8821A_1ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8821A_1ANT_WIFI_STATUS{
|
||||||
|
BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE = 0x0,
|
||||||
|
BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN = 0x1,
|
||||||
|
BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN = 0x2,
|
||||||
|
BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT = 0x3,
|
||||||
|
BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE = 0x4,
|
||||||
|
BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY = 0x5,
|
||||||
|
BT_8821A_1ANT_WIFI_STATUS_MAX
|
||||||
|
}BT_8821A_1ANT_WIFI_STATUS,*PBT_8821A_1ANT_WIFI_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8821A_1ANT_COEX_ALGO{
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS = 0x4,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_PANEDR = 0x5,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_PANHS = 0x6,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP = 0x7,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_PANEDR_HID = 0x8,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x9,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_HID_A2DP = 0xa,
|
||||||
|
BT_8821A_1ANT_COEX_ALGO_MAX = 0xb,
|
||||||
|
}BT_8821A_1ANT_COEX_ALGO,*PBT_8821A_1ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8821A_1ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bAutoTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
u1Byte preLps;
|
||||||
|
u1Byte curLps;
|
||||||
|
u1Byte preRpwm;
|
||||||
|
u1Byte curRpwm;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
|
||||||
|
u4Byte backupArfrCnt1; // Auto Rate Fallback Retry cnt
|
||||||
|
u4Byte backupArfrCnt2; // Auto Rate Fallback Retry cnt
|
||||||
|
u2Byte backupRetryLimit;
|
||||||
|
u1Byte backupAmpduMaxTime;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
|
||||||
|
u4Byte preRaMask;
|
||||||
|
u4Byte curRaMask;
|
||||||
|
u1Byte preArfrType;
|
||||||
|
u1Byte curArfrType;
|
||||||
|
u1Byte preRetryLimitType;
|
||||||
|
u1Byte curRetryLimitType;
|
||||||
|
u1Byte preAmpduTimeType;
|
||||||
|
u1Byte curAmpduTimeType;
|
||||||
|
|
||||||
|
u1Byte errorCondition;
|
||||||
|
} COEX_DM_8821A_1ANT, *PCOEX_DM_8821A_1ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8821A_1ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
u4Byte specialPktPeriodCnt;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8821A_1ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8821A_1ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8821A_1ANT, *PCOEX_STA_8821A_1ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_PnpNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte pnpState
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a1ant_DbgControl(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte opCode,
|
||||||
|
IN u1Byte opLen,
|
||||||
|
IN pu1Byte pData
|
||||||
|
);
|
4140
hal/OUTSRC-BTCoexist/HalBtc8821a2Ant.c
Normal file
4140
hal/OUTSRC-BTCoexist/HalBtc8821a2Ant.c
Normal file
File diff suppressed because it is too large
Load Diff
182
hal/OUTSRC-BTCoexist/HalBtc8821a2Ant.h
Normal file
182
hal/OUTSRC-BTCoexist/HalBtc8821a2Ant.h
Normal file
@ -0,0 +1,182 @@
|
|||||||
|
//===========================================
|
||||||
|
// The following is for 8821A 2Ant BT Co-exist definition
|
||||||
|
//===========================================
|
||||||
|
#define BT_INFO_8821A_2ANT_B_FTP BIT7
|
||||||
|
#define BT_INFO_8821A_2ANT_B_A2DP BIT6
|
||||||
|
#define BT_INFO_8821A_2ANT_B_HID BIT5
|
||||||
|
#define BT_INFO_8821A_2ANT_B_SCO_BUSY BIT4
|
||||||
|
#define BT_INFO_8821A_2ANT_B_ACL_BUSY BIT3
|
||||||
|
#define BT_INFO_8821A_2ANT_B_INQ_PAGE BIT2
|
||||||
|
#define BT_INFO_8821A_2ANT_B_SCO_ESCO BIT1
|
||||||
|
#define BT_INFO_8821A_2ANT_B_CONNECTION BIT0
|
||||||
|
|
||||||
|
#define BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT 2
|
||||||
|
|
||||||
|
typedef enum _BT_INFO_SRC_8821A_2ANT{
|
||||||
|
BT_INFO_SRC_8821A_2ANT_WIFI_FW = 0x0,
|
||||||
|
BT_INFO_SRC_8821A_2ANT_BT_RSP = 0x1,
|
||||||
|
BT_INFO_SRC_8821A_2ANT_BT_ACTIVE_SEND = 0x2,
|
||||||
|
BT_INFO_SRC_8821A_2ANT_MAX
|
||||||
|
}BT_INFO_SRC_8821A_2ANT,*PBT_INFO_SRC_8821A_2ANT;
|
||||||
|
|
||||||
|
typedef enum _BT_8821A_2ANT_BT_STATUS{
|
||||||
|
BT_8821A_2ANT_BT_STATUS_IDLE = 0x0,
|
||||||
|
BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE = 0x1,
|
||||||
|
BT_8821A_2ANT_BT_STATUS_NON_IDLE = 0x2,
|
||||||
|
BT_8821A_2ANT_BT_STATUS_MAX
|
||||||
|
}BT_8821A_2ANT_BT_STATUS,*PBT_8821A_2ANT_BT_STATUS;
|
||||||
|
|
||||||
|
typedef enum _BT_8821A_2ANT_COEX_ALGO{
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_UNDEFINED = 0x0,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_SCO = 0x1,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_HID = 0x2,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_A2DP = 0x3,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS = 0x4,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_PANEDR = 0x5,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_PANHS = 0x6,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP = 0x7,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_PANEDR_HID = 0x8,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR = 0x9,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_HID_A2DP = 0xa,
|
||||||
|
BT_8821A_2ANT_COEX_ALGO_MAX = 0xb,
|
||||||
|
}BT_8821A_2ANT_COEX_ALGO,*PBT_8821A_2ANT_COEX_ALGO;
|
||||||
|
|
||||||
|
typedef struct _COEX_DM_8821A_2ANT{
|
||||||
|
// fw mechanism
|
||||||
|
BOOLEAN bPreDecBtPwr;
|
||||||
|
BOOLEAN bCurDecBtPwr;
|
||||||
|
u1Byte preFwDacSwingLvl;
|
||||||
|
u1Byte curFwDacSwingLvl;
|
||||||
|
BOOLEAN bCurIgnoreWlanAct;
|
||||||
|
BOOLEAN bPreIgnoreWlanAct;
|
||||||
|
u1Byte prePsTdma;
|
||||||
|
u1Byte curPsTdma;
|
||||||
|
u1Byte psTdmaPara[5];
|
||||||
|
u1Byte psTdmaDuAdjType;
|
||||||
|
BOOLEAN bResetTdmaAdjust;
|
||||||
|
BOOLEAN bPrePsTdmaOn;
|
||||||
|
BOOLEAN bCurPsTdmaOn;
|
||||||
|
BOOLEAN bPreBtAutoReport;
|
||||||
|
BOOLEAN bCurBtAutoReport;
|
||||||
|
|
||||||
|
// sw mechanism
|
||||||
|
BOOLEAN bPreRfRxLpfShrink;
|
||||||
|
BOOLEAN bCurRfRxLpfShrink;
|
||||||
|
u4Byte btRf0x1eBackup;
|
||||||
|
BOOLEAN bPreLowPenaltyRa;
|
||||||
|
BOOLEAN bCurLowPenaltyRa;
|
||||||
|
BOOLEAN bPreDacSwingOn;
|
||||||
|
u4Byte preDacSwingLvl;
|
||||||
|
BOOLEAN bCurDacSwingOn;
|
||||||
|
u4Byte curDacSwingLvl;
|
||||||
|
BOOLEAN bPreAdcBackOff;
|
||||||
|
BOOLEAN bCurAdcBackOff;
|
||||||
|
BOOLEAN bPreAgcTableEn;
|
||||||
|
BOOLEAN bCurAgcTableEn;
|
||||||
|
u4Byte preVal0x6c0;
|
||||||
|
u4Byte curVal0x6c0;
|
||||||
|
u4Byte preVal0x6c4;
|
||||||
|
u4Byte curVal0x6c4;
|
||||||
|
u4Byte preVal0x6c8;
|
||||||
|
u4Byte curVal0x6c8;
|
||||||
|
u1Byte preVal0x6cc;
|
||||||
|
u1Byte curVal0x6cc;
|
||||||
|
BOOLEAN bLimitedDig;
|
||||||
|
|
||||||
|
// algorithm related
|
||||||
|
u1Byte preAlgorithm;
|
||||||
|
u1Byte curAlgorithm;
|
||||||
|
u1Byte btStatus;
|
||||||
|
u1Byte wifiChnlInfo[3];
|
||||||
|
} COEX_DM_8821A_2ANT, *PCOEX_DM_8821A_2ANT;
|
||||||
|
|
||||||
|
typedef struct _COEX_STA_8821A_2ANT{
|
||||||
|
BOOLEAN bBtLinkExist;
|
||||||
|
BOOLEAN bScoExist;
|
||||||
|
BOOLEAN bA2dpExist;
|
||||||
|
BOOLEAN bHidExist;
|
||||||
|
BOOLEAN bPanExist;
|
||||||
|
|
||||||
|
BOOLEAN bUnderLps;
|
||||||
|
BOOLEAN bUnderIps;
|
||||||
|
u4Byte highPriorityTx;
|
||||||
|
u4Byte highPriorityRx;
|
||||||
|
u4Byte lowPriorityTx;
|
||||||
|
u4Byte lowPriorityRx;
|
||||||
|
u1Byte btRssi;
|
||||||
|
u1Byte preBtRssiState;
|
||||||
|
u1Byte preWifiRssiState[4];
|
||||||
|
BOOLEAN bC2hBtInfoReqSent;
|
||||||
|
u1Byte btInfoC2h[BT_INFO_SRC_8821A_2ANT_MAX][10];
|
||||||
|
u4Byte btInfoC2hCnt[BT_INFO_SRC_8821A_2ANT_MAX];
|
||||||
|
BOOLEAN bC2hBtInquiryPage;
|
||||||
|
u1Byte btRetryCnt;
|
||||||
|
u1Byte btInfoExt;
|
||||||
|
}COEX_STA_8821A_2ANT, *PCOEX_STA_8821A_2ANT;
|
||||||
|
|
||||||
|
//===========================================
|
||||||
|
// The following is interface which will notify coex module.
|
||||||
|
//===========================================
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_InitHwConfig(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN BOOLEAN bWifiOnly
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_InitCoexDm(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_IpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_LpsNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_ScanNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_ConnectNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_MediaStatusNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_SpecialPacketNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte type
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_BtInfoNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN pu1Byte tmpBuf,
|
||||||
|
IN u1Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_HaltNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_PnpNotify(
|
||||||
|
IN PBTC_COEXIST pBtCoexist,
|
||||||
|
IN u1Byte pnpState
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_Periodical(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
EXhalbtc8821a2ant_DisplayCoexInfo(
|
||||||
|
IN PBTC_COEXIST pBtCoexist
|
||||||
|
);
|
||||||
|
|
708
hal/OUTSRC-BTCoexist/HalBtcOutSrc.h
Normal file
708
hal/OUTSRC-BTCoexist/HalBtcOutSrc.h
Normal file
File diff suppressed because it is too large
Load Diff
56
hal/OUTSRC-BTCoexist/Mp_Precomp.h
Normal file
56
hal/OUTSRC-BTCoexist/Mp_Precomp.h
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2013 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef __MP_PRECOMP_H__
|
||||||
|
#define __MP_PRECOMP_H__
|
||||||
|
|
||||||
|
#include <drv_types.h>
|
||||||
|
#include <hal_data.h>
|
||||||
|
|
||||||
|
#define BT_TMP_BUF_SIZE 100
|
||||||
|
|
||||||
|
#ifdef PLATFORM_LINUX
|
||||||
|
#define rsprintf snprintf
|
||||||
|
#elif defined(PLATFORM_WINDOWS)
|
||||||
|
#define rsprintf sprintf_s
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define DCMD_Printf DBG_BT_INFO
|
||||||
|
|
||||||
|
#define delay_ms(ms) rtw_mdelay_os(ms)
|
||||||
|
|
||||||
|
#ifdef bEnable
|
||||||
|
#undef bEnable
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "HalBtcOutSrc.h"
|
||||||
|
#include "HalBtc8188c2Ant.h"
|
||||||
|
#include "HalBtc8192d2Ant.h"
|
||||||
|
#include "HalBtc8192e1Ant.h"
|
||||||
|
#include "HalBtc8192e2Ant.h"
|
||||||
|
#include "HalBtc8723a1Ant.h"
|
||||||
|
#include "HalBtc8723a2Ant.h"
|
||||||
|
#include "HalBtc8723b1Ant.h"
|
||||||
|
#include "HalBtc8723b2Ant.h"
|
||||||
|
#include "HalBtc8812a1Ant.h"
|
||||||
|
#include "HalBtc8812a2Ant.h"
|
||||||
|
#include "HalBtc8821a1Ant.h"
|
||||||
|
#include "HalBtc8821a2Ant.h"
|
||||||
|
|
||||||
|
#endif // __MP_PRECOMP_H__
|
530
hal/OUTSRC/HalPhyRf.c
Normal file
530
hal/OUTSRC/HalPhyRf.c
Normal file
File diff suppressed because it is too large
Load Diff
89
hal/OUTSRC/HalPhyRf.h
Normal file
89
hal/OUTSRC/HalPhyRf.h
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __HAL_PHY_RF_H__
|
||||||
|
#define __HAL_PHY_RF_H__
|
||||||
|
|
||||||
|
typedef enum _SPUR_CAL_METHOD {
|
||||||
|
PLL_RESET,
|
||||||
|
AFE_PHASE_SEL
|
||||||
|
} SPUR_CAL_METHOD;
|
||||||
|
|
||||||
|
typedef enum _PWRTRACK_CONTROL_METHOD {
|
||||||
|
BBSWING,
|
||||||
|
TXAGC,
|
||||||
|
MIX_MODE
|
||||||
|
} PWRTRACK_METHOD;
|
||||||
|
|
||||||
|
typedef VOID (*FuncSetPwr)(PDM_ODM_T, PWRTRACK_METHOD, u1Byte, u1Byte);
|
||||||
|
typedef VOID (*FuncIQK)(PDM_ODM_T, u1Byte, u1Byte, u1Byte);
|
||||||
|
typedef VOID (*FuncLCK)(PDM_ODM_T);
|
||||||
|
typedef VOID (*FuncSwing)(PDM_ODM_T, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);
|
||||||
|
|
||||||
|
typedef struct _TXPWRTRACK_CFG {
|
||||||
|
u1Byte SwingTableSize_CCK;
|
||||||
|
u1Byte SwingTableSize_OFDM;
|
||||||
|
u1Byte Threshold_IQK;
|
||||||
|
u1Byte AverageThermalNum;
|
||||||
|
u1Byte RfPathCount;
|
||||||
|
u4Byte ThermalRegAddr;
|
||||||
|
FuncSetPwr ODM_TxPwrTrackSetPwr;
|
||||||
|
FuncIQK DoIQK;
|
||||||
|
FuncLCK PHY_LCCalibrate;
|
||||||
|
FuncSwing GetDeltaSwingTable;
|
||||||
|
} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;
|
||||||
|
|
||||||
|
void ConfigureTxpowerTrack(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT PTXPWRTRACK_CFG pConfig
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_ClearTxPowerTrackingState(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_TXPowerTrackingCallback_ThermalMeter(
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
#else
|
||||||
|
IN PADAPTER Adapter
|
||||||
|
#endif
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define ODM_TARGET_CHNL_NUM_2G_5G 59
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_ResetIQKResult(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
u1Byte
|
||||||
|
ODM_GetRightChnlPlaceforIQK(
|
||||||
|
IN u1Byte chnl
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
#endif // #ifndef __HAL_PHY_RF_H__
|
||||||
|
|
14198
hal/OUTSRC/odm.c
Normal file
14198
hal/OUTSRC/odm.c
Normal file
File diff suppressed because it is too large
Load Diff
2366
hal/OUTSRC/odm.h
Normal file
2366
hal/OUTSRC/odm.h
Normal file
File diff suppressed because it is too large
Load Diff
2269
hal/OUTSRC/odm_AntDiv.c
Normal file
2269
hal/OUTSRC/odm_AntDiv.c
Normal file
File diff suppressed because it is too large
Load Diff
136
hal/OUTSRC/odm_AntDiv.h
Normal file
136
hal/OUTSRC/odm_AntDiv.h
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ODMANTDIV_H__
|
||||||
|
#define __ODMANTDIV_H__
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define ANT1_2G 0 // = ANT2_5G
|
||||||
|
#define ANT2_2G 1 // = ANT1_5G
|
||||||
|
|
||||||
|
//Antenna Diversty Control Type
|
||||||
|
#define ODM_AUTO_ANT 0
|
||||||
|
#define ODM_FIX_MAIN_ANT 1
|
||||||
|
#define ODM_FIX_AUX_ANT 2
|
||||||
|
|
||||||
|
#define TX_BY_REG 0
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
|
||||||
|
#define ODM_RTL8881A 0 //Just for windows driver to jointly use ODM-driver
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define ODM_ANTDIV_SUPPORT (ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8723B|ODM_RTL8821|ODM_RTL8881A|ODM_RTL8812)
|
||||||
|
#define ODM_N_ANTDIV_SUPPORT (ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8723B)
|
||||||
|
#define ODM_AC_ANTDIV_SUPPORT (ODM_RTL8821|ODM_RTL8881A|ODM_RTL8812)
|
||||||
|
#define ODM_SMART_ANT_SUPPORT (ODM_RTL8188E|ODM_RTL8192E)
|
||||||
|
|
||||||
|
#define ODM_ANTDIV_2G_SUPPORT_IC (ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8723B|ODM_RTL8881A)
|
||||||
|
#define ODM_ANTDIV_5G_SUPPORT_IC (ODM_RTL8821|ODM_RTL8881A|ODM_RTL8812)
|
||||||
|
#define ODM_ANTDIV_2G BIT0
|
||||||
|
#define ODM_ANTDIV_5G BIT1
|
||||||
|
|
||||||
|
#define ANTDIV_ON 1
|
||||||
|
#define ANTDIV_OFF 0
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_AntDivInit(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_AntDiv(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#if (defined(CONFIG_HW_ANTENNA_DIVERSITY))
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_UpdateRxIdleAnt(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u1Byte Ant
|
||||||
|
);
|
||||||
|
|
||||||
|
#if (RTL8723B_SUPPORT == 1)||(RTL8821A_SUPPORT == 1)
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
||||||
|
VOID
|
||||||
|
ODM_SW_AntDiv_Callback(
|
||||||
|
IN PRT_TIMER pTimer
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_SW_AntDiv_WorkitemCallback(
|
||||||
|
IN PVOID pContext
|
||||||
|
);
|
||||||
|
#endif //#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
|
||||||
|
VOID
|
||||||
|
ODM_SW_AntDiv_Callback(void *FunctionContext);
|
||||||
|
#endif //#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if(RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
|
||||||
|
#if ( !(DM_ODM_SUPPORT_TYPE == ODM_CE))
|
||||||
|
VOID
|
||||||
|
odm_FastAntTraining(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_FastAntTrainingCallback(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_FastAntTrainingWorkItemCallback(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_Process_RSSIForAntDiv(
|
||||||
|
IN OUT PDM_ODM_T pDM_Odm,
|
||||||
|
IN PODM_PHY_INFO_T pPhyInfo,
|
||||||
|
IN PODM_PACKET_INFO_T pPktinfo
|
||||||
|
);
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
|
||||||
|
VOID
|
||||||
|
ODM_SetTxAntByTxInfo(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN pu1Byte pDesc,
|
||||||
|
IN u1Byte macId
|
||||||
|
);
|
||||||
|
|
||||||
|
#else// (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
VOID
|
||||||
|
ODM_SetTxAntByTxInfo(
|
||||||
|
//IN PDM_ODM_T pDM_Odm,
|
||||||
|
struct rtl8192cd_priv *priv,
|
||||||
|
struct tx_desc *pdesc,
|
||||||
|
struct tx_insn *txcfg,
|
||||||
|
unsigned short aid
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif //#if (defined(CONFIG_HW_ANTENNA_DIVERSITY))
|
||||||
|
#endif //#ifndef __ODMANTDIV_H__
|
2356
hal/OUTSRC/odm_HWConfig.c
Normal file
2356
hal/OUTSRC/odm_HWConfig.c
Normal file
File diff suppressed because it is too large
Load Diff
231
hal/OUTSRC/odm_HWConfig.h
Normal file
231
hal/OUTSRC/odm_HWConfig.h
Normal file
@ -0,0 +1,231 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __HALHWOUTSRC_H__
|
||||||
|
#define __HALHWOUTSRC_H__
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------Define -------------------------------------------*/
|
||||||
|
#define READ_NEXT_PAIR(v1, v2, i) do { i += 2; v1 = Array[i]; v2 = Array[i+1]; } while(0)
|
||||||
|
#define AGC_DIFF_CONFIG_MP(ic, band) (ODM_ReadAndConfig_MP_##ic##_AGC_TAB_DIFF(pDM_Odm, Array_MP_##ic##_AGC_TAB_DIFF_##band, \
|
||||||
|
sizeof(Array_MP_##ic##_AGC_TAB_DIFF_##band)/sizeof(u4Byte)))
|
||||||
|
#define AGC_DIFF_CONFIG_TC(ic, band) (ODM_ReadAndConfig_TC_##ic##_AGC_TAB_DIFF(pDM_Odm, Array_TC_##ic##_AGC_TAB_DIFF_##band, \
|
||||||
|
sizeof(Array_TC_##ic##_AGC_TAB_DIFF_##band)/sizeof(u4Byte)))
|
||||||
|
|
||||||
|
#define AGC_DIFF_CONFIG(ic, band) do {\
|
||||||
|
if (pDM_Odm->bIsMPChip)\
|
||||||
|
AGC_DIFF_CONFIG_MP(ic,band);\
|
||||||
|
else\
|
||||||
|
AGC_DIFF_CONFIG_TC(ic,band);\
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
|
||||||
|
//============================================================
|
||||||
|
// structure and define
|
||||||
|
//============================================================
|
||||||
|
|
||||||
|
typedef struct _Phy_Rx_AGC_Info
|
||||||
|
{
|
||||||
|
#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
|
||||||
|
u1Byte gain:7,trsw:1;
|
||||||
|
#else
|
||||||
|
u1Byte trsw:1,gain:7;
|
||||||
|
#endif
|
||||||
|
} PHY_RX_AGC_INFO_T,*pPHY_RX_AGC_INFO_T;
|
||||||
|
|
||||||
|
typedef struct _Phy_Status_Rpt_8192cd
|
||||||
|
{
|
||||||
|
PHY_RX_AGC_INFO_T path_agc[2];
|
||||||
|
u1Byte ch_corr[2];
|
||||||
|
u1Byte cck_sig_qual_ofdm_pwdb_all;
|
||||||
|
u1Byte cck_agc_rpt_ofdm_cfosho_a;
|
||||||
|
u1Byte cck_rpt_b_ofdm_cfosho_b;
|
||||||
|
u1Byte rsvd_1;//ch_corr_msb;
|
||||||
|
u1Byte noise_power_db_msb;
|
||||||
|
s1Byte path_cfotail[2];
|
||||||
|
u1Byte pcts_mask[2];
|
||||||
|
s1Byte stream_rxevm[2];
|
||||||
|
u1Byte path_rxsnr[2];
|
||||||
|
u1Byte noise_power_db_lsb;
|
||||||
|
u1Byte rsvd_2[3];
|
||||||
|
u1Byte stream_csi[2];
|
||||||
|
u1Byte stream_target_csi[2];
|
||||||
|
s1Byte sig_evm;
|
||||||
|
u1Byte rsvd_3;
|
||||||
|
|
||||||
|
#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
|
||||||
|
u1Byte antsel_rx_keep_2:1; //ex_intf_flg:1;
|
||||||
|
u1Byte sgi_en:1;
|
||||||
|
u1Byte rxsc:2;
|
||||||
|
u1Byte idle_long:1;
|
||||||
|
u1Byte r_ant_train_en:1;
|
||||||
|
u1Byte ant_sel_b:1;
|
||||||
|
u1Byte ant_sel:1;
|
||||||
|
#else // _BIG_ENDIAN_
|
||||||
|
u1Byte ant_sel:1;
|
||||||
|
u1Byte ant_sel_b:1;
|
||||||
|
u1Byte r_ant_train_en:1;
|
||||||
|
u1Byte idle_long:1;
|
||||||
|
u1Byte rxsc:2;
|
||||||
|
u1Byte sgi_en:1;
|
||||||
|
u1Byte antsel_rx_keep_2:1; //ex_intf_flg:1;
|
||||||
|
#endif
|
||||||
|
} PHY_STATUS_RPT_8192CD_T,*PPHY_STATUS_RPT_8192CD_T;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct _Phy_Status_Rpt_8812
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
PHY_RX_AGC_INFO_T path_agc[2];
|
||||||
|
u1Byte ch_num[2];
|
||||||
|
u1Byte cck_sig_qual_ofdm_pwdb_all;
|
||||||
|
u1Byte cck_agc_rpt_ofdm_cfosho_a;
|
||||||
|
u1Byte cck_bb_pwr_ofdm_cfosho_b;
|
||||||
|
u1Byte cck_rx_path; //CCK_RX_PATH [3:0] (with regA07[3:0] definition)
|
||||||
|
u1Byte rsvd_1;
|
||||||
|
u1Byte path_cfotail[2];
|
||||||
|
u1Byte pcts_mask[2];
|
||||||
|
s1Byte stream_rxevm[2];
|
||||||
|
u1Byte path_rxsnr[2];
|
||||||
|
u1Byte rsvd_2[2];
|
||||||
|
u1Byte stream_snr[2];
|
||||||
|
u1Byte stream_csi[2];
|
||||||
|
u1Byte rsvd_3[2];
|
||||||
|
s1Byte sig_evm;
|
||||||
|
u1Byte rsvd_4;
|
||||||
|
#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
|
||||||
|
u1Byte antidx_anta:3;
|
||||||
|
u1Byte antidx_antb:3;
|
||||||
|
u1Byte rsvd_5:2;
|
||||||
|
#else // _BIG_ENDIAN_
|
||||||
|
u1Byte rsvd_5:2;
|
||||||
|
u1Byte antidx_antb:3;
|
||||||
|
u1Byte antidx_anta:3;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//2012.05.24 LukeLee: This structure should take big/little endian in consideration later.....
|
||||||
|
|
||||||
|
//DWORD 0
|
||||||
|
u1Byte gain_trsw[2];
|
||||||
|
#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
|
||||||
|
u2Byte chl_num:10;
|
||||||
|
u2Byte sub_chnl:4;
|
||||||
|
u2Byte r_RFMOD:2;
|
||||||
|
#else // _BIG_ENDIAN_
|
||||||
|
u2Byte r_RFMOD:2;
|
||||||
|
u2Byte sub_chnl:4;
|
||||||
|
u2Byte chl_num:10;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//DWORD 1
|
||||||
|
u1Byte pwdb_all;
|
||||||
|
u1Byte cfosho[4]; // DW 1 byte 1 DW 2 byte 0
|
||||||
|
|
||||||
|
//DWORD 2
|
||||||
|
s1Byte cfotail[4]; // DW 2 byte 1 DW 3 byte 0
|
||||||
|
|
||||||
|
//DWORD 3
|
||||||
|
s1Byte rxevm[2]; // DW 3 byte 1 DW 3 byte 2
|
||||||
|
s1Byte rxsnr[2]; // DW 3 byte 3 DW 4 byte 0
|
||||||
|
|
||||||
|
//DWORD 4
|
||||||
|
u1Byte PCTS_MSK_RPT[2];
|
||||||
|
u1Byte pdsnr[2]; // DW 4 byte 3 DW 5 Byte 0
|
||||||
|
|
||||||
|
//DWORD 5
|
||||||
|
u1Byte csi_current[2];
|
||||||
|
u1Byte rx_gain_c;
|
||||||
|
|
||||||
|
//DWORD 6
|
||||||
|
u1Byte rx_gain_d;
|
||||||
|
s1Byte sigevm;
|
||||||
|
u1Byte resvd_0;
|
||||||
|
u1Byte antidx_anta:3;
|
||||||
|
u1Byte antidx_antb:3;
|
||||||
|
u1Byte resvd_1:2;
|
||||||
|
} PHY_STATUS_RPT_8812_T,*PPHY_STATUS_RPT_8812_T;
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_Init_RSSIForDM(
|
||||||
|
IN OUT PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_PhyStatusQuery(
|
||||||
|
IN OUT PDM_ODM_T pDM_Odm,
|
||||||
|
OUT PODM_PHY_INFO_T pPhyInfo,
|
||||||
|
IN pu1Byte pPhyStatus,
|
||||||
|
IN PODM_PACKET_INFO_T pPktinfo
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_MacStatusQuery(
|
||||||
|
IN OUT PDM_ODM_T pDM_Odm,
|
||||||
|
IN pu1Byte pMacStatus,
|
||||||
|
IN u1Byte MacID,
|
||||||
|
IN BOOLEAN bPacketMatchBSSID,
|
||||||
|
IN BOOLEAN bPacketToSelf,
|
||||||
|
IN BOOLEAN bPacketBeacon
|
||||||
|
);
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE|ODM_AP))
|
||||||
|
|
||||||
|
HAL_STATUS
|
||||||
|
ODM_ConfigRFWithTxPwrTrackHeaderFile(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
HAL_STATUS
|
||||||
|
ODM_ConfigRFWithHeaderFile(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN ODM_RF_Config_Type ConfigType,
|
||||||
|
IN ODM_RF_RADIO_PATH_E eRFPath
|
||||||
|
);
|
||||||
|
|
||||||
|
HAL_STATUS
|
||||||
|
ODM_ConfigBBWithHeaderFile(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN ODM_BB_Config_Type ConfigType
|
||||||
|
);
|
||||||
|
|
||||||
|
HAL_STATUS
|
||||||
|
ODM_ConfigMACWithHeaderFile(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
HAL_STATUS
|
||||||
|
ODM_ConfigFWWithHeaderFile(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN ODM_FW_Config_Type ConfigType,
|
||||||
|
OUT u1Byte *pFirmware,
|
||||||
|
OUT u4Byte *pSize
|
||||||
|
);
|
||||||
|
|
||||||
|
u4Byte
|
||||||
|
ODM_GetHWImgVersion(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
57
hal/OUTSRC/odm_RegDefine11AC.h
Normal file
57
hal/OUTSRC/odm_RegDefine11AC.h
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ODM_REGDEFINE11AC_H__
|
||||||
|
#define __ODM_REGDEFINE11AC_H__
|
||||||
|
|
||||||
|
//2 RF REG LIST
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//2 BB REG LIST
|
||||||
|
//PAGE 8
|
||||||
|
#define ODM_REG_CCK_RPT_FORMAT_11AC 0x804
|
||||||
|
#define ODM_REG_BB_RX_PATH_11AC 0x808
|
||||||
|
//PAGE 9
|
||||||
|
#define ODM_REG_OFDM_FA_RST_11AC 0x9A4
|
||||||
|
//PAGE A
|
||||||
|
#define ODM_REG_CCK_CCA_11AC 0xA0A
|
||||||
|
#define ODM_REG_CCK_FA_RST_11AC 0xA2C
|
||||||
|
#define ODM_REG_CCK_FA_11AC 0xA5C
|
||||||
|
//PAGE C
|
||||||
|
#define ODM_REG_IGI_A_11AC 0xC50
|
||||||
|
//PAGE E
|
||||||
|
#define ODM_REG_IGI_B_11AC 0xE50
|
||||||
|
//PAGE F
|
||||||
|
#define ODM_REG_OFDM_FA_11AC 0xF48
|
||||||
|
|
||||||
|
|
||||||
|
//2 MAC REG LIST
|
||||||
|
#define ODM_REG_RESP_TX_11AC 0x6D8
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//DIG Related
|
||||||
|
#define ODM_BIT_IGI_11AC 0xFFFFFFFF
|
||||||
|
#define ODM_BIT_CCK_RPT_FORMAT_11AC BIT16
|
||||||
|
#define ODM_BIT_BB_RX_PATH_11AC 0xF
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
174
hal/OUTSRC/odm_RegDefine11N.h
Normal file
174
hal/OUTSRC/odm_RegDefine11N.h
Normal file
@ -0,0 +1,174 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ODM_REGDEFINE11N_H__
|
||||||
|
#define __ODM_REGDEFINE11N_H__
|
||||||
|
|
||||||
|
|
||||||
|
//2 RF REG LIST
|
||||||
|
#define ODM_REG_RF_MODE_11N 0x00
|
||||||
|
#define ODM_REG_RF_0B_11N 0x0B
|
||||||
|
#define ODM_REG_CHNBW_11N 0x18
|
||||||
|
#define ODM_REG_T_METER_11N 0x24
|
||||||
|
#define ODM_REG_RF_25_11N 0x25
|
||||||
|
#define ODM_REG_RF_26_11N 0x26
|
||||||
|
#define ODM_REG_RF_27_11N 0x27
|
||||||
|
#define ODM_REG_RF_2B_11N 0x2B
|
||||||
|
#define ODM_REG_RF_2C_11N 0x2C
|
||||||
|
#define ODM_REG_RXRF_A3_11N 0x3C
|
||||||
|
#define ODM_REG_T_METER_92D_11N 0x42
|
||||||
|
#define ODM_REG_T_METER_88E_11N 0x42
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//2 BB REG LIST
|
||||||
|
//PAGE 8
|
||||||
|
#define ODM_REG_BB_CTRL_11N 0x800
|
||||||
|
#define ODM_REG_RF_PIN_11N 0x804
|
||||||
|
#define ODM_REG_PSD_CTRL_11N 0x808
|
||||||
|
#define ODM_REG_TX_ANT_CTRL_11N 0x80C
|
||||||
|
#define ODM_REG_BB_PWR_SAV5_11N 0x818
|
||||||
|
#define ODM_REG_CCK_RPT_FORMAT_11N 0x824
|
||||||
|
#define ODM_REG_RX_DEFUALT_A_11N 0x858
|
||||||
|
#define ODM_REG_RX_DEFUALT_B_11N 0x85A
|
||||||
|
#define ODM_REG_BB_PWR_SAV3_11N 0x85C
|
||||||
|
#define ODM_REG_ANTSEL_CTRL_11N 0x860
|
||||||
|
#define ODM_REG_RX_ANT_CTRL_11N 0x864
|
||||||
|
#define ODM_REG_PIN_CTRL_11N 0x870
|
||||||
|
#define ODM_REG_BB_PWR_SAV1_11N 0x874
|
||||||
|
#define ODM_REG_ANTSEL_PATH_11N 0x878
|
||||||
|
#define ODM_REG_BB_3WIRE_11N 0x88C
|
||||||
|
#define ODM_REG_SC_CNT_11N 0x8C4
|
||||||
|
#define ODM_REG_PSD_DATA_11N 0x8B4
|
||||||
|
//PAGE 9
|
||||||
|
#define ODM_REG_ANT_MAPPING1_11N 0x914
|
||||||
|
#define ODM_REG_ANT_MAPPING2_11N 0x918
|
||||||
|
//PAGE A
|
||||||
|
#define ODM_REG_CCK_ANTDIV_PARA1_11N 0xA00
|
||||||
|
#define ODM_REG_CCK_CCA_11N 0xA0A
|
||||||
|
#define ODM_REG_CCK_ANTDIV_PARA2_11N 0xA0C
|
||||||
|
#define ODM_REG_CCK_ANTDIV_PARA3_11N 0xA10
|
||||||
|
#define ODM_REG_CCK_ANTDIV_PARA4_11N 0xA14
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA1_11N 0xA22
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA2_11N 0xA23
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA3_11N 0xA24
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA4_11N 0xA25
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA5_11N 0xA26
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA6_11N 0xA27
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA7_11N 0xA28
|
||||||
|
#define ODM_REG_CCK_FILTER_PARA8_11N 0xA29
|
||||||
|
#define ODM_REG_CCK_FA_RST_11N 0xA2C
|
||||||
|
#define ODM_REG_CCK_FA_MSB_11N 0xA58
|
||||||
|
#define ODM_REG_CCK_FA_LSB_11N 0xA5C
|
||||||
|
#define ODM_REG_CCK_CCA_CNT_11N 0xA60
|
||||||
|
#define ODM_REG_BB_PWR_SAV4_11N 0xA74
|
||||||
|
//PAGE B
|
||||||
|
#define ODM_REG_LNA_SWITCH_11N 0xB2C
|
||||||
|
#define ODM_REG_PATH_SWITCH_11N 0xB30
|
||||||
|
#define ODM_REG_RSSI_CTRL_11N 0xB38
|
||||||
|
#define ODM_REG_CONFIG_ANTA_11N 0xB68
|
||||||
|
#define ODM_REG_RSSI_BT_11N 0xB9C
|
||||||
|
//PAGE C
|
||||||
|
#define ODM_REG_OFDM_FA_HOLDC_11N 0xC00
|
||||||
|
#define ODM_REG_BB_RX_PATH_11N 0xC04
|
||||||
|
#define ODM_REG_TRMUX_11N 0xC08
|
||||||
|
#define ODM_REG_OFDM_FA_RSTC_11N 0xC0C
|
||||||
|
#define ODM_REG_RXIQI_MATRIX_11N 0xC14
|
||||||
|
#define ODM_REG_TXIQK_MATRIX_LSB1_11N 0xC4C
|
||||||
|
#define ODM_REG_IGI_A_11N 0xC50
|
||||||
|
#define ODM_REG_ANTDIV_PARA2_11N 0xC54
|
||||||
|
#define ODM_REG_IGI_B_11N 0xC58
|
||||||
|
#define ODM_REG_ANTDIV_PARA3_11N 0xC5C
|
||||||
|
#define ODM_REG_L1SBD_PD_CH_11N 0XC6C
|
||||||
|
#define ODM_REG_BB_PWR_SAV2_11N 0xC70
|
||||||
|
#define ODM_REG_RX_OFF_11N 0xC7C
|
||||||
|
#define ODM_REG_TXIQK_MATRIXA_11N 0xC80
|
||||||
|
#define ODM_REG_TXIQK_MATRIXB_11N 0xC88
|
||||||
|
#define ODM_REG_TXIQK_MATRIXA_LSB2_11N 0xC94
|
||||||
|
#define ODM_REG_TXIQK_MATRIXB_LSB2_11N 0xC9C
|
||||||
|
#define ODM_REG_RXIQK_MATRIX_LSB_11N 0xCA0
|
||||||
|
#define ODM_REG_ANTDIV_PARA1_11N 0xCA4
|
||||||
|
#define ODM_REG_OFDM_FA_TYPE1_11N 0xCF0
|
||||||
|
//PAGE D
|
||||||
|
#define ODM_REG_OFDM_FA_RSTD_11N 0xD00
|
||||||
|
#define ODM_REG_OFDM_FA_TYPE2_11N 0xDA0
|
||||||
|
#define ODM_REG_OFDM_FA_TYPE3_11N 0xDA4
|
||||||
|
#define ODM_REG_OFDM_FA_TYPE4_11N 0xDA8
|
||||||
|
//PAGE E
|
||||||
|
#define ODM_REG_TXAGC_A_6_18_11N 0xE00
|
||||||
|
#define ODM_REG_TXAGC_A_24_54_11N 0xE04
|
||||||
|
#define ODM_REG_TXAGC_A_1_MCS32_11N 0xE08
|
||||||
|
#define ODM_REG_TXAGC_A_MCS0_3_11N 0xE10
|
||||||
|
#define ODM_REG_TXAGC_A_MCS4_7_11N 0xE14
|
||||||
|
#define ODM_REG_TXAGC_A_MCS8_11_11N 0xE18
|
||||||
|
#define ODM_REG_TXAGC_A_MCS12_15_11N 0xE1C
|
||||||
|
#define ODM_REG_FPGA0_IQK_11N 0xE28
|
||||||
|
#define ODM_REG_TXIQK_TONE_A_11N 0xE30
|
||||||
|
#define ODM_REG_RXIQK_TONE_A_11N 0xE34
|
||||||
|
#define ODM_REG_TXIQK_PI_A_11N 0xE38
|
||||||
|
#define ODM_REG_RXIQK_PI_A_11N 0xE3C
|
||||||
|
#define ODM_REG_TXIQK_11N 0xE40
|
||||||
|
#define ODM_REG_RXIQK_11N 0xE44
|
||||||
|
#define ODM_REG_IQK_AGC_PTS_11N 0xE48
|
||||||
|
#define ODM_REG_IQK_AGC_RSP_11N 0xE4C
|
||||||
|
#define ODM_REG_BLUETOOTH_11N 0xE6C
|
||||||
|
#define ODM_REG_RX_WAIT_CCA_11N 0xE70
|
||||||
|
#define ODM_REG_TX_CCK_RFON_11N 0xE74
|
||||||
|
#define ODM_REG_TX_CCK_BBON_11N 0xE78
|
||||||
|
#define ODM_REG_OFDM_RFON_11N 0xE7C
|
||||||
|
#define ODM_REG_OFDM_BBON_11N 0xE80
|
||||||
|
#define ODM_REG_TX2RX_11N 0xE84
|
||||||
|
#define ODM_REG_TX2TX_11N 0xE88
|
||||||
|
#define ODM_REG_RX_CCK_11N 0xE8C
|
||||||
|
#define ODM_REG_RX_OFDM_11N 0xED0
|
||||||
|
#define ODM_REG_RX_WAIT_RIFS_11N 0xED4
|
||||||
|
#define ODM_REG_RX2RX_11N 0xED8
|
||||||
|
#define ODM_REG_STANDBY_11N 0xEDC
|
||||||
|
#define ODM_REG_SLEEP_11N 0xEE0
|
||||||
|
#define ODM_REG_PMPD_ANAEN_11N 0xEEC
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//2 MAC REG LIST
|
||||||
|
#define ODM_REG_BB_RST_11N 0x02
|
||||||
|
#define ODM_REG_ANTSEL_PIN_11N 0x4C
|
||||||
|
#define ODM_REG_EARLY_MODE_11N 0x4D0
|
||||||
|
#define ODM_REG_RSSI_MONITOR_11N 0x4FE
|
||||||
|
#define ODM_REG_EDCA_VO_11N 0x500
|
||||||
|
#define ODM_REG_EDCA_VI_11N 0x504
|
||||||
|
#define ODM_REG_EDCA_BE_11N 0x508
|
||||||
|
#define ODM_REG_EDCA_BK_11N 0x50C
|
||||||
|
#define ODM_REG_TXPAUSE_11N 0x522
|
||||||
|
#define ODM_REG_RESP_TX_11N 0x6D8
|
||||||
|
#define ODM_REG_ANT_TRAIN_PARA1_11N 0x7b0
|
||||||
|
#define ODM_REG_ANT_TRAIN_PARA2_11N 0x7b4
|
||||||
|
|
||||||
|
|
||||||
|
//DIG Related
|
||||||
|
#define ODM_BIT_IGI_11N 0x0000007F
|
||||||
|
#define ODM_BIT_CCK_RPT_FORMAT_11N BIT9
|
||||||
|
#define ODM_BIT_BB_RX_PATH_11N 0xF
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
629
hal/OUTSRC/odm_debug.c
Normal file
629
hal/OUTSRC/odm_debug.c
Normal file
File diff suppressed because it is too large
Load Diff
892
hal/OUTSRC/odm_debug.h
Normal file
892
hal/OUTSRC/odm_debug.h
Normal file
File diff suppressed because it is too large
Load Diff
750
hal/OUTSRC/odm_interface.c
Normal file
750
hal/OUTSRC/odm_interface.c
Normal file
File diff suppressed because it is too large
Load Diff
394
hal/OUTSRC/odm_interface.h
Normal file
394
hal/OUTSRC/odm_interface.h
Normal file
@ -0,0 +1,394 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __ODM_INTERFACE_H__
|
||||||
|
#define __ODM_INTERFACE_H__
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// =========== Constant/Structure/Enum/... Define
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// =========== Macro Define
|
||||||
|
//
|
||||||
|
|
||||||
|
#define _reg_all(_name) ODM_##_name
|
||||||
|
#define _reg_ic(_name, _ic) ODM_##_name##_ic
|
||||||
|
#define _bit_all(_name) BIT_##_name
|
||||||
|
#define _bit_ic(_name, _ic) BIT_##_name##_ic
|
||||||
|
|
||||||
|
// _cat: implemented by Token-Pasting Operator.
|
||||||
|
#if 0
|
||||||
|
#define _cat(_name, _ic_type, _func) \
|
||||||
|
( \
|
||||||
|
_func##_all(_name) \
|
||||||
|
)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*===================================
|
||||||
|
|
||||||
|
#define ODM_REG_DIG_11N 0xC50
|
||||||
|
#define ODM_REG_DIG_11AC 0xDDD
|
||||||
|
|
||||||
|
ODM_REG(DIG,_pDM_Odm)
|
||||||
|
=====================================*/
|
||||||
|
|
||||||
|
#define _reg_11N(_name) ODM_REG_##_name##_11N
|
||||||
|
#define _reg_11AC(_name) ODM_REG_##_name##_11AC
|
||||||
|
#define _bit_11N(_name) ODM_BIT_##_name##_11N
|
||||||
|
#define _bit_11AC(_name) ODM_BIT_##_name##_11AC
|
||||||
|
|
||||||
|
#if 1 //TODO: enable it if we need to support run-time to differentiate between 92C_SERIES and JAGUAR_SERIES.
|
||||||
|
#define _cat(_name, _ic_type, _func) \
|
||||||
|
( \
|
||||||
|
((_ic_type) & ODM_IC_11N_SERIES)? _func##_11N(_name): \
|
||||||
|
_func##_11AC(_name) \
|
||||||
|
)
|
||||||
|
#endif
|
||||||
|
#if 0 // only sample code
|
||||||
|
#define _cat(_name, _ic_type, _func) \
|
||||||
|
( \
|
||||||
|
((_ic_type) & ODM_RTL8192C)? _func##_ic(_name, _8192C): \
|
||||||
|
((_ic_type) & ODM_RTL8192D)? _func##_ic(_name, _8192D): \
|
||||||
|
((_ic_type) & ODM_RTL8192S)? _func##_ic(_name, _8192S): \
|
||||||
|
((_ic_type) & ODM_RTL8723A)? _func##_ic(_name, _8723A): \
|
||||||
|
((_ic_type) & ODM_RTL8188E)? _func##_ic(_name, _8188E): \
|
||||||
|
_func##_ic(_name, _8195) \
|
||||||
|
)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// _name: name of register or bit.
|
||||||
|
// Example: "ODM_REG(R_A_AGC_CORE1, pDM_Odm)"
|
||||||
|
// gets "ODM_R_A_AGC_CORE1" or "ODM_R_A_AGC_CORE1_8192C", depends on SupportICType.
|
||||||
|
#define ODM_REG(_name, _pDM_Odm) _cat(_name, _pDM_Odm->SupportICType, _reg)
|
||||||
|
#define ODM_BIT(_name, _pDM_Odm) _cat(_name, _pDM_Odm->SupportICType, _bit)
|
||||||
|
|
||||||
|
typedef enum _ODM_H2C_CMD
|
||||||
|
{
|
||||||
|
ODM_H2C_RSSI_REPORT = 0,
|
||||||
|
ODM_H2C_PSD_RESULT=1,
|
||||||
|
ODM_H2C_PathDiv = 2,
|
||||||
|
ODM_MAX_H2CCMD
|
||||||
|
}ODM_H2C_CMD;
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// 2012/02/17 MH For non-MP compile pass only. Linux does not support workitem.
|
||||||
|
// Suggest HW team to use thread instead of workitem. Windows also support the feature.
|
||||||
|
//
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
|
||||||
|
typedef void *PRT_WORK_ITEM ;
|
||||||
|
typedef void RT_WORKITEM_HANDLE,*PRT_WORKITEM_HANDLE;
|
||||||
|
typedef VOID (*RT_WORKITEM_CALL_BACK)(PVOID pContext);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
typedef struct tasklet_struct RT_WORKITEM_HANDLE, *PRT_WORKITEM_HANDLE;
|
||||||
|
|
||||||
|
typedef struct _RT_WORK_ITEM
|
||||||
|
{
|
||||||
|
|
||||||
|
RT_WORKITEM_HANDLE Handle; // Platform-dependent handle for this workitem, e.g. Ndis Workitem object.
|
||||||
|
PVOID Adapter; // Pointer to Adapter object.
|
||||||
|
PVOID pContext; // Parameter to passed to CallBackFunc().
|
||||||
|
RT_WORKITEM_CALL_BACK CallbackFunc; // Callback function of the workitem.
|
||||||
|
u1Byte RefCount; // 0: driver is going to unload, 1: No such workitem scheduled, 2: one workitem is schedueled.
|
||||||
|
PVOID pPlatformExt; // Pointer to platform-dependent extension.
|
||||||
|
BOOLEAN bFree;
|
||||||
|
char szID[36]; // An identity string of this workitem.
|
||||||
|
}RT_WORK_ITEM, *PRT_WORK_ITEM;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//
|
||||||
|
// =========== Extern Variable ??? It should be forbidden.
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// =========== EXtern Function Prototype
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
|
u1Byte
|
||||||
|
ODM_Read1Byte(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr
|
||||||
|
);
|
||||||
|
|
||||||
|
u2Byte
|
||||||
|
ODM_Read2Byte(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr
|
||||||
|
);
|
||||||
|
|
||||||
|
u4Byte
|
||||||
|
ODM_Read4Byte(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_Write1Byte(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u1Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_Write2Byte(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u2Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_Write4Byte(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_SetMACReg(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u4Byte BitMask,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
u4Byte
|
||||||
|
ODM_GetMACReg(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u4Byte BitMask
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_SetBBReg(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u4Byte BitMask,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
u4Byte
|
||||||
|
ODM_GetBBReg(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u4Byte BitMask
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_SetRFReg(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN ODM_RF_RADIO_PATH_E eRFPath,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u4Byte BitMask,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
u4Byte
|
||||||
|
ODM_GetRFReg(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN ODM_RF_RADIO_PATH_E eRFPath,
|
||||||
|
IN u4Byte RegAddr,
|
||||||
|
IN u4Byte BitMask
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Memory Relative Function.
|
||||||
|
//
|
||||||
|
VOID
|
||||||
|
ODM_AllocateMemory(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT PVOID *pPtr,
|
||||||
|
IN u4Byte length
|
||||||
|
);
|
||||||
|
VOID
|
||||||
|
ODM_FreeMemory(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT PVOID pPtr,
|
||||||
|
IN u4Byte length
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_MoveMemory(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT PVOID pDest,
|
||||||
|
IN PVOID pSrc,
|
||||||
|
IN u4Byte Length
|
||||||
|
);
|
||||||
|
|
||||||
|
s4Byte ODM_CompareMemory(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN PVOID pBuf1,
|
||||||
|
IN PVOID pBuf2,
|
||||||
|
IN u4Byte length
|
||||||
|
);
|
||||||
|
|
||||||
|
//
|
||||||
|
// ODM MISC-spin lock relative API.
|
||||||
|
//
|
||||||
|
VOID
|
||||||
|
ODM_AcquireSpinLock(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN RT_SPINLOCK_TYPE type
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_ReleaseSpinLock(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN RT_SPINLOCK_TYPE type
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// ODM MISC-workitem relative API.
|
||||||
|
//
|
||||||
|
VOID
|
||||||
|
ODM_InitializeWorkItem(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN PRT_WORK_ITEM pRtWorkItem,
|
||||||
|
IN RT_WORKITEM_CALL_BACK RtWorkItemCallback,
|
||||||
|
IN PVOID pContext,
|
||||||
|
IN const char* szID
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_StartWorkItem(
|
||||||
|
IN PRT_WORK_ITEM pRtWorkItem
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_StopWorkItem(
|
||||||
|
IN PRT_WORK_ITEM pRtWorkItem
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_FreeWorkItem(
|
||||||
|
IN PRT_WORK_ITEM pRtWorkItem
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_ScheduleWorkItem(
|
||||||
|
IN PRT_WORK_ITEM pRtWorkItem
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_IsWorkItemScheduled(
|
||||||
|
IN PRT_WORK_ITEM pRtWorkItem
|
||||||
|
);
|
||||||
|
|
||||||
|
//
|
||||||
|
// ODM Timer relative API.
|
||||||
|
//
|
||||||
|
VOID
|
||||||
|
ODM_StallExecution(
|
||||||
|
IN u4Byte usDelay
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_delay_ms(IN u4Byte ms);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_delay_us(IN u4Byte us);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_sleep_ms(IN u4Byte ms);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_sleep_us(IN u4Byte us);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_SetTimer(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN PRT_TIMER pTimer,
|
||||||
|
IN u4Byte msDelay
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_InitializeTimer(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN PRT_TIMER pTimer,
|
||||||
|
IN RT_TIMER_CALL_BACK CallBackFunc,
|
||||||
|
IN PVOID pContext,
|
||||||
|
IN const char* szID
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_CancelTimer(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN PRT_TIMER pTimer
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_ReleaseTimer(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN PRT_TIMER pTimer
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// ODM FW relative API.
|
||||||
|
//
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
|
||||||
|
VOID
|
||||||
|
ODM_FillH2CCmd(
|
||||||
|
IN PADAPTER Adapter,
|
||||||
|
IN u1Byte ElementID,
|
||||||
|
IN u4Byte CmdLen,
|
||||||
|
IN pu1Byte pCmdBuffer
|
||||||
|
);
|
||||||
|
#else
|
||||||
|
u4Byte
|
||||||
|
ODM_FillH2CCmd(
|
||||||
|
IN pu1Byte pH2CBuffer,
|
||||||
|
IN u4Byte H2CBufferLen,
|
||||||
|
IN u4Byte CmdNum,
|
||||||
|
IN pu4Byte pElementID,
|
||||||
|
IN pu4Byte pCmdLen,
|
||||||
|
IN pu1Byte* pCmbBuffer,
|
||||||
|
IN pu1Byte CmdStartSeq
|
||||||
|
);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
u4Byte
|
||||||
|
ODM_GetCurrentTime(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
s4Byte
|
||||||
|
ODM_GetProgressingTime(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Start_Time
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif // __ODM_INTERFACE_H__
|
||||||
|
|
307
hal/OUTSRC/odm_precomp.h
Normal file
307
hal/OUTSRC/odm_precomp.h
Normal file
@ -0,0 +1,307 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ODM_PRECOMP_H__
|
||||||
|
#define __ODM_PRECOMP_H__
|
||||||
|
|
||||||
|
#include "odm_types.h"
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
||||||
|
#include "Precomp.h" // We need to include mp_precomp.h due to batch file setting.
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#define TEST_FALG___ 1
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//2 Config Flags and Structs - defined by each ODM Type
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
#include "../8192cd_cfg.h"
|
||||||
|
#include "../odm_inc.h"
|
||||||
|
|
||||||
|
#include "../8192cd.h"
|
||||||
|
#include "../8192cd_util.h"
|
||||||
|
#ifdef _BIG_ENDIAN_
|
||||||
|
#define ODM_ENDIAN_TYPE ODM_ENDIAN_BIG
|
||||||
|
#else
|
||||||
|
#define ODM_ENDIAN_TYPE ODM_ENDIAN_LITTLE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef AP_BUILD_WORKAROUND
|
||||||
|
#include "../8192cd_headers.h"
|
||||||
|
#include "../8192cd_debug.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_ADSL)
|
||||||
|
// Flags
|
||||||
|
#include "../8192cd_cfg.h" // OUTSRC needs ADSL config flags.
|
||||||
|
#include "../odm_inc.h" // OUTSRC needs some extra flags.
|
||||||
|
// Data Structure
|
||||||
|
#include "../common_types.h" // OUTSRC and rtl8192cd both needs basic type such as UINT8 and BIT0.
|
||||||
|
#include "../8192cd.h" // OUTSRC needs basic ADSL struct definition.
|
||||||
|
#include "../8192cd_util.h" // OUTSRC needs basic I/O function.
|
||||||
|
#ifdef _BIG_ENDIAN_
|
||||||
|
#define ODM_ENDIAN_TYPE ODM_ENDIAN_BIG
|
||||||
|
#else
|
||||||
|
#define ODM_ENDIAN_TYPE ODM_ENDIAN_LITTLE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef ADSL_AP_BUILD_WORKAROUND
|
||||||
|
// NESTED_INC: Functions defined outside should not be included!! Marked by Annie, 2011-10-14.
|
||||||
|
#include "../8192cd_headers.h"
|
||||||
|
#include "../8192cd_debug.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE ==ODM_CE)
|
||||||
|
//#include <drv_conf.h>
|
||||||
|
//#include <basic_types.h>
|
||||||
|
//#include <osdep_service.h>
|
||||||
|
//#include <drv_types.h>
|
||||||
|
//#include <rtw_byteorder.h>
|
||||||
|
//#include <hal_intf.h>
|
||||||
|
#define BEAMFORMING_SUPPORT 0
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
||||||
|
#include "Mp_Precomp.h"
|
||||||
|
#define ODM_ENDIAN_TYPE ODM_ENDIAN_LITTLE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
//2 Hardware Parameter Files
|
||||||
|
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
#if (RTL8192C_SUPPORT==1)
|
||||||
|
#include "rtl8192c/Hal8192CEFWImg_AP.h"
|
||||||
|
#include "rtl8192c/Hal8192CEPHYImg_AP.h"
|
||||||
|
#include "rtl8192c/Hal8192CEMACImg_AP.h"
|
||||||
|
#endif
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_ADSL)
|
||||||
|
#include "rtl8192c/Hal8192CEFWImg_ADSL.h"
|
||||||
|
#include "rtl8192c/Hal8192CEPHYImg_ADSL.h"
|
||||||
|
#include "rtl8192c/Hal8192CEMACImg_ADSL.h"
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
|
||||||
|
#if(RTL8192CE_SUPPORT ==1)
|
||||||
|
#include "rtl8192c/Hal8192CEFWImg_CE.h"
|
||||||
|
#include "rtl8192c/Hal8192CEPHYImg_CE.h"
|
||||||
|
#include "rtl8192c/Hal8192CEMACImg_CE.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if(RTL8192CU_SUPPORT ==1)
|
||||||
|
#include "rtl8192c/Hal8192CUFWImg_CE.h"
|
||||||
|
#include "rtl8192c/Hal8192CUPHYImg_CE.h"
|
||||||
|
#include "rtl8192c/Hal8192CUMACImg_CE.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if(RTL8192DE_SUPPORT ==1)
|
||||||
|
#include "rtl8192d/Hal8192DEFWImg_CE.h"
|
||||||
|
#include "rtl8192d/Hal8192DEPHYImg_CE.h"
|
||||||
|
#include "rtl8192d/Hal8192DEMACImg_CE.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if(RTL8192DU_SUPPORT ==1)
|
||||||
|
#include "rtl8192d/Hal8192DUFWImg_CE.h"
|
||||||
|
#include "rtl8192d/Hal8192DUPHYImg_CE.h"
|
||||||
|
#include "rtl8192d/Hal8192DUMACImg_CE.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if(RTL8723AS_SUPPORT==1)
|
||||||
|
#include "rtl8723a/Hal8723SHWImg_CE.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if(RTL8723AU_SUPPORT==1)
|
||||||
|
#include "rtl8723a/Hal8723UHWImg_CE.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
//2 OutSrc Header Files
|
||||||
|
|
||||||
|
#include "odm.h"
|
||||||
|
#include "odm_HWConfig.h"
|
||||||
|
#include "odm_debug.h"
|
||||||
|
#include "odm_RegDefine11AC.h"
|
||||||
|
#include "odm_RegDefine11N.h"
|
||||||
|
#include "odm_AntDiv.h"
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
#if (RTL8192C_SUPPORT==1)
|
||||||
|
#include "rtl8192c/HalDMOutSrc8192C_AP.h"
|
||||||
|
#endif
|
||||||
|
#if (RTL8188E_SUPPORT==1)
|
||||||
|
#include "rtl8188e/Hal8188ERateAdaptive.h"//for RA,Power training
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_ADSL)
|
||||||
|
#include "rtl8192c/HalDMOutSrc8192C_ADSL.h"
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
|
||||||
|
//#include "hal_com.h"
|
||||||
|
#include "HalPhyRf.h"
|
||||||
|
#if (RTL8192C_SUPPORT==1)
|
||||||
|
#ifdef CONFIG_INTEL_PROXIM
|
||||||
|
#include "../proxim/intel_proxim.h"
|
||||||
|
#endif
|
||||||
|
#include "rtl8192c/HalDMOutSrc8192C_CE.h"
|
||||||
|
#include <rtl8192c_hal.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8192D_SUPPORT==1)
|
||||||
|
#include "rtl8192d/HalDMOutSrc8192D_CE.h"
|
||||||
|
#include "rtl8192d_hal.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8723A_SUPPORT==1)
|
||||||
|
#include "rtl8192c/HalDMOutSrc8192C_CE.h" //for IQK,LCK,Power-tracking
|
||||||
|
#include "rtl8723a_hal.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8188E_SUPPORT==1)
|
||||||
|
#include "rtl8188e/HalPhyRf_8188e.h"//for IQK,LCK,Power-tracking
|
||||||
|
#include "rtl8188e/Hal8188ERateAdaptive.h"//for RA,Power training
|
||||||
|
#include "rtl8188e_hal.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT==1)
|
||||||
|
#include "rtl8192e/HalPhyRf_8192e.h"//for IQK,LCK,Power-tracking
|
||||||
|
#include "rtl8192e_hal.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8812A_SUPPORT==1)
|
||||||
|
#include "rtl8812a/HalPhyRf_8812A.h"//for IQK,LCK,Power-tracking
|
||||||
|
#include "rtl8812a_hal.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8821A_SUPPORT==1)
|
||||||
|
#include "rtl8821a/HalPhyRf_8821A.h"//for IQK,LCK,Power-tracking
|
||||||
|
#include "rtl8812a/HalPhyRf_8812A.h"//for IQK,LCK,Power-tracking
|
||||||
|
#include "rtl8812a_hal.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8723B_SUPPORT==1)
|
||||||
|
#include "rtl8723b/HalPhyRf_8723B.h"//for IQK,LCK,Power-tracking
|
||||||
|
#include "rtl8723b_hal.h"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "odm_interface.h"
|
||||||
|
#include "odm_reg.h"
|
||||||
|
|
||||||
|
#if (RTL8192C_SUPPORT==1)
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
#include "rtl8192c/Hal8192CHWImg_MAC.h"
|
||||||
|
#include "rtl8192c/Hal8192CHWImg_RF.h"
|
||||||
|
#include "rtl8192c/Hal8192CHWImg_BB.h"
|
||||||
|
#include "rtl8192c/Hal8192CHWImg_FW.h"
|
||||||
|
#endif
|
||||||
|
#include "rtl8192c/odm_RTL8192C.h"
|
||||||
|
#endif
|
||||||
|
#if (RTL8192D_SUPPORT==1)
|
||||||
|
#include "rtl8192d/odm_RTL8192D.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8723A_SUPPORT==1)
|
||||||
|
#include "rtl8723a/HalHWImg8723A_MAC.h"
|
||||||
|
#include "rtl8723a/HalHWImg8723A_RF.h"
|
||||||
|
#include "rtl8723a/HalHWImg8723A_BB.h"
|
||||||
|
#include "rtl8723a/HalHWImg8723A_FW.h"
|
||||||
|
#include "rtl8723a/odm_RegConfig8723A.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8188E_SUPPORT==1)
|
||||||
|
#include "rtl8188e/HalHWImg8188E_MAC.h"
|
||||||
|
#include "rtl8188e/HalHWImg8188E_RF.h"
|
||||||
|
#include "rtl8188e/HalHWImg8188E_BB.h"
|
||||||
|
#include "rtl8188e/HalHWImg8188E_FW.h"
|
||||||
|
#include "rtl8188e/Hal8188EReg.h"
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
|
||||||
|
#include "rtl8188e/HalPhyRf_8188e.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (TESTCHIP_SUPPORT == 1)
|
||||||
|
#include "rtl8188e/HalHWImg8188E_TestChip_MAC.h"
|
||||||
|
#include "rtl8188e/HalHWImg8188E_TestChip_RF.h"
|
||||||
|
#include "rtl8188e/HalHWImg8188E_TestChip_BB.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#include "rtl8188e/odm_RegConfig8188E.h"
|
||||||
|
#include "rtl8188e/odm_RTL8188E.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT==1)
|
||||||
|
#include "rtl8192e/HalHWImg8192E_MAC.h"
|
||||||
|
#include "rtl8192e/HalHWImg8192E_RF.h"
|
||||||
|
#include "rtl8192e/HalHWImg8192E_BB.h"
|
||||||
|
#include "rtl8192e/HalHWImg8192E_FW.h"
|
||||||
|
#include "rtl8192e/Hal8192EReg.h"
|
||||||
|
#include "rtl8192e/odm_RegConfig8192E.h"
|
||||||
|
#include "rtl8192e/odm_RTL8192E.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8723B_SUPPORT==1)
|
||||||
|
#include "rtl8723b/HalHWImg8723B_MAC.h"
|
||||||
|
#include "rtl8723b/HalHWImg8723B_RF.h"
|
||||||
|
#include "rtl8723b/HalHWImg8723B_BB.h"
|
||||||
|
#include "rtl8723b/HalHWImg8723B_FW.h"
|
||||||
|
#include "rtl8723b/HalHWImg8723B_MP.h"
|
||||||
|
#include "rtl8723b/Hal8723BReg.h"
|
||||||
|
#include "rtl8723b/odm_RTL8723B.h"
|
||||||
|
#include "rtl8723b/odm_RegConfig8723B.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (RTL8812A_SUPPORT==1)
|
||||||
|
#include "rtl8812a/HalHWImg8812A_MAC.h"
|
||||||
|
#include "rtl8812a/HalHWImg8812A_RF.h"
|
||||||
|
#include "rtl8812a/HalHWImg8812A_BB.h"
|
||||||
|
#include "rtl8812a/HalHWImg8812A_FW.h"
|
||||||
|
#include "rtl8812a/odm_RegConfig8812A.h"
|
||||||
|
#include "rtl8812a/odm_RTL8812A.h"
|
||||||
|
#if (TESTCHIP_SUPPORT == 1)
|
||||||
|
#include "rtl8812a/HalHWImg8812A_TestChip_MAC.h"
|
||||||
|
#include "rtl8812a/HalHWImg8812A_TestChip_RF.h"
|
||||||
|
#include "rtl8812a/HalHWImg8812A_TestChip_BB.h"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if (RTL8821A_SUPPORT==1)
|
||||||
|
#include "rtl8821a/HalHWImg8821A_MAC.h"
|
||||||
|
#include "rtl8821a/HalHWImg8821A_RF.h"
|
||||||
|
#include "rtl8821a/HalHWImg8821A_BB.h"
|
||||||
|
#include "rtl8821a/HalHWImg8821A_FW.h"
|
||||||
|
#include "rtl8821a/odm_RegConfig8821A.h"
|
||||||
|
#include "rtl8821a/odm_RTL8821A.h"
|
||||||
|
#if (TESTCHIP_SUPPORT == 1)
|
||||||
|
#include "rtl8821a/HalHWImg8821A_TestChip_MAC.h"
|
||||||
|
#include "rtl8821a/HalHWImg8821A_TestChip_RF.h"
|
||||||
|
#include "rtl8821a/HalHWImg8821A_TestChip_BB.h"
|
||||||
|
#include "rtl8821a/HalHWImg8821A_TestChip_FW.h"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // __ODM_PRECOMP_H__
|
||||||
|
|
122
hal/OUTSRC/odm_reg.h
Normal file
122
hal/OUTSRC/odm_reg.h
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
//============================================================
|
||||||
|
// File Name: odm_reg.h
|
||||||
|
//
|
||||||
|
// Description:
|
||||||
|
//
|
||||||
|
// This file is for general register definition.
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//============================================================
|
||||||
|
#ifndef __HAL_ODM_REG_H__
|
||||||
|
#define __HAL_ODM_REG_H__
|
||||||
|
|
||||||
|
//
|
||||||
|
// Register Definition
|
||||||
|
//
|
||||||
|
|
||||||
|
//MAC REG
|
||||||
|
#define ODM_BB_RESET 0x002
|
||||||
|
#define ODM_DUMMY 0x4fe
|
||||||
|
#define RF_T_METER_OLD 0x24
|
||||||
|
#define RF_T_METER_NEW 0x42
|
||||||
|
|
||||||
|
#define ODM_EDCA_VO_PARAM 0x500
|
||||||
|
#define ODM_EDCA_VI_PARAM 0x504
|
||||||
|
#define ODM_EDCA_BE_PARAM 0x508
|
||||||
|
#define ODM_EDCA_BK_PARAM 0x50C
|
||||||
|
#define ODM_TXPAUSE 0x522
|
||||||
|
|
||||||
|
//BB REG
|
||||||
|
#define ODM_FPGA_PHY0_PAGE8 0x800
|
||||||
|
#define ODM_PSD_SETTING 0x808
|
||||||
|
#define ODM_AFE_SETTING 0x818
|
||||||
|
#define ODM_TXAGC_B_24_54 0x834
|
||||||
|
#define ODM_TXAGC_B_MCS32_5 0x838
|
||||||
|
#define ODM_TXAGC_B_MCS0_MCS3 0x83c
|
||||||
|
#define ODM_TXAGC_B_MCS4_MCS7 0x848
|
||||||
|
#define ODM_TXAGC_B_MCS8_MCS11 0x84c
|
||||||
|
#define ODM_ANALOG_REGISTER 0x85c
|
||||||
|
#define ODM_RF_INTERFACE_OUTPUT 0x860
|
||||||
|
#define ODM_TXAGC_B_MCS12_MCS15 0x868
|
||||||
|
#define ODM_TXAGC_B_11_A_2_11 0x86c
|
||||||
|
#define ODM_AD_DA_LSB_MASK 0x874
|
||||||
|
#define ODM_ENABLE_3_WIRE 0x88c
|
||||||
|
#define ODM_PSD_REPORT 0x8b4
|
||||||
|
#define ODM_R_ANT_SELECT 0x90c
|
||||||
|
#define ODM_CCK_ANT_SELECT 0xa07
|
||||||
|
#define ODM_CCK_PD_THRESH 0xa0a
|
||||||
|
#define ODM_CCK_RF_REG1 0xa11
|
||||||
|
#define ODM_CCK_MATCH_FILTER 0xa20
|
||||||
|
#define ODM_CCK_RAKE_MAC 0xa2e
|
||||||
|
#define ODM_CCK_CNT_RESET 0xa2d
|
||||||
|
#define ODM_CCK_TX_DIVERSITY 0xa2f
|
||||||
|
#define ODM_CCK_FA_CNT_MSB 0xa5b
|
||||||
|
#define ODM_CCK_FA_CNT_LSB 0xa5c
|
||||||
|
#define ODM_CCK_NEW_FUNCTION 0xa75
|
||||||
|
#define ODM_OFDM_PHY0_PAGE_C 0xc00
|
||||||
|
#define ODM_OFDM_RX_ANT 0xc04
|
||||||
|
#define ODM_R_A_RXIQI 0xc14
|
||||||
|
#define ODM_R_A_AGC_CORE1 0xc50
|
||||||
|
#define ODM_R_A_AGC_CORE2 0xc54
|
||||||
|
#define ODM_R_B_AGC_CORE1 0xc58
|
||||||
|
#define ODM_R_AGC_PAR 0xc70
|
||||||
|
#define ODM_R_HTSTF_AGC_PAR 0xc7c
|
||||||
|
#define ODM_TX_PWR_TRAINING_A 0xc90
|
||||||
|
#define ODM_TX_PWR_TRAINING_B 0xc98
|
||||||
|
#define ODM_OFDM_FA_CNT1 0xcf0
|
||||||
|
#define ODM_OFDM_PHY0_PAGE_D 0xd00
|
||||||
|
#define ODM_OFDM_FA_CNT2 0xda0
|
||||||
|
#define ODM_OFDM_FA_CNT3 0xda4
|
||||||
|
#define ODM_OFDM_FA_CNT4 0xda8
|
||||||
|
#define ODM_TXAGC_A_6_18 0xe00
|
||||||
|
#define ODM_TXAGC_A_24_54 0xe04
|
||||||
|
#define ODM_TXAGC_A_1_MCS32 0xe08
|
||||||
|
#define ODM_TXAGC_A_MCS0_MCS3 0xe10
|
||||||
|
#define ODM_TXAGC_A_MCS4_MCS7 0xe14
|
||||||
|
#define ODM_TXAGC_A_MCS8_MCS11 0xe18
|
||||||
|
#define ODM_TXAGC_A_MCS12_MCS15 0xe1c
|
||||||
|
|
||||||
|
//RF REG
|
||||||
|
#define ODM_GAIN_SETTING 0x00
|
||||||
|
#define ODM_CHANNEL 0x18
|
||||||
|
|
||||||
|
//Ant Detect Reg
|
||||||
|
#define ODM_DPDT 0x300
|
||||||
|
|
||||||
|
//PSD Init
|
||||||
|
#define ODM_PSDREG 0x808
|
||||||
|
|
||||||
|
//92D Path Div
|
||||||
|
#define PATHDIV_REG 0xB30
|
||||||
|
#define PATHDIV_TRI 0xBA0
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Bitmap Definition
|
||||||
|
//
|
||||||
|
|
||||||
|
#define BIT_FA_RESET BIT0
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
265
hal/OUTSRC/odm_types.h
Normal file
265
hal/OUTSRC/odm_types.h
Normal file
@ -0,0 +1,265 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef __ODM_TYPES_H__
|
||||||
|
#define __ODM_TYPES_H__
|
||||||
|
|
||||||
|
//
|
||||||
|
// Define Different SW team support
|
||||||
|
//
|
||||||
|
#define ODM_AP 0x01 //BIT0
|
||||||
|
#define ODM_ADSL 0x02 //BIT1
|
||||||
|
#define ODM_CE 0x04 //BIT2
|
||||||
|
#define ODM_WIN 0x08 //BIT3
|
||||||
|
|
||||||
|
#define DM_ODM_SUPPORT_TYPE ODM_CE
|
||||||
|
|
||||||
|
// Deifne HW endian support
|
||||||
|
#define ODM_ENDIAN_BIG 0
|
||||||
|
#define ODM_ENDIAN_LITTLE 1
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
|
||||||
|
#define RT_PCI_INTERFACE 1
|
||||||
|
#define RT_USB_INTERFACE 2
|
||||||
|
#define RT_SDIO_INTERFACE 3
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum _HAL_STATUS{
|
||||||
|
HAL_STATUS_SUCCESS,
|
||||||
|
HAL_STATUS_FAILURE,
|
||||||
|
/*RT_STATUS_PENDING,
|
||||||
|
RT_STATUS_RESOURCE,
|
||||||
|
RT_STATUS_INVALID_CONTEXT,
|
||||||
|
RT_STATUS_INVALID_PARAMETER,
|
||||||
|
RT_STATUS_NOT_SUPPORT,
|
||||||
|
RT_STATUS_OS_API_FAILED,*/
|
||||||
|
}HAL_STATUS,*PHAL_STATUS;
|
||||||
|
|
||||||
|
|
||||||
|
#if( (DM_ODM_SUPPORT_TYPE == ODM_AP) ||(DM_ODM_SUPPORT_TYPE == ODM_ADSL) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
|
||||||
|
|
||||||
|
#define VISTA_USB_RX_REVISE 0
|
||||||
|
|
||||||
|
//
|
||||||
|
// Declare for ODM spin lock defintion temporarily fro compile pass.
|
||||||
|
//
|
||||||
|
typedef enum _RT_SPINLOCK_TYPE{
|
||||||
|
RT_TX_SPINLOCK = 1,
|
||||||
|
RT_RX_SPINLOCK = 2,
|
||||||
|
RT_RM_SPINLOCK = 3,
|
||||||
|
RT_CAM_SPINLOCK = 4,
|
||||||
|
RT_SCAN_SPINLOCK = 5,
|
||||||
|
RT_LOG_SPINLOCK = 7,
|
||||||
|
RT_BW_SPINLOCK = 8,
|
||||||
|
RT_CHNLOP_SPINLOCK = 9,
|
||||||
|
RT_RF_OPERATE_SPINLOCK = 10,
|
||||||
|
RT_INITIAL_SPINLOCK = 11,
|
||||||
|
RT_RF_STATE_SPINLOCK = 12, // For RF state. Added by Bruce, 2007-10-30.
|
||||||
|
#if VISTA_USB_RX_REVISE
|
||||||
|
RT_USBRX_CONTEXT_SPINLOCK = 13,
|
||||||
|
RT_USBRX_POSTPROC_SPINLOCK = 14, // protect data of Adapter->IndicateW/ IndicateR
|
||||||
|
#endif
|
||||||
|
//Shall we define Ndis 6.2 SpinLock Here ?
|
||||||
|
RT_PORT_SPINLOCK=16,
|
||||||
|
RT_H2C_SPINLOCK = 20, // For H2C cmd. Added by tynli. 2009.11.09.
|
||||||
|
|
||||||
|
RT_BTData_SPINLOCK=25,
|
||||||
|
|
||||||
|
RT_WAPI_OPTION_SPINLOCK=26,
|
||||||
|
RT_WAPI_RX_SPINLOCK=27,
|
||||||
|
|
||||||
|
// add for 92D CCK control issue
|
||||||
|
RT_CCK_PAGEA_SPINLOCK = 28,
|
||||||
|
RT_BUFFER_SPINLOCK = 29,
|
||||||
|
RT_CHANNEL_AND_BANDWIDTH_SPINLOCK = 30,
|
||||||
|
RT_GEN_TEMP_BUF_SPINLOCK = 31,
|
||||||
|
RT_AWB_SPINLOCK = 32,
|
||||||
|
RT_FW_PS_SPINLOCK = 33,
|
||||||
|
RT_HW_TIMER_SPIN_LOCK = 34,
|
||||||
|
RT_MPT_WI_SPINLOCK = 35,
|
||||||
|
RT_P2P_SPIN_LOCK = 36, // Protect P2P context
|
||||||
|
RT_DBG_SPIN_LOCK = 37,
|
||||||
|
RT_IQK_SPINLOCK = 38,
|
||||||
|
RT_PENDED_OID_SPINLOCK = 39,
|
||||||
|
RT_CHNLLIST_SPINLOCK = 40,
|
||||||
|
RT_INDIC_SPINLOCK = 41, //protect indication
|
||||||
|
}RT_SPINLOCK_TYPE;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
||||||
|
#define STA_INFO_T RT_WLAN_STA
|
||||||
|
#define PSTA_INFO_T PRT_WLAN_STA
|
||||||
|
|
||||||
|
// typedef unsigned long u4Byte,*pu4Byte;
|
||||||
|
#define CONFIG_HW_ANTENNA_DIVERSITY
|
||||||
|
#define CONFIG_SW_ANTENNA_DIVERSITY
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
|
||||||
|
// To let ADSL/AP project compile ok; it should be removed after all conflict are solved. Added by Annie, 2011-10-07.
|
||||||
|
#define ADSL_AP_BUILD_WORKAROUND
|
||||||
|
#define AP_BUILD_WORKAROUND
|
||||||
|
//
|
||||||
|
#ifdef CONFIG_ANT_SWITCH
|
||||||
|
#define CONFIG_HW_ANTENNA_DIVERSITY
|
||||||
|
#if ( defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY) )
|
||||||
|
#define CONFIG_NOT_SUPPORT_ANTDIV
|
||||||
|
#elif( !defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY) )
|
||||||
|
#define CONFIG_2G_SUPPORT_ANTDIV
|
||||||
|
#elif( defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY) )
|
||||||
|
#define CONFIG_5G_SUPPORT_ANTDIV
|
||||||
|
#elif( !defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY) )
|
||||||
|
#define CONFIG_2G5G_SUPPORT_ANTDIV
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef AP_BUILD_WORKAROUND
|
||||||
|
#include "../typedef.h"
|
||||||
|
#else
|
||||||
|
typedef void VOID,*PVOID;
|
||||||
|
typedef unsigned char BOOLEAN,*PBOOLEAN;
|
||||||
|
typedef unsigned char u1Byte,*pu1Byte;
|
||||||
|
typedef unsigned short u2Byte,*pu2Byte;
|
||||||
|
typedef unsigned int u4Byte,*pu4Byte;
|
||||||
|
typedef unsigned long long u8Byte,*pu8Byte;
|
||||||
|
typedef char s1Byte,*ps1Byte;
|
||||||
|
typedef short s2Byte,*ps2Byte;
|
||||||
|
typedef long s4Byte,*ps4Byte;
|
||||||
|
typedef long long s8Byte,*ps8Byte;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct rtl8192cd_priv *prtl8192cd_priv;
|
||||||
|
typedef struct stat_info STA_INFO_T,*PSTA_INFO_T;
|
||||||
|
typedef struct timer_list RT_TIMER, *PRT_TIMER;
|
||||||
|
typedef void * RT_TIMER_CALL_BACK;
|
||||||
|
|
||||||
|
#define DEV_BUS_TYPE RT_PCI_INTERFACE
|
||||||
|
|
||||||
|
#define _TRUE 1
|
||||||
|
#define _FALSE 0
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_ADSL)
|
||||||
|
|
||||||
|
// To let ADSL/AP project compile ok; it should be removed after all conflict are solved. Added by Annie, 2011-10-07.
|
||||||
|
#define ADSL_AP_BUILD_WORKAROUND
|
||||||
|
#define ADSL_BUILD_WORKAROUND
|
||||||
|
//
|
||||||
|
|
||||||
|
typedef unsigned char BOOLEAN,*PBOOLEAN;
|
||||||
|
typedef unsigned char u1Byte,*pu1Byte;
|
||||||
|
typedef unsigned short u2Byte,*pu2Byte;
|
||||||
|
typedef unsigned int u4Byte,*pu4Byte;
|
||||||
|
typedef unsigned long long u8Byte,*pu8Byte;
|
||||||
|
typedef char s1Byte,*ps1Byte;
|
||||||
|
typedef short s2Byte,*ps2Byte;
|
||||||
|
typedef long s4Byte,*ps4Byte;
|
||||||
|
typedef long long s8Byte,*ps8Byte;
|
||||||
|
|
||||||
|
typedef struct rtl8192cd_priv *prtl8192cd_priv;
|
||||||
|
typedef struct stat_info STA_INFO_T,*PSTA_INFO_T;
|
||||||
|
typedef struct timer_list RT_TIMER, *PRT_TIMER;
|
||||||
|
typedef void * RT_TIMER_CALL_BACK;
|
||||||
|
|
||||||
|
#define DEV_BUS_TYPE RT_PCI_INTERFACE
|
||||||
|
|
||||||
|
#define _TRUE 1
|
||||||
|
#define _FALSE 0
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
|
||||||
|
#include <drv_types.h>
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
typedef u8 u1Byte, *pu1Byte;
|
||||||
|
typedef u16 u2Byte,*pu2Byte;
|
||||||
|
typedef u32 u4Byte,*pu4Byte;
|
||||||
|
typedef u64 u8Byte,*pu8Byte;
|
||||||
|
typedef s8 s1Byte,*ps1Byte;
|
||||||
|
typedef s16 s2Byte,*ps2Byte;
|
||||||
|
typedef s32 s4Byte,*ps4Byte;
|
||||||
|
typedef s64 s8Byte,*ps8Byte;
|
||||||
|
#else
|
||||||
|
#define u1Byte u8
|
||||||
|
#define pu1Byte u8*
|
||||||
|
|
||||||
|
#define u2Byte u16
|
||||||
|
#define pu2Byte u16*
|
||||||
|
|
||||||
|
#define u4Byte u32
|
||||||
|
#define pu4Byte u32*
|
||||||
|
|
||||||
|
#define u8Byte u64
|
||||||
|
#define pu8Byte u64*
|
||||||
|
|
||||||
|
#define s1Byte s8
|
||||||
|
#define ps1Byte s8*
|
||||||
|
|
||||||
|
#define s2Byte s16
|
||||||
|
#define ps2Byte s16*
|
||||||
|
|
||||||
|
#define s4Byte s32
|
||||||
|
#define ps4Byte s32*
|
||||||
|
|
||||||
|
#define s8Byte s64
|
||||||
|
#define ps8Byte s64*
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_USB_HCI
|
||||||
|
#define DEV_BUS_TYPE RT_USB_INTERFACE
|
||||||
|
#elif defined(CONFIG_PCI_HCI)
|
||||||
|
#define DEV_BUS_TYPE RT_PCI_INTERFACE
|
||||||
|
#elif defined(CONFIG_SDIO_HCI)
|
||||||
|
#define DEV_BUS_TYPE RT_SDIO_INTERFACE
|
||||||
|
#elif defined(CONFIG_GSPI_HCI)
|
||||||
|
#define DEV_BUS_TYPE RT_SDIO_INTERFACE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(CONFIG_LITTLE_ENDIAN)
|
||||||
|
#define ODM_ENDIAN_TYPE ODM_ENDIAN_LITTLE
|
||||||
|
#elif defined (CONFIG_BIG_ENDIAN)
|
||||||
|
#define ODM_ENDIAN_TYPE ODM_ENDIAN_BIG
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct timer_list RT_TIMER, *PRT_TIMER;
|
||||||
|
typedef void * RT_TIMER_CALL_BACK;
|
||||||
|
#define STA_INFO_T struct sta_info
|
||||||
|
#define PSTA_INFO_T struct sta_info *
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define TRUE _TRUE
|
||||||
|
#define FALSE _FALSE
|
||||||
|
|
||||||
|
|
||||||
|
#define SET_TX_DESC_ANTSEL_A_88E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 1, __Value)
|
||||||
|
#define SET_TX_DESC_ANTSEL_B_88E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 25, 1, __Value)
|
||||||
|
#define SET_TX_DESC_ANTSEL_C_88E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 29, 1, __Value)
|
||||||
|
|
||||||
|
//define useless flag to avoid compile warning
|
||||||
|
#define USE_WORKITEM 0
|
||||||
|
#define FOR_BRAZIL_PRETEST 0
|
||||||
|
#define FPGA_TWO_MAC_VERIFICATION 0
|
||||||
|
#define RTL8881A_SUPPORT 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __ODM_TYPES_H__
|
||||||
|
|
1089
hal/OUTSRC/rtl8192e/Hal8192EReg.h
Normal file
1089
hal/OUTSRC/rtl8192e/Hal8192EReg.h
Normal file
File diff suppressed because it is too large
Load Diff
796
hal/OUTSRC/rtl8192e/HalHWImg8192E_BB.c
Normal file
796
hal/OUTSRC/rtl8192e/HalHWImg8192E_BB.c
Normal file
File diff suppressed because it is too large
Load Diff
56
hal/OUTSRC/rtl8192e/HalHWImg8192E_BB.h
Normal file
56
hal/OUTSRC/rtl8192e/HalHWImg8192E_BB.h
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
#ifndef __INC_MP_BB_HW_IMG_8192E_H
|
||||||
|
#define __INC_MP_BB_HW_IMG_8192E_H
|
||||||
|
|
||||||
|
//static BOOLEAN CheckCondition(const u4Byte Condition, const u4Byte Hex);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* AGC_TAB.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_AGC_TAB( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* PHY_REG.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_PHY_REG( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* PHY_REG_PG.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_PHY_REG_PG( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif // end of HWIMG_SUPPORT
|
||||||
|
|
6559
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW.c
Normal file
6559
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW.c
Normal file
File diff suppressed because it is too large
Load Diff
61
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW.h
Normal file
61
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW.h
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
#ifndef __INC_MP_FW_HW_IMG_8192E_H
|
||||||
|
#define __INC_MP_FW_HW_IMG_8192E_H
|
||||||
|
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* FW_AP.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadFirmware_MP_8192E_FW_AP(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT u1Byte *pFirmware,
|
||||||
|
OUT u4Byte *pFirmwareSize
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* FW_NIC.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadFirmware_MP_8192E_FW_NIC(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT u1Byte *pFirmware,
|
||||||
|
OUT u4Byte *pFirmwareSize
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* FW_WoWLAN.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadFirmware_MP_8192E_FW_WoWLAN(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT u1Byte *pFirmware,
|
||||||
|
OUT u4Byte *pFirmwareSize
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif // end of HWIMG_SUPPORT
|
||||||
|
|
4831
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW_v18.c
Normal file
4831
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW_v18.c
Normal file
File diff suppressed because it is too large
Load Diff
61
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW_v18.h
Normal file
61
hal/OUTSRC/rtl8192e/HalHWImg8192E_FW_v18.h
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
#ifndef __INC_MP_FW_HW_IMG_8192E_H
|
||||||
|
#define __INC_MP_FW_HW_IMG_8192E_H
|
||||||
|
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* FW_AP.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadFirmware_MP_8192E_FW_AP_WoWLAN(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT u1Byte *pFirmware,
|
||||||
|
OUT u4Byte *pFirmwareSize
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* FW_NIC.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadFirmware_MP_8192E_FW_NIC(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT u1Byte *pFirmware,
|
||||||
|
OUT u4Byte *pFirmwareSize
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* FW_WoWLAN.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadFirmware_MP_8192E_FW_WoWLAN(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT u1Byte *pFirmware,
|
||||||
|
OUT u4Byte *pFirmwareSize
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif // end of HWIMG_SUPPORT
|
||||||
|
|
236
hal/OUTSRC/rtl8192e/HalHWImg8192E_MAC.c
Normal file
236
hal/OUTSRC/rtl8192e/HalHWImg8192E_MAC.c
Normal file
@ -0,0 +1,236 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#include "../odm_precomp.h"
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
static BOOLEAN
|
||||||
|
CheckCondition(
|
||||||
|
const u4Byte Condition,
|
||||||
|
const u4Byte Hex
|
||||||
|
)
|
||||||
|
{
|
||||||
|
u4Byte _board = (Hex & 0x000000FF);
|
||||||
|
u4Byte _interface = (Hex & 0x0000FF00) >> 8;
|
||||||
|
u4Byte _platform = (Hex & 0x00FF0000) >> 16;
|
||||||
|
u4Byte cond = Condition;
|
||||||
|
|
||||||
|
if ( Condition == 0xCDCDCDCD )
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
cond = Condition & 0x000000FF;
|
||||||
|
if ( (_board != cond) && (cond != 0xFF) )
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
cond = Condition & 0x0000FF00;
|
||||||
|
cond = cond >> 8;
|
||||||
|
if ( ((_interface & cond) == 0) && (cond != 0x07) )
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
cond = Condition & 0x00FF0000;
|
||||||
|
cond = cond >> 16;
|
||||||
|
if ( ((_platform & cond) == 0) && (cond != 0x0F) )
|
||||||
|
return FALSE;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* MAC_REG.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
u4Byte Array_MP_8192E_MAC_REG[] = {
|
||||||
|
0x011, 0x000000EB,
|
||||||
|
0x012, 0x00000007,
|
||||||
|
0x014, 0x00000075,
|
||||||
|
0x303, 0x000000A7,
|
||||||
|
0x428, 0x0000000A,
|
||||||
|
0x429, 0x00000010,
|
||||||
|
0x430, 0x00000000,
|
||||||
|
0x431, 0x00000000,
|
||||||
|
0x432, 0x00000000,
|
||||||
|
0x433, 0x00000001,
|
||||||
|
0x434, 0x00000004,
|
||||||
|
0x435, 0x00000005,
|
||||||
|
0x436, 0x00000007,
|
||||||
|
0x437, 0x00000008,
|
||||||
|
0x43C, 0x00000004,
|
||||||
|
0x43D, 0x00000005,
|
||||||
|
0x43E, 0x00000007,
|
||||||
|
0x43F, 0x00000008,
|
||||||
|
0x440, 0x0000005D,
|
||||||
|
0x441, 0x00000001,
|
||||||
|
0x442, 0x00000000,
|
||||||
|
0x444, 0x00000010,
|
||||||
|
0x445, 0x00000000,
|
||||||
|
0x446, 0x00000000,
|
||||||
|
0x447, 0x00000000,
|
||||||
|
0x448, 0x00000000,
|
||||||
|
0x449, 0x000000F0,
|
||||||
|
0x44A, 0x0000000F,
|
||||||
|
0x44B, 0x0000003E,
|
||||||
|
0x44C, 0x00000010,
|
||||||
|
0x44D, 0x00000000,
|
||||||
|
0x44E, 0x00000000,
|
||||||
|
0x44F, 0x00000000,
|
||||||
|
0x450, 0x00000000,
|
||||||
|
0x451, 0x000000F0,
|
||||||
|
0x452, 0x0000000F,
|
||||||
|
0x453, 0x00000000,
|
||||||
|
0x456, 0x0000005E,
|
||||||
|
0x460, 0x00000066,
|
||||||
|
0x461, 0x00000066,
|
||||||
|
0x4C8, 0x000000FF,
|
||||||
|
0x4C9, 0x00000008,
|
||||||
|
0x4CC, 0x000000FF,
|
||||||
|
0x4CD, 0x000000FF,
|
||||||
|
0x4CE, 0x00000001,
|
||||||
|
0x500, 0x00000026,
|
||||||
|
0x501, 0x000000A2,
|
||||||
|
0x502, 0x0000002F,
|
||||||
|
0x503, 0x00000000,
|
||||||
|
0x504, 0x00000028,
|
||||||
|
0x505, 0x000000A3,
|
||||||
|
0x506, 0x0000005E,
|
||||||
|
0x507, 0x00000000,
|
||||||
|
0x508, 0x0000002B,
|
||||||
|
0x509, 0x000000A4,
|
||||||
|
0x50A, 0x0000005E,
|
||||||
|
0x50B, 0x00000000,
|
||||||
|
0x50C, 0x0000004F,
|
||||||
|
0x50D, 0x000000A4,
|
||||||
|
0x50E, 0x00000000,
|
||||||
|
0x50F, 0x00000000,
|
||||||
|
0x512, 0x0000001C,
|
||||||
|
0x514, 0x0000000A,
|
||||||
|
0x516, 0x0000000A,
|
||||||
|
0x525, 0x0000004F,
|
||||||
|
0x540, 0x00000012,
|
||||||
|
0x541, 0x00000064,
|
||||||
|
0x550, 0x00000010,
|
||||||
|
0x551, 0x00000010,
|
||||||
|
0x559, 0x00000002,
|
||||||
|
0x55C, 0x00000050,
|
||||||
|
0x55D, 0x000000FF,
|
||||||
|
0x605, 0x00000030,
|
||||||
|
0x608, 0x0000000E,
|
||||||
|
0x609, 0x0000002A,
|
||||||
|
0x620, 0x000000FF,
|
||||||
|
0x621, 0x000000FF,
|
||||||
|
0x622, 0x000000FF,
|
||||||
|
0x623, 0x000000FF,
|
||||||
|
0x624, 0x000000FF,
|
||||||
|
0x625, 0x000000FF,
|
||||||
|
0x626, 0x000000FF,
|
||||||
|
0x627, 0x000000FF,
|
||||||
|
0x638, 0x00000050,
|
||||||
|
0x63C, 0x0000000A,
|
||||||
|
0x63D, 0x0000000A,
|
||||||
|
0x63E, 0x0000000E,
|
||||||
|
0x63F, 0x0000000E,
|
||||||
|
0x640, 0x00000040,
|
||||||
|
0x642, 0x00000040,
|
||||||
|
0x643, 0x00000000,
|
||||||
|
0x652, 0x000000C8,
|
||||||
|
0x66E, 0x00000005,
|
||||||
|
0x700, 0x00000021,
|
||||||
|
0x701, 0x00000043,
|
||||||
|
0x702, 0x00000065,
|
||||||
|
0x703, 0x00000087,
|
||||||
|
0x708, 0x00000021,
|
||||||
|
0x709, 0x00000043,
|
||||||
|
0x70A, 0x00000065,
|
||||||
|
0x70B, 0x00000087,
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_MAC_REG(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
)
|
||||||
|
{
|
||||||
|
#define READ_NEXT_PAIR(v1, v2, i) do { i += 2; v1 = Array[i]; v2 = Array[i+1]; } while(0)
|
||||||
|
|
||||||
|
u4Byte hex = 0;
|
||||||
|
u4Byte i = 0;
|
||||||
|
u2Byte count = 0;
|
||||||
|
pu4Byte ptr_array = NULL;
|
||||||
|
u1Byte platform = pDM_Odm->SupportPlatform;
|
||||||
|
u1Byte _interface = pDM_Odm->SupportInterface;
|
||||||
|
u1Byte board = pDM_Odm->BoardType;
|
||||||
|
u4Byte ArrayLen = sizeof(Array_MP_8192E_MAC_REG)/sizeof(u4Byte);
|
||||||
|
pu4Byte Array = Array_MP_8192E_MAC_REG;
|
||||||
|
|
||||||
|
|
||||||
|
hex += board;
|
||||||
|
hex += _interface << 8;
|
||||||
|
hex += platform << 16;
|
||||||
|
hex += 0xFF000000;
|
||||||
|
ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ReadAndConfig_MP_8192E_MAC_REG, hex = 0x%X\n", hex));
|
||||||
|
|
||||||
|
for (i = 0; i < ArrayLen; i += 2 )
|
||||||
|
{
|
||||||
|
u4Byte v1 = Array[i];
|
||||||
|
u4Byte v2 = Array[i+1];
|
||||||
|
|
||||||
|
// This (offset, data) pair meets the condition.
|
||||||
|
if ( v1 < 0xCDCDCDCD )
|
||||||
|
{
|
||||||
|
odm_ConfigMAC_8192E(pDM_Odm, v1, (u1Byte)v2);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{ // This line is the start line of branch.
|
||||||
|
if ( !CheckCondition(Array[i], hex) )
|
||||||
|
{ // Discard the following (offset, data) pairs.
|
||||||
|
READ_NEXT_PAIR(v1, v2, i);
|
||||||
|
while (v2 != 0xDEAD &&
|
||||||
|
v2 != 0xCDEF &&
|
||||||
|
v2 != 0xCDCD && i < ArrayLen -2)
|
||||||
|
{
|
||||||
|
READ_NEXT_PAIR(v1, v2, i);
|
||||||
|
}
|
||||||
|
i -= 2; // prevent from for-loop += 2
|
||||||
|
}
|
||||||
|
else // Configure matched pairs and skip to end of if-else.
|
||||||
|
{
|
||||||
|
READ_NEXT_PAIR(v1, v2, i);
|
||||||
|
while (v2 != 0xDEAD &&
|
||||||
|
v2 != 0xCDEF &&
|
||||||
|
v2 != 0xCDCD && i < ArrayLen -2)
|
||||||
|
{
|
||||||
|
odm_ConfigMAC_8192E(pDM_Odm, v1, (u1Byte)v2);
|
||||||
|
READ_NEXT_PAIR(v1, v2, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
while (v2 != 0xDEAD && i < ArrayLen -2)
|
||||||
|
{
|
||||||
|
READ_NEXT_PAIR(v1, v2, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // end of HWIMG_SUPPORT
|
||||||
|
|
38
hal/OUTSRC/rtl8192e/HalHWImg8192E_MAC.h
Normal file
38
hal/OUTSRC/rtl8192e/HalHWImg8192E_MAC.h
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
#ifndef __INC_MP_MAC_HW_IMG_8192E_H
|
||||||
|
#define __INC_MP_MAC_HW_IMG_8192E_H
|
||||||
|
|
||||||
|
//static BOOLEAN CheckCondition(const u4Byte Condition, const u4Byte Hex);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* MAC_REG.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_MAC_REG( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif // end of HWIMG_SUPPORT
|
||||||
|
|
988
hal/OUTSRC/rtl8192e/HalHWImg8192E_RF.c
Normal file
988
hal/OUTSRC/rtl8192e/HalHWImg8192E_RF.c
Normal file
File diff suppressed because it is too large
Load Diff
83
hal/OUTSRC/rtl8192e/HalHWImg8192E_RF.h
Normal file
83
hal/OUTSRC/rtl8192e/HalHWImg8192E_RF.h
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
#ifndef __INC_MP_RF_HW_IMG_8192E_H
|
||||||
|
#define __INC_MP_RF_HW_IMG_8192E_H
|
||||||
|
|
||||||
|
//static BOOLEAN CheckCondition(const u4Byte Condition, const u4Byte Hex);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* RadioA.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_RadioA( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* RadioB.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_RadioB( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* TxPowerTrack_AP.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_TxPowerTrack_AP( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* TxPowerTrack_PCIE.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_TxPowerTrack_PCIE( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* TxPowerTrack_USB.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_TxPowerTrack_USB( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* TXPWR_LMT.TXT
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
ODM_ReadAndConfig_MP_8192E_TXPWR_LMT( // TC: Test Chip, MP: MP Chip
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif // end of HWIMG_SUPPORT
|
||||||
|
|
3796
hal/OUTSRC/rtl8192e/HalPhyRf_8192e.c
Normal file
3796
hal/OUTSRC/rtl8192e/HalPhyRf_8192e.c
Normal file
File diff suppressed because it is too large
Load Diff
131
hal/OUTSRC/rtl8192e/HalPhyRf_8192e.h
Normal file
131
hal/OUTSRC/rtl8192e/HalPhyRf_8192e.h
Normal file
@ -0,0 +1,131 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __HAL_PHY_RF_8192E_H__
|
||||||
|
#define __HAL_PHY_RF_8192E_H__
|
||||||
|
|
||||||
|
/*--------------------------Define Parameters-------------------------------*/
|
||||||
|
#define IQK_DELAY_TIME_92E 10 //ms
|
||||||
|
#define index_mapping_NUM_92E 15
|
||||||
|
#define AVG_THERMAL_NUM_92E 4
|
||||||
|
|
||||||
|
#include "../HalPhyRf.h"
|
||||||
|
|
||||||
|
void ConfigureTxpowerTrack_8192E(
|
||||||
|
PTXPWRTRACK_CFG pConfig
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
GetDeltaSwingTable_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
OUT pu1Byte *TemperatureUP_A,
|
||||||
|
OUT pu1Byte *TemperatureDOWN_A,
|
||||||
|
OUT pu1Byte *TemperatureUP_B,
|
||||||
|
OUT pu1Byte *TemperatureDOWN_B
|
||||||
|
);
|
||||||
|
|
||||||
|
void DoIQK_8192E(
|
||||||
|
PDM_ODM_T pDM_Odm,
|
||||||
|
u1Byte DeltaThermalIndex,
|
||||||
|
u1Byte ThermalValue,
|
||||||
|
u1Byte Threshold
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ODM_TxPwrTrackSetPwr92E(
|
||||||
|
PDM_ODM_T pDM_Odm,
|
||||||
|
PWRTRACK_METHOD Method,
|
||||||
|
u1Byte RFPath,
|
||||||
|
u1Byte ChannelMappedIndex
|
||||||
|
);
|
||||||
|
|
||||||
|
//1 7. IQK
|
||||||
|
|
||||||
|
void
|
||||||
|
PHY_IQCalibrate_8192E(
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
#else
|
||||||
|
IN PADAPTER Adapter,
|
||||||
|
#endif
|
||||||
|
IN BOOLEAN bReCovery);
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// LC calibrate
|
||||||
|
//
|
||||||
|
void
|
||||||
|
PHY_LCCalibrate_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
//
|
||||||
|
// AP calibrate
|
||||||
|
//
|
||||||
|
void
|
||||||
|
PHY_APCalibrate_8192E(
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
#else
|
||||||
|
IN PADAPTER pAdapter,
|
||||||
|
#endif
|
||||||
|
IN s1Byte delta);
|
||||||
|
void
|
||||||
|
PHY_DigitalPredistortion_8192E( IN PADAPTER pAdapter);
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
_PHY_SaveADDARegisters_92E(
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
#else
|
||||||
|
IN PADAPTER pAdapter,
|
||||||
|
#endif
|
||||||
|
IN pu4Byte ADDAReg,
|
||||||
|
IN pu4Byte ADDABackup,
|
||||||
|
IN u4Byte RegisterNum
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
_PHY_PathADDAOn_92E(
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
#else
|
||||||
|
IN PADAPTER pAdapter,
|
||||||
|
#endif
|
||||||
|
IN pu4Byte ADDAReg,
|
||||||
|
IN BOOLEAN isPathAOn,
|
||||||
|
IN BOOLEAN is2T
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
_PHY_MACSettingCalibration_92E(
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
#else
|
||||||
|
IN PADAPTER pAdapter,
|
||||||
|
#endif
|
||||||
|
IN pu4Byte MACReg,
|
||||||
|
IN pu4Byte MACBackup
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
#endif // #ifndef __HAL_PHY_RF_8188E_H__
|
||||||
|
|
437
hal/OUTSRC/rtl8192e/odm_RTL8192E.c
Normal file
437
hal/OUTSRC/rtl8192e/odm_RTL8192E.c
Normal file
@ -0,0 +1,437 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
//============================================================
|
||||||
|
// include files
|
||||||
|
//============================================================
|
||||||
|
|
||||||
|
|
||||||
|
#include "../odm_precomp.h"
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_Write_Dynamic_CCA(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u1Byte CurrentMFstate
|
||||||
|
)
|
||||||
|
{
|
||||||
|
pPri_CCA_T PrimaryCCA = &(pDM_Odm->DM_PriCCA);
|
||||||
|
|
||||||
|
if (PrimaryCCA->MF_state != CurrentMFstate){
|
||||||
|
|
||||||
|
ODM_SetBBReg(pDM_Odm, ODM_REG_L1SBD_PD_CH_11N, BIT8|BIT7, CurrentMFstate);
|
||||||
|
}
|
||||||
|
|
||||||
|
PrimaryCCA->MF_state = CurrentMFstate;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_PrimaryCCA_Check_Init(
|
||||||
|
IN PDM_ODM_T pDM_Odm)
|
||||||
|
{
|
||||||
|
#if((DM_ODM_SUPPORT_TYPE==ODM_WIN) ||(DM_ODM_SUPPORT_TYPE==ODM_AP))
|
||||||
|
PADAPTER pAdapter = pDM_Odm->Adapter;
|
||||||
|
pPri_CCA_T PrimaryCCA = &(pDM_Odm->DM_PriCCA);
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
|
||||||
|
|
||||||
|
pHalData->RTSEN = 0;
|
||||||
|
PrimaryCCA->DupRTS_flag = 0;
|
||||||
|
PrimaryCCA->intf_flag = 0;
|
||||||
|
PrimaryCCA->intf_type = 0;
|
||||||
|
PrimaryCCA->Monitor_flag = 0;
|
||||||
|
PrimaryCCA->PriCCA_flag = 0;
|
||||||
|
PrimaryCCA->CH_offset = 0;
|
||||||
|
PrimaryCCA->MF_state = 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_DynamicPrimaryCCA_Check(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if(pDM_Odm->SupportICType != ODM_RTL8192E)
|
||||||
|
return;
|
||||||
|
|
||||||
|
switch (pDM_Odm->SupportPlatform)
|
||||||
|
{
|
||||||
|
case ODM_WIN:
|
||||||
|
|
||||||
|
#if(DM_ODM_SUPPORT_TYPE==ODM_WIN)
|
||||||
|
odm_DynamicPrimaryCCAMP(pDM_Odm);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ODM_CE:
|
||||||
|
#if(DM_ODM_SUPPORT_TYPE==ODM_CE)
|
||||||
|
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ODM_AP:
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
odm_DynamicPrimaryCCAAP(pDM_Odm);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if(DM_ODM_SUPPORT_TYPE==ODM_WIN)
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_DynamicPrimaryCCAMP(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
)
|
||||||
|
{
|
||||||
|
PADAPTER pAdapter = pDM_Odm->Adapter;
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
|
||||||
|
PFALSE_ALARM_STATISTICS FalseAlmCnt = &(pDM_Odm->FalseAlmCnt);
|
||||||
|
pPri_CCA_T PrimaryCCA = &(pDM_Odm->DM_PriCCA);
|
||||||
|
BOOLEAN Is40MHz = FALSE;
|
||||||
|
u8Byte OFDM_CCA, OFDM_FA, BW_USC_Cnt, BW_LSC_Cnt;
|
||||||
|
u1Byte SecCHOffset;
|
||||||
|
u1Byte CurMFstate;
|
||||||
|
static u1Byte CountDown = Monitor_TIME;
|
||||||
|
|
||||||
|
OFDM_CCA = FalseAlmCnt->Cnt_OFDM_CCA;
|
||||||
|
OFDM_FA = FalseAlmCnt->Cnt_Ofdm_fail;
|
||||||
|
BW_USC_Cnt = FalseAlmCnt->Cnt_BW_USC;
|
||||||
|
BW_LSC_Cnt = FalseAlmCnt->Cnt_BW_LSC;
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: OFDM CCA=%d\n", OFDM_CCA));
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: OFDM FA=%d\n", OFDM_FA));
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: BW_USC=%d\n", BW_USC_Cnt));
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: BW_LSC=%d\n", BW_LSC_Cnt));
|
||||||
|
Is40MHz = *(pDM_Odm->pBandWidth);
|
||||||
|
SecCHOffset = *(pDM_Odm->pSecChOffset); // NIC: 2: sec is below, 1: sec is above
|
||||||
|
//DbgPrint("92E: SecCHOffset = %d\n", SecCHOffset);
|
||||||
|
if(IsAPModeExist(pAdapter)){
|
||||||
|
CurMFstate = MF_USC_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!pDM_Odm->bLinked){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
|
||||||
|
if(Is40MHz){
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: Cont Down= %d\n", CountDown));
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: Primary_CCA_flag=%d\n", PrimaryCCA->PriCCA_flag));
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: Intf_Type=%d\n", PrimaryCCA->intf_type));
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: Intf_flag=%d\n", PrimaryCCA->intf_flag ));
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_PRICCA, ODM_DBG_LOUD, ("92E: Duplicate RTS Flag=%d\n", PrimaryCCA->DupRTS_flag));
|
||||||
|
//DbgPrint("92E RTS_EN=%d\n", pHalData->RTSEN);
|
||||||
|
|
||||||
|
if(PrimaryCCA->PriCCA_flag == 0){
|
||||||
|
|
||||||
|
if(SecCHOffset == 2){ // Primary channel is above NOTE: duplicate CTS can remove this condition
|
||||||
|
|
||||||
|
if((OFDM_CCA > OFDMCCA_TH) && (BW_LSC_Cnt>(BW_USC_Cnt + BW_Ind_Bias))
|
||||||
|
&& (OFDM_FA>(OFDM_CCA>>1))){
|
||||||
|
|
||||||
|
PrimaryCCA->intf_type = 1;
|
||||||
|
PrimaryCCA->intf_flag = 1;
|
||||||
|
CurMFstate = MF_USC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
PrimaryCCA->PriCCA_flag = 1;
|
||||||
|
}
|
||||||
|
else if((OFDM_CCA > OFDMCCA_TH) && (BW_LSC_Cnt>(BW_USC_Cnt + BW_Ind_Bias))
|
||||||
|
&& (OFDM_FA < (OFDM_CCA>>1))){
|
||||||
|
|
||||||
|
PrimaryCCA->intf_type = 2;
|
||||||
|
PrimaryCCA->intf_flag = 1;
|
||||||
|
CurMFstate = MF_USC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
PrimaryCCA->PriCCA_flag = 1;
|
||||||
|
PrimaryCCA->DupRTS_flag = 1;
|
||||||
|
pHalData->RTSEN = 1;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
|
||||||
|
PrimaryCCA->intf_type = 0;
|
||||||
|
PrimaryCCA->intf_flag = 0;
|
||||||
|
CurMFstate = MF_USC_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
pHalData->RTSEN = 0;
|
||||||
|
PrimaryCCA->DupRTS_flag = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else if (SecCHOffset == 1){
|
||||||
|
|
||||||
|
if((OFDM_CCA > OFDMCCA_TH) && (BW_USC_Cnt > (BW_LSC_Cnt + BW_Ind_Bias))
|
||||||
|
&& (OFDM_FA > (OFDM_CCA>>1))){
|
||||||
|
|
||||||
|
PrimaryCCA->intf_type = 1;
|
||||||
|
PrimaryCCA->intf_flag = 1;
|
||||||
|
CurMFstate = MF_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
PrimaryCCA->PriCCA_flag = 1;
|
||||||
|
}
|
||||||
|
else if((OFDM_CCA > OFDMCCA_TH) && (BW_USC_Cnt>(BW_LSC_Cnt + BW_Ind_Bias))
|
||||||
|
&& (OFDM_FA < (OFDM_CCA>>1))){
|
||||||
|
|
||||||
|
PrimaryCCA->intf_type = 2;
|
||||||
|
PrimaryCCA->intf_flag = 1;
|
||||||
|
CurMFstate = MF_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
PrimaryCCA->PriCCA_flag = 1;
|
||||||
|
PrimaryCCA->DupRTS_flag = 1;
|
||||||
|
pHalData->RTSEN = 1;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
|
||||||
|
PrimaryCCA->intf_type = 0;
|
||||||
|
PrimaryCCA->intf_flag = 0;
|
||||||
|
CurMFstate = MF_USC_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
pHalData->RTSEN = 0;
|
||||||
|
PrimaryCCA->DupRTS_flag = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else{ // PrimaryCCA->PriCCA_flag==1
|
||||||
|
|
||||||
|
CountDown--;
|
||||||
|
if(CountDown == 0){
|
||||||
|
CountDown = Monitor_TIME;
|
||||||
|
PrimaryCCA->PriCCA_flag = 0;
|
||||||
|
CurMFstate = MF_USC_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate); // default
|
||||||
|
pHalData->RTSEN = 0;
|
||||||
|
PrimaryCCA->DupRTS_flag = 0;
|
||||||
|
PrimaryCCA->intf_type = 0;
|
||||||
|
PrimaryCCA->intf_flag = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif(DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_DynamicPrimaryCCAAP(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
)
|
||||||
|
{
|
||||||
|
PADAPTER Adapter = pDM_Odm->Adapter;
|
||||||
|
prtl8192cd_priv priv = pDM_Odm->priv;
|
||||||
|
PFALSE_ALARM_STATISTICS FalseAlmCnt = &(pDM_Odm->FalseAlmCnt);
|
||||||
|
pPri_CCA_T PrimaryCCA = &(pDM_Odm->DM_PriCCA);
|
||||||
|
|
||||||
|
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
|
||||||
|
u1Byte i;
|
||||||
|
static u4Byte Count_Down = Monitor_TIME;
|
||||||
|
BOOLEAN STA_BW = FALSE, STA_BW_pre = FALSE, STA_BW_TMP = FALSE;
|
||||||
|
BOOLEAN bConnected = FALSE;
|
||||||
|
BOOLEAN Is40MHz = FALSE;
|
||||||
|
u1Byte SecCHOffset;
|
||||||
|
u1Byte CurMFstate;
|
||||||
|
PSTA_INFO_T pstat;
|
||||||
|
|
||||||
|
Is40MHz = *(pDM_Odm->pBandWidth);
|
||||||
|
SecCHOffset = *(pDM_Odm->pSecChOffset); // AP: 1: sec is below, 2: sec is above
|
||||||
|
|
||||||
|
|
||||||
|
for(i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++){
|
||||||
|
pstat = pDM_Odm->pODM_StaInfo[i];
|
||||||
|
if(IS_STA_VALID(pstat)){
|
||||||
|
|
||||||
|
STA_BW_TMP = pstat->tx_bw;
|
||||||
|
if(STA_BW_TMP > STA_BW){
|
||||||
|
STA_BW = STA_BW_TMP;
|
||||||
|
}
|
||||||
|
bConnected = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(Is40MHz){
|
||||||
|
|
||||||
|
if(PrimaryCCA->PriCCA_flag == 0){
|
||||||
|
|
||||||
|
if(bConnected){
|
||||||
|
|
||||||
|
if(STA_BW == 0){ //2 STA BW=20M
|
||||||
|
|
||||||
|
PrimaryCCA->PriCCA_flag = 1;
|
||||||
|
if(SecCHOffset==1){
|
||||||
|
CurMFstate = MF_USC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
}
|
||||||
|
else if(SecCHOffset==2){
|
||||||
|
CurMFstate = MF_USC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{ //2 STA BW=40M
|
||||||
|
if(PrimaryCCA->intf_flag == 0){
|
||||||
|
|
||||||
|
odm_Intf_Detection(pDM_Odm);
|
||||||
|
}
|
||||||
|
else{ // intf_flag = 1
|
||||||
|
|
||||||
|
if(PrimaryCCA->intf_type == 1){
|
||||||
|
|
||||||
|
if(PrimaryCCA->CH_offset == 1){
|
||||||
|
|
||||||
|
CurMFstate = MF_USC;
|
||||||
|
if(SecCHOffset == 1){ // AP, 1: primary is above 2: primary is below
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(PrimaryCCA->CH_offset == 2){
|
||||||
|
|
||||||
|
CurMFstate = MF_LSC;
|
||||||
|
if(SecCHOffset == 2){
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(PrimaryCCA->intf_type==2){
|
||||||
|
|
||||||
|
if(PrimaryCCA->CH_offset==1){
|
||||||
|
|
||||||
|
//ODM_SetBBReg(pDM_Odm, ODM_REG_L1SBD_PD_CH_11N, BIT8|BIT7, MF_USC);
|
||||||
|
pHalData->RTSEN = 1;
|
||||||
|
}
|
||||||
|
else if(PrimaryCCA->CH_offset==2){
|
||||||
|
|
||||||
|
//ODM_SetBBReg(pDM_Odm, ODM_REG_L1SBD_PD_CH_11N, BIT8|BIT7, MF_LSC);
|
||||||
|
pHalData->RTSEN = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else{ // disconnected interference detection
|
||||||
|
|
||||||
|
odm_Intf_Detection(pDM_Odm);
|
||||||
|
}// end of disconnected
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
else{ // PrimaryCCA->PriCCA_flag == 1
|
||||||
|
|
||||||
|
if(STA_BW==0){
|
||||||
|
|
||||||
|
STA_BW_pre = STA_BW;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Count_Down--;
|
||||||
|
if((Count_Down == 0) || ((STA_BW & STA_BW_pre) != 1)){
|
||||||
|
|
||||||
|
Count_Down = Monitor_TIME;
|
||||||
|
PrimaryCCA->PriCCA_flag = 0;
|
||||||
|
PrimaryCCA->intf_type = 0;
|
||||||
|
PrimaryCCA->intf_flag = 0;
|
||||||
|
CurMFstate = MF_USC_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate); // default
|
||||||
|
pHalData->RTSEN = 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
STA_BW_pre = STA_BW;
|
||||||
|
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
//2 Reset
|
||||||
|
odm_PrimaryCCA_Check_Init(pDM_Odm);
|
||||||
|
CurMFstate = MF_USC_LSC;
|
||||||
|
odm_Write_Dynamic_CCA(pDM_Odm, CurMFstate);
|
||||||
|
Count_Down = Monitor_TIME;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_Intf_Detection(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
)
|
||||||
|
{
|
||||||
|
PFALSE_ALARM_STATISTICS FalseAlmCnt = &(pDM_Odm->FalseAlmCnt);
|
||||||
|
pPri_CCA_T PrimaryCCA = &(pDM_Odm->DM_PriCCA);
|
||||||
|
|
||||||
|
if((FalseAlmCnt->Cnt_OFDM_CCA>OFDMCCA_TH)
|
||||||
|
&&(FalseAlmCnt->Cnt_BW_LSC>(FalseAlmCnt->Cnt_BW_USC+BW_Ind_Bias))){
|
||||||
|
|
||||||
|
PrimaryCCA->intf_flag = 1;
|
||||||
|
PrimaryCCA->CH_offset = 1; // 1:LSC, 2:USC
|
||||||
|
if(FalseAlmCnt->Cnt_Ofdm_fail>(FalseAlmCnt->Cnt_OFDM_CCA>>1)){
|
||||||
|
PrimaryCCA->intf_type = 1;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
PrimaryCCA->intf_type = 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if((FalseAlmCnt->Cnt_OFDM_CCA>OFDMCCA_TH)
|
||||||
|
&&(FalseAlmCnt->Cnt_BW_USC>(FalseAlmCnt->Cnt_BW_LSC+BW_Ind_Bias))){
|
||||||
|
|
||||||
|
PrimaryCCA->intf_flag = 1;
|
||||||
|
PrimaryCCA->CH_offset = 2; // 1:LSC, 2:USC
|
||||||
|
if(FalseAlmCnt->Cnt_Ofdm_fail>(FalseAlmCnt->Cnt_OFDM_CCA>>1)){
|
||||||
|
PrimaryCCA->intf_type = 1;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
PrimaryCCA->intf_type = 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
PrimaryCCA->intf_flag = 0;
|
||||||
|
PrimaryCCA->intf_type = 0;
|
||||||
|
PrimaryCCA->CH_offset = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif // RTL8192E_SUPPORT == 1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
67
hal/OUTSRC/rtl8192e/odm_RTL8192E.h
Normal file
67
hal/OUTSRC/rtl8192e/odm_RTL8192E.h
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef __ODM_RTL8192E_H__
|
||||||
|
#define __ODM_RTL8192E_H__
|
||||||
|
|
||||||
|
#define OFDMCCA_TH 500
|
||||||
|
#define BW_Ind_Bias 500
|
||||||
|
#define MF_USC 2
|
||||||
|
#define MF_LSC 1
|
||||||
|
#define MF_USC_LSC 0
|
||||||
|
#define Monitor_TIME 30
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_Write_Dynamic_CCA(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u1Byte CurrentMFstate
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_PrimaryCCA_Check_Init(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_DynamicPrimaryCCA_Check(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_DynamicPrimaryCCAMP(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_DynamicPrimaryCCAAP(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
odm_Intf_Detection(
|
||||||
|
IN PDM_ODM_T pDM_Odm
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
235
hal/OUTSRC/rtl8192e/odm_RegConfig8192E.c
Normal file
235
hal/OUTSRC/rtl8192e/odm_RegConfig8192E.c
Normal file
@ -0,0 +1,235 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
#include "../odm_precomp.h"
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigRFReg_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Data,
|
||||||
|
IN ODM_RF_RADIO_PATH_E RF_PATH,
|
||||||
|
IN u4Byte RegAddr
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if(Addr == 0xfe || Addr == 0xffe)
|
||||||
|
{
|
||||||
|
#ifdef CONFIG_LONG_DELAY_ISSUE
|
||||||
|
ODM_sleep_ms(50);
|
||||||
|
#else
|
||||||
|
ODM_delay_ms(50);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ODM_SetRFReg(pDM_Odm, RF_PATH, RegAddr, bRFRegOffsetMask, Data);
|
||||||
|
// Add 1us delay between BB/RF register setting.
|
||||||
|
ODM_delay_us(1);
|
||||||
|
|
||||||
|
|
||||||
|
//For disable/enable test in high temperature, the B6 value will fail to fill. Suggestion by Ed 20130.
|
||||||
|
if(Addr == 0xb6)
|
||||||
|
{
|
||||||
|
u4Byte getvalue=0;
|
||||||
|
u1Byte count =0;
|
||||||
|
getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);
|
||||||
|
|
||||||
|
ODM_delay_us(1);
|
||||||
|
|
||||||
|
while((getvalue>>8)!=(Data>>8))
|
||||||
|
{
|
||||||
|
count++;
|
||||||
|
ODM_SetRFReg(pDM_Odm, RF_PATH, RegAddr, bRFRegOffsetMask, Data);
|
||||||
|
ODM_delay_us(1);
|
||||||
|
getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [B6] getvalue 0x%x, Data 0x%x, count %d\n", getvalue, Data,count));
|
||||||
|
if(count>5)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(Addr == 0xb2)
|
||||||
|
{
|
||||||
|
u4Byte getvalue=0;
|
||||||
|
u1Byte count =0;
|
||||||
|
getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);
|
||||||
|
|
||||||
|
ODM_delay_us(1);
|
||||||
|
|
||||||
|
while(getvalue!=Data)
|
||||||
|
{
|
||||||
|
count++;
|
||||||
|
ODM_SetRFReg(pDM_Odm, RF_PATH, RegAddr, bRFRegOffsetMask, Data);
|
||||||
|
ODM_delay_us(1);
|
||||||
|
//Do LCK againg
|
||||||
|
ODM_SetRFReg(pDM_Odm, RF_PATH, 0x18, bRFRegOffsetMask, 0x0fc07);
|
||||||
|
ODM_delay_us(1);
|
||||||
|
getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [B2] getvalue 0x%x, Data 0x%x, count %d\n", getvalue, Data,count));
|
||||||
|
if(count>5)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigRF_RadioA_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Data
|
||||||
|
)
|
||||||
|
{
|
||||||
|
u4Byte content = 0x1000; // RF_Content: radioa_txt
|
||||||
|
u4Byte maskforPhySet= (u4Byte)(content&0xE000);
|
||||||
|
|
||||||
|
odm_ConfigRFReg_8192E(pDM_Odm, Addr, Data, ODM_RF_PATH_A, Addr|maskforPhySet);
|
||||||
|
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [RadioA] %08X %08X\n", Addr, Data));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigRF_RadioB_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Data
|
||||||
|
)
|
||||||
|
{
|
||||||
|
u4Byte content = 0x1001; // RF_Content: radiob_txt
|
||||||
|
u4Byte maskforPhySet= (u4Byte)(content&0xE000);
|
||||||
|
|
||||||
|
odm_ConfigRFReg_8192E(pDM_Odm, Addr, Data, ODM_RF_PATH_B, Addr|maskforPhySet);
|
||||||
|
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [RadioB] %08X %08X\n", Addr, Data));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigMAC_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u1Byte Data
|
||||||
|
)
|
||||||
|
{
|
||||||
|
ODM_Write1Byte(pDM_Odm, Addr, Data);
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigMACWithHeaderFile: [MAC_REG] %08X %08X\n", Addr, Data));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_AGC_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Bitmask,
|
||||||
|
IN u4Byte Data
|
||||||
|
)
|
||||||
|
{
|
||||||
|
ODM_SetBBReg(pDM_Odm, Addr, Bitmask, Data);
|
||||||
|
// Add 1us delay between BB/RF register setting.
|
||||||
|
ODM_delay_us(1);
|
||||||
|
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigBBWithHeaderFile: [AGC_TAB] %08X %08X\n", Addr, Data));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_PHY_REG_PG_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Band,
|
||||||
|
IN u4Byte RfPath,
|
||||||
|
IN u4Byte TxNum,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Bitmask,
|
||||||
|
IN u4Byte Data
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if (Addr == 0xfe || Addr == 0xffe)
|
||||||
|
#ifdef CONFIG_LONG_DELAY_ISSUE
|
||||||
|
ODM_sleep_ms(50);
|
||||||
|
#else
|
||||||
|
ODM_delay_ms(50);
|
||||||
|
#endif
|
||||||
|
else
|
||||||
|
{
|
||||||
|
#if !(DM_ODM_SUPPORT_TYPE&ODM_AP)
|
||||||
|
PHY_StoreTxPowerByRate(pDM_Odm->Adapter, Band, RfPath, TxNum, Addr, Bitmask, Data);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ConfigBBWithHeaderFile: [PHY_REG] %08X %08X %08X\n", Addr, Bitmask, Data));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_PHY_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Bitmask,
|
||||||
|
IN u4Byte Data
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if (Addr == 0xfe)
|
||||||
|
#ifdef CONFIG_LONG_DELAY_ISSUE
|
||||||
|
ODM_sleep_ms(50);
|
||||||
|
#else
|
||||||
|
ODM_delay_ms(50);
|
||||||
|
#endif
|
||||||
|
else if (Addr == 0xfd)
|
||||||
|
ODM_delay_ms(5);
|
||||||
|
else if (Addr == 0xfc)
|
||||||
|
ODM_delay_ms(1);
|
||||||
|
else if (Addr == 0xfb)
|
||||||
|
ODM_delay_us(50);
|
||||||
|
else if (Addr == 0xfa)
|
||||||
|
ODM_delay_us(5);
|
||||||
|
else if (Addr == 0xf9)
|
||||||
|
ODM_delay_us(1);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ODM_SetBBReg(pDM_Odm, Addr, Bitmask, Data);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add 1us delay between BB/RF register setting.
|
||||||
|
ODM_delay_us(1);
|
||||||
|
ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigBBWithHeaderFile: [PHY_REG] %08X %08X\n", Addr, Data));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_TXPWR_LMT_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN pu1Byte Regulation,
|
||||||
|
IN pu1Byte Band,
|
||||||
|
IN pu1Byte Bandwidth,
|
||||||
|
IN pu1Byte RateSection,
|
||||||
|
IN pu1Byte RfPath,
|
||||||
|
IN pu1Byte Channel,
|
||||||
|
IN pu1Byte PowerLimit
|
||||||
|
)
|
||||||
|
{
|
||||||
|
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
|
||||||
|
PHY_SetTxPowerLimit(pDM_Odm, Regulation, Band,
|
||||||
|
Bandwidth, RateSection, RfPath, Channel, PowerLimit);
|
||||||
|
#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
|
||||||
|
PHY_SetTxPowerLimit(pDM_Odm->Adapter, Regulation, Band,
|
||||||
|
Bandwidth, RateSection, RfPath, Channel, PowerLimit);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
98
hal/OUTSRC/rtl8192e/odm_RegConfig8192E.h
Normal file
98
hal/OUTSRC/rtl8192e/odm_RegConfig8192E.h
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef __INC_ODM_REGCONFIG_H_8192E
|
||||||
|
#define __INC_ODM_REGCONFIG_H_8192E
|
||||||
|
|
||||||
|
#if (RTL8192E_SUPPORT == 1)
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigRFReg_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Data,
|
||||||
|
IN ODM_RF_RADIO_PATH_E RF_PATH,
|
||||||
|
IN u4Byte RegAddr
|
||||||
|
);
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigRF_RadioA_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigRF_RadioB_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigMAC_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u1Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_AGC_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Bitmask,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_PHY_REG_PG_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Band,
|
||||||
|
IN u4Byte RfPath,
|
||||||
|
IN u4Byte TxNum,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Bitmask,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_PHY_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN u4Byte Addr,
|
||||||
|
IN u4Byte Bitmask,
|
||||||
|
IN u4Byte Data
|
||||||
|
);
|
||||||
|
|
||||||
|
void
|
||||||
|
odm_ConfigBB_TXPWR_LMT_8192E(
|
||||||
|
IN PDM_ODM_T pDM_Odm,
|
||||||
|
IN pu1Byte Regulation,
|
||||||
|
IN pu1Byte Band,
|
||||||
|
IN pu1Byte Bandwidth,
|
||||||
|
IN pu1Byte RateSection,
|
||||||
|
IN pu1Byte RfPath,
|
||||||
|
IN pu1Byte Channel,
|
||||||
|
IN pu1Byte PowerLimit
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif // end of SUPPORT
|
||||||
|
|
||||||
|
|
2887
hal/hal_btcoex.c
Normal file
2887
hal/hal_btcoex.c
Normal file
File diff suppressed because it is too large
Load Diff
1648
hal/hal_com.c
Normal file
1648
hal/hal_com.c
Normal file
File diff suppressed because it is too large
Load Diff
4068
hal/hal_com_phycfg.c
Normal file
4068
hal/hal_com_phycfg.c
Normal file
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user