OSDN Git Service

staging: rtl8723bs: update to the latest driver
[android-x86/kernel.git] / drivers / staging / rtl8723bs / include / rtw_mp.h
index 5ada574..88ace11 100644 (file)
  * 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;
 
@@ -33,7 +28,7 @@ struct mp_xmit_frame
 
        int frame_tag;
 
-       _adapter *padapter;
+       struct adapter *padapter;
 
        uint mem[(MAX_MP_XMITBUF_SZ >> 2)];
 };
@@ -54,144 +49,122 @@ struct mp_tx
        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
@@ -199,7 +172,7 @@ typedef struct _MPT_CONTEXT
 #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,
@@ -243,24 +216,24 @@ enum {
 
 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;
@@ -269,7 +242,7 @@ struct mp_priv
        bool  rx_bindicatePkt;
        struct recv_stat rxstat;
 
-       //RF/BB relative
+       /* RF/BB relative */
        u8 channel;
        u8 bandwidth;
        u8 prime_channel_offset;
@@ -277,18 +250,18 @@ struct mp_priv
        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;
@@ -298,20 +271,20 @@ struct mp_priv
 
        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 {
@@ -325,29 +298,14 @@ struct bb_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,
@@ -357,19 +315,16 @@ typedef enum _MP_MODE_ {
        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 */
@@ -402,175 +357,156 @@ typedef enum _MPT_RATE_INDEX
        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_ */