2014-12-19 06:59:46 +00:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* include files */
|
|
|
|
/* */
|
2014-12-19 06:59:46 +00:00
|
|
|
|
|
|
|
#include "odm_precomp.h"
|
2016-02-15 02:14:42 +00:00
|
|
|
#include "Hal8188EPhyCfg.h"
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* ODM IO Relative API. */
|
2014-12-19 06:59:46 +00:00
|
|
|
|
2014-12-30 23:50:44 +00:00
|
|
|
u8
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_Read1Byte(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
return rtw_read8(Adapter,RegAddr);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-12-30 22:52:58 +00:00
|
|
|
u16
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_Read2Byte(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
return rtw_read16(Adapter,RegAddr);
|
|
|
|
}
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_Read4Byte(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
return rtw_read32(Adapter,RegAddr);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_Write1Byte(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr,
|
|
|
|
u8 Data
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
rtw_write8(Adapter,RegAddr, Data);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_Write2Byte(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr,
|
|
|
|
u16 Data
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
rtw_write16(Adapter,RegAddr, Data);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_Write4Byte(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr,
|
|
|
|
u32 Data
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
rtw_write32(Adapter,RegAddr, Data);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_SetMACReg(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr,
|
|
|
|
u32 BitMask,
|
|
|
|
u32 Data
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
PHY_SetBBReg(Adapter, RegAddr, BitMask, Data);
|
|
|
|
}
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_GetMACReg(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr,
|
|
|
|
u32 BitMask
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
return PHY_QueryBBReg(Adapter, RegAddr, BitMask);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_SetBBReg(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr,
|
|
|
|
u32 BitMask,
|
|
|
|
u32 Data
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
PHY_SetBBReg(Adapter, RegAddr, BitMask, Data);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_GetBBReg(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
u32 RegAddr,
|
|
|
|
u32 BitMask
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
|
|
|
return PHY_QueryBBReg(Adapter, RegAddr, BitMask);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_SetRFReg(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
2016-02-15 02:14:42 +00:00
|
|
|
enum rf_radio_path eRFPath,
|
2015-03-13 17:06:38 +00:00
|
|
|
u32 RegAddr,
|
|
|
|
u32 BitMask,
|
|
|
|
u32 Data
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
2016-02-15 02:14:42 +00:00
|
|
|
PHY_SetRFReg(Adapter, (enum rf_radio_path)eRFPath, RegAddr, BitMask, Data);
|
2014-12-19 06:59:46 +00:00
|
|
|
}
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_GetRFReg(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
2016-02-15 02:14:42 +00:00
|
|
|
enum rf_radio_path eRFPath,
|
2015-03-13 17:06:38 +00:00
|
|
|
u32 RegAddr,
|
|
|
|
u32 BitMask
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter * Adapter = pDM_Odm->Adapter;
|
2015-01-29 21:27:28 +00:00
|
|
|
|
2016-02-15 02:14:42 +00:00
|
|
|
return PHY_QueryRFReg(Adapter, (enum rf_radio_path)eRFPath,
|
2015-01-29 21:27:28 +00:00
|
|
|
RegAddr, BitMask);
|
2014-12-19 06:59:46 +00:00
|
|
|
}
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM Memory relative API. */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_AllocateMemory(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
void * *pPtr,
|
|
|
|
u32 length
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
*pPtr = rtw_zvmalloc(length);
|
|
|
|
}
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* length could be ignored, used to detect memory leakage. */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_FreeMemory(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
void * pPtr,
|
|
|
|
u32 length
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
rtw_vmfree(pPtr, length);
|
|
|
|
}
|
2014-12-30 03:29:35 +00:00
|
|
|
|
2014-12-30 23:58:53 +00:00
|
|
|
s32 ODM_CompareMemory(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
void * pBuf1,
|
|
|
|
void * pBuf2,
|
|
|
|
u32 length
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
return _rtw_memcmp(pBuf1,pBuf2,length);
|
|
|
|
}
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM MISC relative API. */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_AcquireSpinLock(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
RT_SPINLOCK_TYPE type
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
2014-12-30 03:29:35 +00:00
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_ReleaseSpinLock(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
RT_SPINLOCK_TYPE type
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* Work item relative API. FOr MP driver only~! */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_InitializeWorkItem(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
PRT_WORK_ITEM pRtWorkItem,
|
|
|
|
RT_WORKITEM_CALL_BACK RtWorkItemCallback,
|
|
|
|
void * pContext,
|
|
|
|
const char* szID
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_StartWorkItem(
|
2015-03-13 17:06:38 +00:00
|
|
|
PRT_WORK_ITEM pRtWorkItem
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_StopWorkItem(
|
2015-03-13 17:06:38 +00:00
|
|
|
PRT_WORK_ITEM pRtWorkItem
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_FreeWorkItem(
|
2015-03-13 17:06:38 +00:00
|
|
|
PRT_WORK_ITEM pRtWorkItem
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_ScheduleWorkItem(
|
2015-03-13 17:06:38 +00:00
|
|
|
PRT_WORK_ITEM pRtWorkItem
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_IsWorkItemScheduled(
|
2015-03-13 17:06:38 +00:00
|
|
|
PRT_WORK_ITEM pRtWorkItem
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM Timer relative API. */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_StallExecution(
|
2015-03-13 17:06:38 +00:00
|
|
|
u32 usDelay
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
rtw_udelay_os(usDelay);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2015-03-13 17:06:38 +00:00
|
|
|
ODM_delay_ms(u32 ms)
|
2014-12-19 06:59:46 +00:00
|
|
|
{
|
|
|
|
rtw_mdelay_os(ms);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2015-03-13 17:06:38 +00:00
|
|
|
ODM_delay_us(u32 us)
|
2014-12-19 06:59:46 +00:00
|
|
|
{
|
|
|
|
rtw_udelay_os(us);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2015-03-13 17:06:38 +00:00
|
|
|
ODM_sleep_ms(u32 ms)
|
2014-12-19 06:59:46 +00:00
|
|
|
{
|
|
|
|
rtw_msleep_os(ms);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2015-03-13 17:06:38 +00:00
|
|
|
ODM_sleep_us(u32 us)
|
2014-12-19 06:59:46 +00:00
|
|
|
{
|
|
|
|
rtw_usleep_os(us);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_SetTimer(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
PRT_TIMER pTimer,
|
|
|
|
u32 msDelay
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
2015-02-20 00:51:33 +00:00
|
|
|
_set_timer(pTimer,msDelay ); /* ms */
|
2014-12-19 06:59:46 +00:00
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_InitializeTimer(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
PRT_TIMER pTimer,
|
|
|
|
RT_TIMER_CALL_BACK CallBackFunc,
|
|
|
|
void * pContext,
|
|
|
|
const char* szID
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
struct adapter *Adapter = pDM_Odm->Adapter;
|
|
|
|
_init_timer(pTimer,Adapter->pnetdev,CallBackFunc,pDM_Odm);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_CancelTimer(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
PRT_TIMER pTimer
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
_cancel_timer_ex(pTimer);
|
|
|
|
}
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_ReleaseTimer(
|
2015-03-13 17:06:38 +00:00
|
|
|
PDM_ODM_T pDM_Odm,
|
|
|
|
PRT_TIMER pTimer
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM FW relative API. */
|
|
|
|
/* */
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-19 06:59:46 +00:00
|
|
|
ODM_FillH2CCmd(
|
2015-03-13 17:06:38 +00:00
|
|
|
u8 * pH2CBuffer,
|
|
|
|
u32 H2CBufferLen,
|
|
|
|
u32 CmdNum,
|
|
|
|
u32 * pElementID,
|
|
|
|
u32 * pCmdLen,
|
|
|
|
u8 ** pCmbBuffer,
|
|
|
|
u8 * CmdStartSeq
|
2014-12-19 06:59:46 +00:00
|
|
|
)
|
|
|
|
{
|
2015-03-02 23:25:27 +00:00
|
|
|
return true;
|
2014-12-19 06:59:46 +00:00
|
|
|
}
|