2013-05-19 04:28:07 +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__
|
|
|
|
|
|
|
|
//
|
|
|
|
// =========== 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.
|
|
|
|
|
|
|
|
/*===================================
|
|
|
|
|
|
|
|
#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) \
|
|
|
|
)
|
|
|
|
|
|
|
|
// _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)
|
|
|
|
|
2013-07-24 02:54:38 +00:00
|
|
|
enum odm_h2c_cmd {
|
2013-05-19 04:28:07 +00:00
|
|
|
ODM_H2C_RSSI_REPORT = 0,
|
|
|
|
ODM_H2C_PSD_RESULT=1,
|
|
|
|
ODM_H2C_PathDiv = 2,
|
|
|
|
ODM_MAX_H2CCMD
|
2013-07-24 02:54:38 +00:00
|
|
|
};
|
2013-05-19 04:28:07 +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.
|
|
|
|
//
|
2013-05-19 04:37:45 +00:00
|
|
|
typedef void (*RT_WORKITEM_CALL_BACK)(void * pContext);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// =========== Extern Variable ??? It should be forbidden.
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// =========== EXtern Function Prototype
|
|
|
|
//
|
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
u1Byte ODM_Read1Byte(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
u2Byte ODM_Read2Byte(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
u4Byte ODM_Read4Byte(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_Write1Byte(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr, u1Byte Data);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_Write2Byte(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr, u2Byte Data);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_Write4Byte(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr, u4Byte Data);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_SetMACReg(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr, u4Byte BitMask, u4Byte Data);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
u4Byte ODM_GetMACReg(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr, u4Byte BitMask);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_SetBBReg(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr, u4Byte BitMask, u4Byte Data);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
u4Byte ODM_GetBBReg(struct odm_dm_struct *pDM_Odm, u4Byte RegAddr, u4Byte BitMask);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_SetRFReg(struct odm_dm_struct *pDM_Odm, enum ODM_RF_RADIO_PATH eRFPath, u4Byte RegAddr, u4Byte BitMask, u4Byte Data);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
u4Byte ODM_GetRFReg(struct odm_dm_struct *pDM_Odm, enum ODM_RF_RADIO_PATH eRFPath, u4Byte RegAddr, u4Byte BitMask);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// Memory Relative Function.
|
|
|
|
//
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_AllocateMemory(struct odm_dm_struct *pDM_Odm, void **pPtr, u4Byte length);
|
|
|
|
void ODM_FreeMemory(struct odm_dm_struct *pDM_Odm, void *pPtr, u4Byte length);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 16:20:42 +00:00
|
|
|
s4Byte ODM_CompareMemory(struct odm_dm_struct *pDM_Odm, void *pBuf1, void *pBuf2, u4Byte length);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// ODM MISC-spin lock relative API.
|
|
|
|
//
|
2013-07-26 20:25:06 +00:00
|
|
|
void ODM_AcquireSpinLock(struct odm_dm_struct *pDM_Odm, enum RT_SPINLOCK_TYPE type);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
2013-07-26 20:25:06 +00:00
|
|
|
void ODM_ReleaseSpinLock(struct odm_dm_struct *pDM_Odm, enum RT_SPINLOCK_TYPE type);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// ODM MISC-workitem relative API.
|
|
|
|
//
|
2013-07-26 16:20:42 +00:00
|
|
|
void ODM_InitializeWorkItem(struct odm_dm_struct *pDM_Odm, void *pRtWorkItem,
|
2013-07-24 02:54:38 +00:00
|
|
|
RT_WORKITEM_CALL_BACK RtWorkItemCallback,
|
|
|
|
void *pContext, const char *szID);
|
|
|
|
|
|
|
|
void ODM_StartWorkItem(void *pRtWorkItem);
|
|
|
|
|
|
|
|
void ODM_StopWorkItem(void *pRtWorkItem);
|
|
|
|
|
|
|
|
void ODM_FreeWorkItem(void *pRtWorkItem);
|
|
|
|
|
|
|
|
void ODM_ScheduleWorkItem(void *pRtWorkItem);
|
|
|
|
|
|
|
|
void ODM_IsWorkItemScheduled(void *pRtWorkItem);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// ODM Timer relative API.
|
|
|
|
//
|
2013-07-24 02:54:38 +00:00
|
|
|
void ODM_StallExecution(u4Byte usDelay);
|
|
|
|
|
|
|
|
void ODM_delay_ms(u4Byte ms);
|
|
|
|
|
|
|
|
void ODM_delay_us(u4Byte us);
|
|
|
|
|
|
|
|
void ODM_sleep_ms(u4Byte ms);
|
|
|
|
|
|
|
|
void ODM_sleep_us(u4Byte us);
|
|
|
|
|
2013-07-26 20:25:06 +00:00
|
|
|
void ODM_SetTimer(struct odm_dm_struct *pDM_Odm, struct timer_list *pTimer, u4Byte msDelay);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 20:25:06 +00:00
|
|
|
void ODM_InitializeTimer(struct odm_dm_struct *pDM_Odm, struct timer_list *pTimer, void *CallBackFunc, void *pContext, const char *szID);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 20:25:06 +00:00
|
|
|
void ODM_CancelTimer(struct odm_dm_struct *pDM_Odm, struct timer_list *pTimer);
|
2013-07-24 02:54:38 +00:00
|
|
|
|
2013-07-26 20:25:06 +00:00
|
|
|
void ODM_ReleaseTimer(struct odm_dm_struct *pDM_Odm, struct timer_list *pTimer);
|
2013-05-19 04:28:07 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// ODM FW relative API.
|
|
|
|
//
|
2013-07-24 02:54:38 +00:00
|
|
|
u4Byte ODM_FillH2CCmd(pu1Byte pH2CBuffer, u4Byte H2CBufferLen, u4Byte CmdNum, pu4Byte pElementID, pu4Byte pCmdLen, pu1Byte *pCmbBuffer, pu1Byte CmdStartSeq);
|
|
|
|
|
2013-05-19 04:28:07 +00:00
|
|
|
#endif // __ODM_INTERFACE_H__
|