* 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 _RTW_MP_H_
#define _RTW_MP_H_
-#define MAX_MP_XMITBUF_SZ 2048
+#define MAX_MP_XMITBUF_SZ 2048
#define NR_MP_XMITFRAME 8
struct mp_xmit_frame
{
- _list list;
+ struct list_head list;
struct pkt_attrib attrib;
int frame_tag;
- _adapter *padapter;
+ struct adapter *padapter;
uint mem[(MAX_MP_XMITBUF_SZ >> 2)];
};
u32 count, sended;
u8 payload;
struct pkt_attrib attrib;
- //struct tx_desc desc;
- //u8 resvdtx[7];
+ /* struct tx_desc desc; */
+ /* u8 resvdtx[7]; */
u8 desc[TXDESC_SIZE];
u8 *pallocated_buf;
u8 *buf;
u32 buf_size, write_size;
- void * PktTxThread;
+ void *PktTxThread;
};
#define MP_MAX_LINES 1000
#define MP_MAX_LINES_BYTES 256
-#define u1Byte u8
-#define s8 s8
-#define u4Byte u32
-#define s4Byte s32
-#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 s4Byte s32
-#define ps4Byte s32*
-#define s8Byte s64
-#define ps8Byte s64*
-
-typedef void (*MPT_WORK_ITEM_HANDLER)(IN void * Adapter);
+typedef void (*MPT_WORK_ITEM_HANDLER)(void *Adapter);
typedef struct _MPT_CONTEXT
{
- // Indicate if we have started Mass Production Test.
+ /* Indicate if we have started Mass Production Test. */
bool bMassProdTest;
- // Indicate if the driver is unloading or unloaded.
+ /* Indicate if the driver is unloading or unloaded. */
bool bMptDrvUnload;
_sema MPh2c_Sema;
_timer MPh2c_timeout_timer;
-// Event used to sync H2c for BT control
+/* Event used to sync H2c for BT control */
bool MptH2cRspEvent;
bool MptBtC2hEvent;
bool bMPh2c_timeout;
/* 8190 PCI does not support NDIS_WORK_ITEM. */
- // Work Item for Mass Production Test.
- //NDIS_WORK_ITEM MptWorkItem;
-// RT_WORK_ITEM MptWorkItem;
- // Event used to sync the case unloading driver and MptWorkItem is still in progress.
-// NDIS_EVENT MptWorkItemEvent;
- // To protect the following variables.
-// NDIS_SPIN_LOCK MptWorkItemSpinLock;
- // Indicate a MptWorkItem is scheduled and not yet finished.
+ /* Work Item for Mass Production Test. */
+ /* NDIS_WORK_ITEM MptWorkItem; */
+/* RT_WORK_ITEM MptWorkItem; */
+ /* Event used to sync the case unloading driver and MptWorkItem is still in progress. */
+/* NDIS_EVENT MptWorkItemEvent; */
+ /* To protect the following variables. */
+/* NDIS_SPIN_LOCK MptWorkItemSpinLock; */
+ /* Indicate a MptWorkItem is scheduled and not yet finished. */
bool bMptWorkItemInProgress;
- // An instance which implements function and context of MptWorkItem.
+ /* An instance which implements function and context of MptWorkItem. */
MPT_WORK_ITEM_HANDLER CurrMptAct;
- // 1=Start, 0=Stop from UI.
- u32 MptTestStart;
- // _TEST_MODE, defined in MPT_Req2.h
- u32 MptTestItem;
- // Variable needed in each implementation of CurrMptAct.
- u32 MptActType; // Type of action performed in CurrMptAct.
- // The Offset of IO operation is depend of MptActType.
- u32 MptIoOffset;
- // The Value of IO operation is depend of MptActType.
- u32 MptIoValue;
- // The RfPath of IO operation is depend of MptActType.
- u32 MptRfPath;
-
- WIRELESS_MODE MptWirelessModeToSw; // Wireless mode to switch.
- u8 MptChannelToSw; // Channel to switch.
- u8 MptInitGainToSet; // Initial gain to set.
- //u32 bMptAntennaA; // true if we want to use antenna A.
- u32 MptBandWidth; // bandwidth to switch.
- u32 MptRateIndex; // rate index.
- // Register value kept for Single Carrier Tx test.
- u8 btMpCckTxPower;
- // Register value kept for Single Carrier Tx test.
- u8 btMpOfdmTxPower;
- // For MP Tx Power index
- u8 TxPwrLevel[2]; // rf-A, rf-B
- u32 RegTxPwrLimit;
- // Content of RCR Regsiter for Mass Production Test.
- u32 MptRCR;
- // true if we only receive packets with specific pattern.
+ /* 1 =Start, 0 =Stop from UI. */
+ u32 MptTestStart;
+ /* _TEST_MODE, defined in MPT_Req2.h */
+ u32 MptTestItem;
+ /* Variable needed in each implementation of CurrMptAct. */
+ u32 MptActType; /* Type of action performed in CurrMptAct. */
+ /* The Offset of IO operation is depend of MptActType. */
+ u32 MptIoOffset;
+ /* The Value of IO operation is depend of MptActType. */
+ u32 MptIoValue;
+ /* The RfPath of IO operation is depend of MptActType. */
+ u32 MptRfPath;
+
+ enum WIRELESS_MODE MptWirelessModeToSw; /* Wireless mode to switch. */
+ u8 MptChannelToSw; /* Channel to switch. */
+ u8 MptInitGainToSet; /* Initial gain to set. */
+ u32 MptBandWidth; /* bandwidth to switch. */
+ u32 MptRateIndex; /* rate index. */
+ /* Register value kept for Single Carrier Tx test. */
+ u8 btMpCckTxPower;
+ /* Register value kept for Single Carrier Tx test. */
+ u8 btMpOfdmTxPower;
+ /* For MP Tx Power index */
+ u8 TxPwrLevel[2]; /* rf-A, rf-B */
+ u32 RegTxPwrLimit;
+ /* Content of RCR Regsiter for Mass Production Test. */
+ u32 MptRCR;
+ /* true if we only receive packets with specific pattern. */
bool bMptFilterPattern;
- // Rx OK count, statistics used in Mass Production Test.
- u32 MptRxOkCnt;
- // Rx CRC32 error count, statistics used in Mass Production Test.
- u32 MptRxCrcErrCnt;
-
- bool bCckContTx; // true if we are in CCK Continuous Tx test.
- bool bOfdmContTx; // true if we are in OFDM Continuous Tx test.
- bool bStartContTx; // true if we have start Continuous Tx test.
- // true if we are in Single Carrier Tx test.
+ /* Rx OK count, statistics used in Mass Production Test. */
+ u32 MptRxOkCnt;
+ /* Rx CRC32 error count, statistics used in Mass Production Test. */
+ u32 MptRxCrcErrCnt;
+
+ bool bCckContTx; /* true if we are in CCK Continuous Tx test. */
+ bool bOfdmContTx; /* true if we are in OFDM Continuous Tx test. */
+ bool bStartContTx; /* true if we have start Continuous Tx test. */
+ /* true if we are in Single Carrier Tx test. */
bool bSingleCarrier;
- // true if we are in Carrier Suppression Tx Test.
+ /* true if we are in Carrier Suppression Tx Test. */
bool bCarrierSuppression;
- //true if we are in Single Tone Tx test.
+ /* true if we are in Single Tone Tx test. */
bool bSingleTone;
- // ACK counter asked by K.Y..
+ /* ACK counter asked by K.Y.. */
bool bMptEnableAckCounter;
- u32 MptAckCounter;
+ u32 MptAckCounter;
- // SD3 Willis For 8192S to save 1T/2T RF table for ACUT Only fro ACUT delete later ~~~!
- //s8 BufOfLines[2][MAX_LINES_HWCONFIG_TXT][MAX_BYTES_LINE_HWCONFIG_TXT];
- //s8 BufOfLines[2][MP_MAX_LINES][MP_MAX_LINES_BYTES];
- //s4Byte RfReadLine[2];
+ /* SD3 Willis For 8192S to save 1T/2T RF table for ACUT Only fro ACUT delete later ~~~! */
+ /* s8 BufOfLines[2][MAX_LINES_HWCONFIG_TXT][MAX_BYTES_LINE_HWCONFIG_TXT]; */
+ /* s8 BufOfLines[2][MP_MAX_LINES][MP_MAX_LINES_BYTES]; */
+ /* s32 RfReadLine[2]; */
- u8 APK_bound[2]; //for APK path A/path B
+ u8 APK_bound[2]; /* for APK path A/path B */
bool bMptIndexEven;
- u8 backup0xc50;
- u8 backup0xc58;
- u8 backup0xc30;
- u8 backup0x52_RF_A;
- u8 backup0x52_RF_B;
+ u8 backup0xc50;
+ u8 backup0xc58;
+ u8 backup0xc30;
+ u8 backup0x52_RF_A;
+ u8 backup0x52_RF_B;
- u4Byte backup0x58_RF_A;
- u4Byte backup0x58_RF_B;
+ u32 backup0x58_RF_A;
+ u32 backup0x58_RF_B;
- u1Byte h2cReqNum;
- u1Byte c2hBuf[32];
+ u8 h2cReqNum;
+ u8 c2hBuf[32];
- u1Byte btInBuf[100];
- u32 mptOutLen;
- u1Byte mptOutBuf[100];
+ u8 btInBuf[100];
+ u32 mptOutLen;
+ u8 mptOutBuf[100];
}MPT_CONTEXT, *PMPT_CONTEXT;
-//#endif
+/* endif */
/* E-Fuse */
#define EFUSE_MAP_SIZE 512
#define EFUSE_MAX_SIZE 512
/* end of E-Fuse */
-//#define RTPRIV_IOCTL_MP ( SIOCIWFIRSTPRIV + 0x17)
+/* define RTPRIV_IOCTL_MP (SIOCIWFIRSTPRIV + 0x17) */
enum {
WRITE_REG = 1,
READ_REG,
struct mp_priv
{
- _adapter *papdater;
+ struct adapter *papdater;
- //Testing Flag
- u32 mode;//0 for normal type packet, 1 for loopback packet (16bytes TXCMD)
+ /* Testing Flag */
+ u32 mode;/* 0 for normal type packet, 1 for loopback packet (16bytes TXCMD) */
u32 prev_fw_state;
- //OID cmd handler
+ /* OID cmd handler */
struct mp_wiparam workparam;
-// u8 act_in_progress;
+/* u8 act_in_progress; */
- //Tx Section
+ /* Tx Section */
u8 TID;
u32 tx_pktcount;
u32 pktInterval;
struct mp_tx tx;
- //Rx Section
+ /* Rx Section */
u32 rx_bssidpktcount;
u32 rx_pktcount;
u32 rx_pktcount_filter_out;
bool rx_bindicatePkt;
struct recv_stat rxstat;
- //RF/BB relative
+ /* RF/BB relative */
u8 channel;
u8 bandwidth;
u8 prime_channel_offset;
u8 txpoweridx_b;
u8 rateidx;
u32 preamble;
-// u8 modem;
+/* u8 modem; */
u32 CrystalCap;
-// u32 curr_crystalcap;
+/* u32 curr_crystalcap; */
u16 antenna_tx;
u16 antenna_rx;
-// u8 curr_rfpath;
+/* u8 curr_rfpath; */
u8 check_mp_pkt;
u8 bSetTxPower;
-// uint ForcedDataRate;
+/* uint ForcedDataRate; */
u8 mp_dm;
u8 mac_filter[ETH_ALEN];
u8 bmac_filter;
u8 *pallocated_mp_xmitframe_buf;
u8 *pmp_xmtframe_buf;
- _queue free_mp_xmitqueue;
+ struct __queue free_mp_xmitqueue;
u32 free_mp_xmitframe_cnt;
bool bSetRxBssid;
bool bTxBufCkFail;
MPT_CONTEXT MptCtx;
- u8 *TXradomBuffer;
+ u8 *TXradomBuffer;
};
typedef struct _IOCMD_STRUCT_ {
- u8 cmdclass;
- u16 value;
- u8 index;
+ u8 cmdclass;
+ u16 value;
+ u8 index;
}IOCMD_STRUCT;
struct rf_reg_param {
u32 value;
};
-typedef struct _MP_FIRMWARE {
- FIRMWARE_SOURCE eFWSource;
- u8* szFwBuffer;
- u32 ulFwLength;
-
- u8* szBTFwBuffer;
- u8 myBTFwBuffer[0x8000];
- u32 ulBTFwLength;
-} RT_MP_FIRMWARE, *PRT_MP_FIRMWARE;
-
-
-
-
-//=======================================================================
-
-#define LOWER true
+#define LOWER true
#define RAISE false
/* Hardware Registers */
#define BB_REG_BASE_ADDR 0x800
/* MP variables */
-typedef enum _MP_MODE_ {
+enum MP_MODE {
MP_OFF,
MP_ON,
MP_ERR,
MP_SINGLE_TONE_TX,
MP_PACKET_TX,
MP_PACKET_RX
-} MP_MODE;
-
+};
#define MAX_RF_PATH_NUMS RF_PATH_MAX
-
extern u8 mpdatarate[NumRates];
/* MP set force data rate base on the definition. */
-typedef enum _MPT_RATE_INDEX
-{
+enum MPT_RATE_INDEX {
/* CCK rate. */
- MPT_RATE_1M =0 , /* 0 */
+ MPT_RATE_1M = 0 , /* 0 */
MPT_RATE_2M,
MPT_RATE_55M,
MPT_RATE_11M, /* 3 */
MPT_RATE_MCS14,
MPT_RATE_MCS15, /* 27 */
/* VHT rate. Total: 20*/
- MPT_RATE_VHT1SS_MCS0 = 100,// To reserve MCS16~MCS31, the index starts from #100.
- MPT_RATE_VHT1SS_MCS1, // #101
+ MPT_RATE_VHT1SS_MCS0 = 100,/* To reserve MCS16~MCS31, the index starts from #100. */
+ MPT_RATE_VHT1SS_MCS1, /* #101 */
MPT_RATE_VHT1SS_MCS2,
MPT_RATE_VHT1SS_MCS3,
MPT_RATE_VHT1SS_MCS4,
MPT_RATE_VHT1SS_MCS5,
- MPT_RATE_VHT1SS_MCS6, // #106
+ MPT_RATE_VHT1SS_MCS6, /* #106 */
MPT_RATE_VHT1SS_MCS7,
MPT_RATE_VHT1SS_MCS8,
MPT_RATE_VHT1SS_MCS9,
MPT_RATE_VHT2SS_MCS0,
- MPT_RATE_VHT2SS_MCS1, // #111
+ MPT_RATE_VHT2SS_MCS1, /* #111 */
MPT_RATE_VHT2SS_MCS2,
MPT_RATE_VHT2SS_MCS3,
MPT_RATE_VHT2SS_MCS4,
MPT_RATE_VHT2SS_MCS5,
- MPT_RATE_VHT2SS_MCS6, // #116
+ MPT_RATE_VHT2SS_MCS6, /* #116 */
MPT_RATE_VHT2SS_MCS7,
MPT_RATE_VHT2SS_MCS8,
MPT_RATE_VHT2SS_MCS9,
MPT_RATE_LAST
-}MPT_RATE_E, *PMPT_RATE_E;
+};
-#define MAX_TX_PWR_INDEX_N_MODE 64 // 0x3F
+#define MAX_TX_PWR_INDEX_N_MODE 64 /* 0x3F */
-typedef enum _POWER_MODE_ {
+enum POWER_MODE {
POWER_LOW = 0,
POWER_NORMAL
-}POWER_MODE;
+};
-// The following enumeration is used to define the value of Reg0xD00[30:28] or JaguarReg0x914[18:16].
-typedef enum _OFDM_TX_MODE {
+/* The following enumeration is used to define the value of Reg0xD00[30:28] or JaguarReg0x914[18:16]. */
+enum OFDM_TX_MODE {
OFDM_ALL_OFF = 0,
OFDM_ContinuousTx = 1,
OFDM_SingleCarrier = 2,
- OFDM_SingleTone = 4,
-} OFDM_TX_MODE;
-
+ OFDM_SingleTone = 4,
+};
#define RX_PKT_BROADCAST 1
#define RX_PKT_DEST_ADDR 2
#define RX_PKT_PHY_MATCH 3
-#define Mac_OFDM_OK 0x00000000
+#define Mac_OFDM_OK 0x00000000
#define Mac_OFDM_Fail 0x10000000
-#define Mac_OFDM_FasleAlarm 0x20000000
+#define Mac_OFDM_FasleAlarm 0x20000000
#define Mac_CCK_OK 0x30000000
#define Mac_CCK_Fail 0x40000000
#define Mac_CCK_FasleAlarm 0x50000000
#define Mac_HT_OK 0x60000000
-#define Mac_HT_Fail 0x70000000
+#define Mac_HT_Fail 0x70000000
#define Mac_HT_FasleAlarm 0x90000000
#define Mac_DropPacket 0xA0000000
-typedef enum _ENCRY_CTRL_STATE_ {
- HW_CONTROL, //hw encryption& decryption
- SW_CONTROL, //sw encryption& decryption
- HW_ENCRY_SW_DECRY, //hw encryption & sw decryption
- SW_ENCRY_HW_DECRY //sw encryption & hw decryption
-}ENCRY_CTRL_STATE;
+enum ENCRY_CTRL_STATE {
+ HW_CONTROL, /* hw encryption& decryption */
+ SW_CONTROL, /* sw encryption& decryption */
+ HW_ENCRY_SW_DECRY, /* hw encryption & sw decryption */
+ SW_ENCRY_HW_DECRY /* sw encryption & hw decryption */
+};
-typedef enum _MPT_TXPWR_DEF{
+enum MPT_TXPWR_DEF {
MPT_CCK,
- MPT_OFDM, // L and HT OFDM
+ MPT_OFDM, /* L and HT OFDM */
MPT_VHT_OFDM
-}MPT_TXPWR_DEF;
-
-#define REG_RF_BB_GAIN_OFFSET 0x7f
-#define RF_GAIN_OFFSET_MASK 0xfffff
-
-//=======================================================================
-//extern struct mp_xmit_frame *alloc_mp_xmitframe(struct mp_priv *pmp_priv);
-//extern int free_mp_xmitframe(struct xmit_priv *pxmitpriv, struct mp_xmit_frame *pmp_xmitframe);
-
-extern s32 init_mp_priv(PADAPTER padapter);
-extern void free_mp_priv(struct mp_priv *pmp_priv);
-extern s32 MPT_InitializeAdapter(PADAPTER padapter, u8 Channel);
-extern void MPT_DeInitAdapter(PADAPTER padapter);
-extern s32 mp_start_test(PADAPTER padapter);
-extern void mp_stop_test(PADAPTER padapter);
-
-//=======================================================================
-//extern void IQCalibrateBcut(PADAPTER pAdapter);
-
-//extern u32 bb_reg_read(PADAPTER Adapter, u16 offset);
-//extern u8 bb_reg_write(PADAPTER Adapter, u16 offset, u32 value);
-//extern u32 rf_reg_read(PADAPTER Adapter, u8 path, u8 offset);
-//extern u8 rf_reg_write(PADAPTER Adapter, u8 path, u8 offset, u32 value);
-
-//extern u32 get_bb_reg(PADAPTER Adapter, u16 offset, u32 bitmask);
-//extern u8 set_bb_reg(PADAPTER Adapter, u16 offset, u32 bitmask, u32 value);
-//extern u32 get_rf_reg(PADAPTER Adapter, u8 path, u8 offset, u32 bitmask);
-//extern u8 set_rf_reg(PADAPTER Adapter, u8 path, u8 offset, u32 bitmask, u32 value);
-
-extern u32 _read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask);
-extern void _write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask, u32 val);
-
-extern u32 read_macreg(_adapter *padapter, u32 addr, u32 sz);
-extern void write_macreg(_adapter *padapter, u32 addr, u32 val, u32 sz);
-extern u32 read_bbreg(_adapter *padapter, u32 addr, u32 bitmask);
-extern void write_bbreg(_adapter *padapter, u32 addr, u32 bitmask, u32 val);
-extern u32 read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr);
-extern void write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 val);
-
-extern void SetChannel(PADAPTER pAdapter);
-extern void SetBandwidth(PADAPTER pAdapter);
-extern int SetTxPower(PADAPTER pAdapter);
-extern void SetAntennaPathPower(PADAPTER pAdapter);
-//extern void SetTxAGCOffset(PADAPTER pAdapter, u32 ulTxAGCOffset);
-extern void SetDataRate(PADAPTER pAdapter);
-
-extern void SetAntenna(PADAPTER pAdapter);
-
-//extern void SetCrystalCap(PADAPTER pAdapter);
-
-extern s32 SetThermalMeter(PADAPTER pAdapter, u8 target_ther);
-extern void GetThermalMeter(PADAPTER pAdapter, u8 *value);
-
-extern void SetContinuousTx(PADAPTER pAdapter, u8 bStart);
-extern void SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart);
-extern void SetSingleToneTx(PADAPTER pAdapter, u8 bStart);
-extern void SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
-extern void PhySetTxPowerLevel(PADAPTER pAdapter);
-
-extern void fill_txdesc_for_mp(PADAPTER padapter, u8 *ptxdesc);
-extern void SetPacketTx(PADAPTER padapter);
-extern void SetPacketRx(PADAPTER pAdapter, u8 bStartRx);
-
-extern void ResetPhyRxPktCount(PADAPTER pAdapter);
-extern u32 GetPhyRxPktReceived(PADAPTER pAdapter);
-extern u32 GetPhyRxPktCRC32Error(PADAPTER pAdapter);
-
-extern s32 SetPowerTracking(PADAPTER padapter, u8 enable);
-extern void GetPowerTracking(PADAPTER padapter, u8 *enable);
-
-extern u32 mp_query_psd(PADAPTER pAdapter, u8 *data);
-
-
-extern void Hal_SetAntenna(PADAPTER pAdapter);
-extern void Hal_SetBandwidth(PADAPTER pAdapter);
-
-extern void Hal_SetTxPower(PADAPTER pAdapter);
-extern void Hal_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
-extern void Hal_SetSingleToneTx ( PADAPTER pAdapter , u8 bStart );
-extern void Hal_SetSingleCarrierTx (PADAPTER pAdapter, u8 bStart);
-extern void Hal_SetContinuousTx (PADAPTER pAdapter, u8 bStart);
-extern void Hal_SetBandwidth(PADAPTER pAdapter);
-
-extern void Hal_SetDataRate(PADAPTER pAdapter);
-extern void Hal_SetChannel(PADAPTER pAdapter);
-extern void Hal_SetAntennaPathPower(PADAPTER pAdapter);
-extern s32 Hal_SetThermalMeter(PADAPTER pAdapter, u8 target_ther);
-extern s32 Hal_SetPowerTracking(PADAPTER padapter, u8 enable);
-extern void Hal_GetPowerTracking(PADAPTER padapter, u8 * enable);
-extern void Hal_GetThermalMeter(PADAPTER pAdapter, u8 *value);
-extern void Hal_mpt_SwitchRfSetting(PADAPTER pAdapter);
-extern void Hal_MPT_CCKTxPowerAdjust(PADAPTER Adapter, bool bInCH14);
-extern void Hal_MPT_CCKTxPowerAdjustbyIndex(PADAPTER pAdapter, bool beven);
-extern void Hal_SetCCKTxPower(PADAPTER pAdapter, u8 * TxPower);
-extern void Hal_SetOFDMTxPower(PADAPTER pAdapter, u8 * TxPower);
-extern void Hal_TriggerRFThermalMeter(PADAPTER pAdapter);
-extern u8 Hal_ReadRFThermalMeter(PADAPTER pAdapter);
-extern void Hal_SetCCKContinuousTx(PADAPTER pAdapter, u8 bStart);
-extern void Hal_SetOFDMContinuousTx(PADAPTER pAdapter, u8 bStart);
-extern void Hal_ProSetCrystalCap (PADAPTER pAdapter , u32 CrystalCapVal);
-//extern void _rtw_mp_xmit_priv(struct xmit_priv *pxmitpriv);
-extern void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter ,bool bMain);
-extern u32 mpt_ProQueryCalTxPower(PADAPTER pAdapter,u8 RfPath);
-extern void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart);
-extern u8 MptToMgntRate(u32 MptRateIdx);
-
-#endif //_RTW_MP_H_
+};
+
+#define REG_RF_BB_GAIN_OFFSET 0x7f
+#define RF_GAIN_OFFSET_MASK 0xfffff
+
+/* */
+/* struct mp_xmit_frame *alloc_mp_xmitframe(struct mp_priv *pmp_priv); */
+/* int free_mp_xmitframe(struct xmit_priv *pxmitpriv, struct mp_xmit_frame *pmp_xmitframe); */
+
+s32 init_mp_priv(struct adapter *padapter);
+void free_mp_priv(struct mp_priv *pmp_priv);
+s32 MPT_InitializeAdapter(struct adapter *padapter, u8 Channel);
+void MPT_DeInitAdapter(struct adapter *padapter);
+s32 mp_start_test(struct adapter *padapter);
+void mp_stop_test(struct adapter *padapter);
+
+u32 _read_rfreg(struct adapter *padapter, u8 rfpath, u32 addr, u32 bitmask);
+void _write_rfreg(struct adapter *padapter, u8 rfpath, u32 addr, u32 bitmask, u32 val);
+
+u32 read_macreg(struct adapter *padapter, u32 addr, u32 sz);
+void write_macreg(struct adapter *padapter, u32 addr, u32 val, u32 sz);
+u32 read_bbreg(struct adapter *padapter, u32 addr, u32 bitmask);
+void write_bbreg(struct adapter *padapter, u32 addr, u32 bitmask, u32 val);
+u32 read_rfreg(struct adapter *padapter, u8 rfpath, u32 addr);
+void write_rfreg(struct adapter *padapter, u8 rfpath, u32 addr, u32 val);
+
+void SetChannel(struct adapter *padapter);
+void SetBandwidth(struct adapter *padapter);
+int SetTxPower(struct adapter *padapter);
+void SetAntennaPathPower(struct adapter *padapter);
+void SetDataRate(struct adapter *padapter);
+
+void SetAntenna(struct adapter *padapter);
+
+s32 SetThermalMeter(struct adapter *padapter, u8 target_ther);
+void GetThermalMeter(struct adapter *padapter, u8 *value);
+
+void SetContinuousTx(struct adapter *padapter, u8 bStart);
+void SetSingleCarrierTx(struct adapter *padapter, u8 bStart);
+void SetSingleToneTx(struct adapter *padapter, u8 bStart);
+void SetCarrierSuppressionTx(struct adapter *padapter, u8 bStart);
+void PhySetTxPowerLevel(struct adapter *padapter);
+
+void fill_txdesc_for_mp(struct adapter *padapter, u8 *ptxdesc);
+void SetPacketTx(struct adapter *padapter);
+void SetPacketRx(struct adapter *padapter, u8 bStartRx);
+
+void ResetPhyRxPktCount(struct adapter *padapter);
+u32 GetPhyRxPktReceived(struct adapter *padapter);
+u32 GetPhyRxPktCRC32Error(struct adapter *padapter);
+
+s32 SetPowerTracking(struct adapter *padapter, u8 enable);
+void GetPowerTracking(struct adapter *padapter, u8 *enable);
+
+u32 mp_query_psd(struct adapter *padapter, u8 *data);
+
+void Hal_SetAntenna(struct adapter *padapter);
+void Hal_SetBandwidth(struct adapter *padapter);
+
+void Hal_SetTxPower(struct adapter *padapter);
+void Hal_SetCarrierSuppressionTx(struct adapter *padapter, u8 bStart);
+void Hal_SetSingleToneTx (struct adapter *padapter , u8 bStart);
+void Hal_SetSingleCarrierTx (struct adapter *padapter, u8 bStart);
+void Hal_SetContinuousTx (struct adapter *padapter, u8 bStart);
+void Hal_SetBandwidth(struct adapter *padapter);
+
+void Hal_SetDataRate(struct adapter *padapter);
+void Hal_SetChannel(struct adapter *padapter);
+void Hal_SetAntennaPathPower(struct adapter *padapter);
+s32 Hal_SetThermalMeter(struct adapter *padapter, u8 target_ther);
+s32 Hal_SetPowerTracking(struct adapter *padapter, u8 enable);
+void Hal_GetPowerTracking(struct adapter *padapter, u8 * enable);
+void Hal_GetThermalMeter(struct adapter *padapter, u8 *value);
+void Hal_mpt_SwitchRfSetting(struct adapter *padapter);
+void Hal_MPT_CCKTxPowerAdjust(struct adapter * Adapter, bool bInCH14);
+void Hal_MPT_CCKTxPowerAdjustbyIndex(struct adapter *padapter, bool beven);
+void Hal_SetCCKTxPower(struct adapter *padapter, u8 * TxPower);
+void Hal_SetOFDMTxPower(struct adapter *padapter, u8 * TxPower);
+void Hal_TriggerRFThermalMeter(struct adapter *padapter);
+u8 Hal_ReadRFThermalMeter(struct adapter *padapter);
+void Hal_SetCCKContinuousTx(struct adapter *padapter, u8 bStart);
+void Hal_SetOFDMContinuousTx(struct adapter *padapter, u8 bStart);
+void Hal_ProSetCrystalCap (struct adapter *padapter , u32 CrystalCapVal);
+void MP_PHY_SetRFPathSwitch(struct adapter *padapter , bool bMain);
+u32 mpt_ProQueryCalTxPower(struct adapter *padapter, u8 RfPath);
+void MPT_PwrCtlDM(struct adapter *padapter, u32 bstart);
+u8 MptToMgntRate(u32 MptRateIdx);
+
+#endif /* _RTW_MP_H_ */