2014-12-11 21:15:04 +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
|
|
|
|
*
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef __ODM_INTERFACE_H__
|
|
|
|
#define __ODM_INTERFACE_H__
|
|
|
|
|
|
|
|
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* =========== Constant/Structure/Enum/... Define */
|
|
|
|
/* */
|
2014-12-11 21:15:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* =========== Macro Define */
|
|
|
|
/* */
|
2014-12-11 21:15:04 +00:00
|
|
|
|
|
|
|
#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
|
|
|
|
|
|
|
|
/*===================================
|
|
|
|
|
|
|
|
#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
|
|
|
|
|
|
|
|
#define _cat(_name, _ic_type, _func) \
|
|
|
|
( \
|
|
|
|
((_ic_type) & ODM_IC_11N_SERIES)? _func##_11N(_name): \
|
|
|
|
_func##_11AC(_name) \
|
|
|
|
)
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* _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. */
|
2014-12-11 21:15:04 +00:00
|
|
|
#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;
|
|
|
|
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* 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. */
|
|
|
|
/* */
|
2014-12-11 21:15:04 +00:00
|
|
|
typedef void *PRT_WORK_ITEM ;
|
|
|
|
typedef void RT_WORKITEM_HANDLE,*PRT_WORKITEM_HANDLE;
|
2014-12-29 02:06:17 +00:00
|
|
|
typedef void (*RT_WORKITEM_CALL_BACK)(void * pContext);
|
2014-12-11 21:15:04 +00:00
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* =========== Extern Variable ??? It should be forbidden. */
|
|
|
|
/* */
|
2014-12-11 21:15:04 +00:00
|
|
|
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* =========== EXtern Function Prototype */
|
|
|
|
/* */
|
2014-12-11 21:15:04 +00:00
|
|
|
|
|
|
|
|
2014-12-30 23:50:44 +00:00
|
|
|
u8
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_Read1Byte(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-30 22:52:58 +00:00
|
|
|
u16
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_Read2Byte(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_Read4Byte(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_Write1Byte(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
2014-12-30 23:50:44 +00:00
|
|
|
IN u8 Data
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_Write2Byte(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
2014-12-30 22:52:58 +00:00
|
|
|
IN u16 Data
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_Write4Byte(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
|
|
|
IN u32 Data
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_SetMACReg(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
|
|
|
IN u32 BitMask,
|
|
|
|
IN u32 Data
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_GetMACReg(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
|
|
|
IN u32 BitMask
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_SetBBReg(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
|
|
|
IN u32 BitMask,
|
|
|
|
IN u32 Data
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_GetBBReg(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
|
|
|
IN u32 BitMask
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_SetRFReg(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN ODM_RF_RADIO_PATH_E eRFPath,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
|
|
|
IN u32 BitMask,
|
|
|
|
IN u32 Data
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_GetRFReg(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN ODM_RF_RADIO_PATH_E eRFPath,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 RegAddr,
|
|
|
|
IN u32 BitMask
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* Memory Relative Function. */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_AllocateMemory(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-29 02:06:17 +00:00
|
|
|
OUT void * *pPtr,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 length
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_FreeMemory(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-29 02:06:17 +00:00
|
|
|
OUT void * pPtr,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 length
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-30 23:58:53 +00:00
|
|
|
s32 ODM_CompareMemory(
|
2014-12-11 21:15:04 +00:00
|
|
|
IN PDM_ODM_T pDM_Odm,
|
2014-12-29 02:06:17 +00:00
|
|
|
IN void * pBuf1,
|
|
|
|
IN void * pBuf2,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 length
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM MISC-spin lock relative API. */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_AcquireSpinLock(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN RT_SPINLOCK_TYPE type
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_ReleaseSpinLock(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN RT_SPINLOCK_TYPE type
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM MISC-workitem relative API. */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_InitializeWorkItem(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN PRT_WORK_ITEM pRtWorkItem,
|
|
|
|
IN RT_WORKITEM_CALL_BACK RtWorkItemCallback,
|
2014-12-29 02:06:17 +00:00
|
|
|
IN void * pContext,
|
2014-12-11 21:15:04 +00:00
|
|
|
IN const char* szID
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_StartWorkItem(
|
|
|
|
IN PRT_WORK_ITEM pRtWorkItem
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_StopWorkItem(
|
|
|
|
IN PRT_WORK_ITEM pRtWorkItem
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_FreeWorkItem(
|
|
|
|
IN PRT_WORK_ITEM pRtWorkItem
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_ScheduleWorkItem(
|
|
|
|
IN PRT_WORK_ITEM pRtWorkItem
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_IsWorkItemScheduled(
|
|
|
|
IN PRT_WORK_ITEM pRtWorkItem
|
|
|
|
);
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM Timer relative API. */
|
|
|
|
/* */
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_StallExecution(
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 usDelay
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-30 22:55:10 +00:00
|
|
|
ODM_delay_ms(IN u32 ms);
|
2014-12-11 21:15:04 +00:00
|
|
|
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-30 22:55:10 +00:00
|
|
|
ODM_delay_us(IN u32 us);
|
2014-12-11 21:15:04 +00:00
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-30 22:55:10 +00:00
|
|
|
ODM_sleep_ms(IN u32 ms);
|
2014-12-11 21:15:04 +00:00
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-30 22:55:10 +00:00
|
|
|
ODM_sleep_us(IN u32 us);
|
2014-12-11 21:15:04 +00:00
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_SetTimer(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN PRT_TIMER pTimer,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 msDelay
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_InitializeTimer(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN PRT_TIMER pTimer,
|
|
|
|
IN RT_TIMER_CALL_BACK CallBackFunc,
|
2014-12-29 02:06:17 +00:00
|
|
|
IN void * pContext,
|
2014-12-11 21:15:04 +00:00
|
|
|
IN const char* szID
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_CancelTimer(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN PRT_TIMER pTimer
|
|
|
|
);
|
|
|
|
|
2014-12-29 02:06:17 +00:00
|
|
|
void
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_ReleaseTimer(
|
|
|
|
IN PDM_ODM_T pDM_Odm,
|
|
|
|
IN PRT_TIMER pTimer
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
/* */
|
|
|
|
/* ODM FW relative API. */
|
|
|
|
/* */
|
2014-12-30 22:55:10 +00:00
|
|
|
u32
|
2014-12-11 21:15:04 +00:00
|
|
|
ODM_FillH2CCmd(
|
2014-12-30 23:50:44 +00:00
|
|
|
IN u8 * pH2CBuffer,
|
2014-12-30 22:55:10 +00:00
|
|
|
IN u32 H2CBufferLen,
|
|
|
|
IN u32 CmdNum,
|
|
|
|
IN u32 * pElementID,
|
|
|
|
IN u32 * pCmdLen,
|
2014-12-30 23:50:44 +00:00
|
|
|
IN u8 ** pCmbBuffer,
|
|
|
|
IN u8 * CmdStartSeq
|
2014-12-11 21:15:04 +00:00
|
|
|
);
|
|
|
|
|
2015-02-20 00:51:33 +00:00
|
|
|
#endif /* __ODM_INTERFACE_H__ */
|