Add the rt linux 4.1.3-rt3 as base
[kvmfornfv.git] / kernel / drivers / staging / rtl8712 / rtl871x_mp.h
diff --git a/kernel/drivers/staging/rtl8712/rtl871x_mp.h b/kernel/drivers/staging/rtl8712/rtl871x_mp.h
new file mode 100644 (file)
index 0000000..75893f2
--- /dev/null
@@ -0,0 +1,286 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2010 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
+ *
+ * Modifications for inclusion into the Linux staging tree are
+ * Copyright(c) 2010 Larry Finger. All rights reserved.
+ *
+ * Contact information:
+ * WLAN FAE <wlanfae@realtek.com>
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ ******************************************************************************/
+#ifndef __RTL871X_MP_H_
+#define __RTL871X_MP_H_
+
+#define MPT_NOOP                       0
+#define MPT_READ_MAC_1BYTE             1
+#define MPT_READ_MAC_2BYTE             2
+#define MPT_READ_MAC_4BYTE             3
+#define MPT_WRITE_MAC_1BYTE            4
+#define MPT_WRITE_MAC_2BYTE            5
+#define MPT_WRITE_MAC_4BYTE            6
+#define MPT_READ_BB_CCK                        7
+#define MPT_WRITE_BB_CCK               8
+#define MPT_READ_BB_OFDM               9
+#define MPT_WRITE_BB_OFDM              10
+#define MPT_READ_RF                    11
+#define MPT_WRITE_RF                   12
+#define MPT_READ_EEPROM_1BYTE          13
+#define MPT_WRITE_EEPROM_1BYTE         14
+#define MPT_READ_EEPROM_2BYTE          15
+#define MPT_WRITE_EEPROM_2BYTE         16
+#define MPT_SET_CSTHRESHOLD            21
+#define MPT_SET_INITGAIN               22
+#define MPT_SWITCH_BAND                        23
+#define MPT_SWITCH_CHANNEL             24
+#define MPT_SET_DATARATE               25
+#define MPT_SWITCH_ANTENNA             26
+#define MPT_SET_TX_POWER               27
+#define MPT_SET_CONT_TX                        28
+#define MPT_SET_SINGLE_CARRIER         29
+#define MPT_SET_CARRIER_SUPPRESSION    30
+#define MPT_GET_RATE_TABLE             31
+#define MPT_READ_TSSI                  32
+#define MPT_GET_THERMAL_METER          33
+#define MAX_MP_XMITBUF_SZ      2048
+#define NR_MP_XMITFRAME                8
+
+struct mp_xmit_frame {
+       struct list_head list;
+       struct pkt_attrib attrib;
+       _pkt *pkt;
+       int frame_tag;
+       struct _adapter *padapter;
+       u8 *mem_addr;
+       u16 sz[8];
+       struct urb *pxmit_urb[8];
+       u8 bpending[8];
+       u8 last[8];
+};
+
+struct mp_wiparam {
+       u32 bcompleted;
+       u32 act_type;
+       u32 io_offset;
+       u32 io_value;
+};
+
+struct mp_priv {
+       struct _adapter *papdater;
+       /*OID cmd handler*/
+       struct mp_wiparam workparam;
+       u8 act_in_progress;
+       /*Tx Section*/
+       u8 TID;
+       u32 tx_pktcount;
+       /*Rx Section*/
+       u32 rx_pktcount;
+       u32 rx_crcerrpktcount;
+       u32 rx_pktloss;
+       struct recv_stat rxstat;
+       /*RF/BB relative*/
+       u32 curr_ch;
+       u32 curr_rateidx;
+       u8 curr_bandwidth;
+       u8 curr_modem;
+       u8 curr_txpoweridx;
+       u32 curr_crystalcap;
+       u16 antenna_tx;
+       u16 antenna_rx;
+       u8 curr_rfpath;
+       u8 check_mp_pkt;
+       uint ForcedDataRate;
+       struct wlan_network mp_network;
+       unsigned char network_macaddr[6];
+       /*Testing Flag*/
+       u32 mode;/*0 for normal type packet,
+                 * 1 for loopback packet (16bytes TXCMD)*/
+       sint prev_fw_state;
+       u8 *pallocated_mp_xmitframe_buf;
+       u8 *pmp_xmtframe_buf;
+       struct  __queue free_mp_xmitqueue;
+       u32 free_mp_xmitframe_cnt;
+};
+
+struct IOCMD_STRUCT {
+       u8      cmdclass;
+       u16     value;
+       u8      index;
+};
+
+struct rf_reg_param {
+       u32 path;
+       u32 offset;
+       u32 value;
+};
+
+struct bb_reg_param {
+       u32 offset;
+       u32 value;
+};
+/* ======================================================================= */
+
+#define LOWER  true
+#define RAISE  false
+#define IOCMD_CTRL_REG                 0x10250370
+#define IOCMD_DATA_REG                 0x10250374
+#define IOCMD_GET_THERMAL_METER                0xFD000028
+#define IOCMD_CLASS_BB_RF              0xF0
+#define IOCMD_BB_READ_IDX              0x00
+#define IOCMD_BB_WRITE_IDX             0x01
+#define IOCMD_RF_READ_IDX              0x02
+#define IOCMD_RF_WRIT_IDX              0x03
+#define BB_REG_BASE_ADDR               0x800
+#define RF_PATH_A      0
+#define RF_PATH_B      1
+#define RF_PATH_C      2
+#define RF_PATH_D      3
+#define MAX_RF_PATH_NUMS       2
+#define _2MAC_MODE_    0
+#define _LOOPBOOK_MODE_        1
+
+/* MP set force data rate base on the definition. */
+enum {
+       /* CCK rate. */
+       MPT_RATE_1M,    /* 0 */
+       MPT_RATE_2M,
+       MPT_RATE_55M,
+       MPT_RATE_11M,   /* 3 */
+
+       /* OFDM rate. */
+       MPT_RATE_6M,    /* 4 */
+       MPT_RATE_9M,
+       MPT_RATE_12M,
+       MPT_RATE_18M,
+       MPT_RATE_24M,
+       MPT_RATE_36M,
+       MPT_RATE_48M,
+       MPT_RATE_54M,   /* 11 */
+
+       /* HT rate. */
+       MPT_RATE_MCS0,  /* 12 */
+       MPT_RATE_MCS1,
+       MPT_RATE_MCS2,
+       MPT_RATE_MCS3,
+       MPT_RATE_MCS4,
+       MPT_RATE_MCS5,
+       MPT_RATE_MCS6,
+       MPT_RATE_MCS7,  /* 19 */
+       MPT_RATE_MCS8,
+       MPT_RATE_MCS9,
+       MPT_RATE_MCS10,
+       MPT_RATE_MCS11,
+       MPT_RATE_MCS12,
+       MPT_RATE_MCS13,
+       MPT_RATE_MCS14,
+       MPT_RATE_MCS15, /* 27 */
+       MPT_RATE_LAST
+};
+
+/* Represent Channel Width in HT Capabilities */
+enum HT_CHANNEL_WIDTH {
+       HT_CHANNEL_WIDTH_20 = 0,
+       HT_CHANNEL_WIDTH_40 = 1,
+};
+
+#define MAX_TX_PWR_INDEX_N_MODE 64     /* 0x3F */
+
+enum POWER_MODE {
+       POWER_LOW = 0,
+       POWER_NORMAL
+};
+
+#define RX_PKT_BROADCAST       1
+#define RX_PKT_DEST_ADDR       2
+#define RX_PKT_PHY_MATCH       3
+
+#define RPTMaxCount 0x000FFFFF
+
+/* parameter 1 : BitMask
+ *     bit 0  : OFDM PPDU
+ *     bit 1  : OFDM False Alarm
+ *     bit 2  : OFDM MPDU OK
+ *     bit 3  : OFDM MPDU Fail
+ *     bit 4  : CCK PPDU
+ *     bit 5  : CCK False Alarm
+ *     bit 6  : CCK MPDU ok
+ *     bit 7  : CCK MPDU fail
+ *     bit 8  : HT PPDU counter
+ *     bit 9  : HT false alarm
+ *     bit 10 : HT MPDU total
+ *     bit 11 : HT MPDU OK
+ *     bit 12 : HT MPDU fail
+ *     bit 15 : RX full drop
+ */
+enum RXPHY_BITMASK {
+       OFDM_PPDU_BIT = 0,
+       OFDM_MPDU_OK_BIT,
+       OFDM_MPDU_FAIL_BIT,
+       CCK_PPDU_BIT,
+       CCK_MPDU_OK_BIT,
+       CCK_MPDU_FAIL_BIT,
+       HT_PPDU_BIT,
+       HT_MPDU_BIT,
+       HT_MPDU_OK_BIT,
+       HT_MPDU_FAIL_BIT,
+};
+
+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*/
+};
+
+/* Bandwidth Offset */
+#define HAL_PRIME_CHNL_OFFSET_DONT_CARE        0
+#define HAL_PRIME_CHNL_OFFSET_LOWER    1
+#define HAL_PRIME_CHNL_OFFSET_UPPER    2
+/*=======================================================================*/
+void mp871xinit(struct _adapter *padapter);
+void mp871xdeinit(struct _adapter *padapter);
+u32 r8712_bb_reg_read(struct _adapter *Adapter, u16 offset);
+u8 r8712_bb_reg_write(struct _adapter *Adapter, u16 offset, u32 value);
+u32 r8712_rf_reg_read(struct _adapter *Adapter, u8 path, u8 offset);
+u8 r8712_rf_reg_write(struct _adapter *Adapter, u8 path,
+                     u8 offset, u32 value);
+u32 r8712_get_bb_reg(struct _adapter *Adapter, u16 offset, u32 bitmask);
+u8 r8712_set_bb_reg(struct _adapter *Adapter, u16 offset,
+                   u32 bitmask, u32 value);
+u32 r8712_get_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
+                    u32 bitmask);
+u8 r8712_set_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
+                   u32 bitmask, u32 value);
+
+void r8712_SetChannel(struct _adapter *pAdapter);
+void r8712_SetTxPower(struct _adapter *pAdapte);
+void r8712_SetTxAGCOffset(struct _adapter *pAdapter, u32 ulTxAGCOffset);
+void r8712_SetDataRate(struct _adapter *pAdapter);
+void r8712_SwitchBandwidth(struct _adapter *pAdapter);
+void r8712_SwitchAntenna(struct _adapter *pAdapter);
+void r8712_SetCrystalCap(struct _adapter *pAdapter);
+void r8712_GetThermalMeter(struct _adapter *pAdapter, u32 *value);
+void r8712_SetContinuousTx(struct _adapter *pAdapter, u8 bStart);
+void r8712_SetSingleCarrierTx(struct _adapter *pAdapter, u8 bStart);
+void r8712_SetSingleToneTx(struct _adapter *pAdapter, u8 bStart);
+void r8712_SetCarrierSuppressionTx(struct _adapter *pAdapter, u8 bStart);
+void r8712_ResetPhyRxPktCount(struct _adapter *pAdapter);
+u32 r8712_GetPhyRxPktReceived(struct _adapter *pAdapter);
+u32 r8712_GetPhyRxPktCRC32Error(struct _adapter *pAdapter);
+
+#endif /*__RTL871X_MP_H_*/
+