root/drivers/staging/rtl8712/rtl871x_mp.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


   1 /* SPDX-License-Identifier: GPL-2.0 */
   2 /******************************************************************************
   3  *
   4  * Copyright(c) 2007 - 2010 Realtek Corporation. All rights reserved.
   5  *
   6  * Modifications for inclusion into the Linux staging tree are
   7  * Copyright(c) 2010 Larry Finger. All rights reserved.
   8  *
   9  * Contact information:
  10  * WLAN FAE <wlanfae@realtek.com>
  11  * Larry Finger <Larry.Finger@lwfinger.net>
  12  *
  13  ******************************************************************************/
  14 #ifndef __RTL871X_MP_H_
  15 #define __RTL871X_MP_H_
  16 
  17 #define MPT_NOOP                        0
  18 #define MPT_READ_MAC_1BYTE              1
  19 #define MPT_READ_MAC_2BYTE              2
  20 #define MPT_READ_MAC_4BYTE              3
  21 #define MPT_WRITE_MAC_1BYTE             4
  22 #define MPT_WRITE_MAC_2BYTE             5
  23 #define MPT_WRITE_MAC_4BYTE             6
  24 #define MPT_READ_BB_CCK                 7
  25 #define MPT_WRITE_BB_CCK                8
  26 #define MPT_READ_BB_OFDM                9
  27 #define MPT_WRITE_BB_OFDM               10
  28 #define MPT_READ_RF                     11
  29 #define MPT_WRITE_RF                    12
  30 #define MPT_READ_EEPROM_1BYTE           13
  31 #define MPT_WRITE_EEPROM_1BYTE          14
  32 #define MPT_READ_EEPROM_2BYTE           15
  33 #define MPT_WRITE_EEPROM_2BYTE          16
  34 #define MPT_SET_CSTHRESHOLD             21
  35 #define MPT_SET_INITGAIN                22
  36 #define MPT_SWITCH_BAND                 23
  37 #define MPT_SWITCH_CHANNEL              24
  38 #define MPT_SET_DATARATE                25
  39 #define MPT_SWITCH_ANTENNA              26
  40 #define MPT_SET_TX_POWER                27
  41 #define MPT_SET_CONT_TX                 28
  42 #define MPT_SET_SINGLE_CARRIER          29
  43 #define MPT_SET_CARRIER_SUPPRESSION     30
  44 #define MPT_GET_RATE_TABLE              31
  45 #define MPT_READ_TSSI                   32
  46 #define MPT_GET_THERMAL_METER           33
  47 #define MAX_MP_XMITBUF_SZ       2048
  48 #define NR_MP_XMITFRAME         8
  49 
  50 struct mp_xmit_frame {
  51         struct list_head list;
  52         struct pkt_attrib attrib;
  53         _pkt *pkt;
  54         int frame_tag;
  55         struct _adapter *padapter;
  56         u8 *mem_addr;
  57         u16 sz[8];
  58         struct urb *pxmit_urb[8];
  59         u8 bpending[8];
  60         u8 last[8];
  61 };
  62 
  63 struct mp_wiparam {
  64         u32 bcompleted;
  65         u32 act_type;
  66         u32 io_offset;
  67         u32 io_value;
  68 };
  69 
  70 struct mp_priv {
  71         struct _adapter *papdater;
  72         /*OID cmd handler*/
  73         struct mp_wiparam workparam;
  74         u8 act_in_progress;
  75         /*Tx Section*/
  76         u8 TID;
  77         u32 tx_pktcount;
  78         /*Rx Section*/
  79         u32 rx_pktcount;
  80         u32 rx_crcerrpktcount;
  81         u32 rx_pktloss;
  82         struct recv_stat rxstat;
  83         /*RF/BB relative*/
  84         u32 curr_ch;
  85         u32 curr_rateidx;
  86         u8 curr_bandwidth;
  87         u8 curr_modem;
  88         u8 curr_txpoweridx;
  89         u32 curr_crystalcap;
  90         u16 antenna_tx;
  91         u16 antenna_rx;
  92         u8 curr_rfpath;
  93         u8 check_mp_pkt;
  94         uint ForcedDataRate;
  95         struct wlan_network mp_network;
  96         unsigned char network_macaddr[6];
  97         /*Testing Flag*/
  98         u32 mode;/*0 for normal type packet,
  99                   * 1 for loopback packet (16bytes TXCMD)
 100                   */
 101         sint prev_fw_state;
 102         u8 *pallocated_mp_xmitframe_buf;
 103         u8 *pmp_xmtframe_buf;
 104         struct  __queue free_mp_xmitqueue;
 105         u32 free_mp_xmitframe_cnt;
 106 };
 107 
 108 struct IOCMD_STRUCT {
 109         u8      cmdclass;
 110         u16     value;
 111         u8      index;
 112 };
 113 
 114 struct rf_reg_param {
 115         u32 path;
 116         u32 offset;
 117         u32 value;
 118 };
 119 
 120 struct bb_reg_param {
 121         u32 offset;
 122         u32 value;
 123 };
 124 /* ======================================================================= */
 125 
 126 #define LOWER   true
 127 #define RAISE   false
 128 #define IOCMD_CTRL_REG                  0x10250370
 129 #define IOCMD_DATA_REG                  0x10250374
 130 #define IOCMD_GET_THERMAL_METER         0xFD000028
 131 #define IOCMD_CLASS_BB_RF               0xF0
 132 #define IOCMD_BB_READ_IDX               0x00
 133 #define IOCMD_BB_WRITE_IDX              0x01
 134 #define IOCMD_RF_READ_IDX               0x02
 135 #define IOCMD_RF_WRIT_IDX               0x03
 136 #define BB_REG_BASE_ADDR                0x800
 137 #define RF_PATH_A       0
 138 #define RF_PATH_B       1
 139 #define RF_PATH_C       2
 140 #define RF_PATH_D       3
 141 #define MAX_RF_PATH_NUMS        2
 142 #define _2MAC_MODE_     0
 143 #define _LOOPBOOK_MODE_ 1
 144 
 145 /* MP set force data rate base on the definition. */
 146 enum {
 147         /* CCK rate. */
 148         MPT_RATE_1M,    /* 0 */
 149         MPT_RATE_2M,
 150         MPT_RATE_55M,
 151         MPT_RATE_11M,   /* 3 */
 152 
 153         /* OFDM rate. */
 154         MPT_RATE_6M,    /* 4 */
 155         MPT_RATE_9M,
 156         MPT_RATE_12M,
 157         MPT_RATE_18M,
 158         MPT_RATE_24M,
 159         MPT_RATE_36M,
 160         MPT_RATE_48M,
 161         MPT_RATE_54M,   /* 11 */
 162 
 163         /* HT rate. */
 164         MPT_RATE_MCS0,  /* 12 */
 165         MPT_RATE_MCS1,
 166         MPT_RATE_MCS2,
 167         MPT_RATE_MCS3,
 168         MPT_RATE_MCS4,
 169         MPT_RATE_MCS5,
 170         MPT_RATE_MCS6,
 171         MPT_RATE_MCS7,  /* 19 */
 172         MPT_RATE_MCS8,
 173         MPT_RATE_MCS9,
 174         MPT_RATE_MCS10,
 175         MPT_RATE_MCS11,
 176         MPT_RATE_MCS12,
 177         MPT_RATE_MCS13,
 178         MPT_RATE_MCS14,
 179         MPT_RATE_MCS15, /* 27 */
 180         MPT_RATE_LAST
 181 };
 182 
 183 /* Represent Channel Width in HT Capabilities */
 184 enum HT_CHANNEL_WIDTH {
 185         HT_CHANNEL_WIDTH_20 = 0,
 186         HT_CHANNEL_WIDTH_40 = 1,
 187 };
 188 
 189 #define MAX_TX_PWR_INDEX_N_MODE 64      /* 0x3F */
 190 
 191 enum POWER_MODE {
 192         POWER_LOW = 0,
 193         POWER_NORMAL
 194 };
 195 
 196 #define RX_PKT_BROADCAST        1
 197 #define RX_PKT_DEST_ADDR        2
 198 #define RX_PKT_PHY_MATCH        3
 199 
 200 #define RPTMaxCount 0x000FFFFF
 201 
 202 /* parameter 1 : BitMask
 203  *      bit 0  : OFDM PPDU
 204  *      bit 1  : OFDM False Alarm
 205  *      bit 2  : OFDM MPDU OK
 206  *      bit 3  : OFDM MPDU Fail
 207  *      bit 4  : CCK PPDU
 208  *      bit 5  : CCK False Alarm
 209  *      bit 6  : CCK MPDU ok
 210  *      bit 7  : CCK MPDU fail
 211  *      bit 8  : HT PPDU counter
 212  *      bit 9  : HT false alarm
 213  *      bit 10 : HT MPDU total
 214  *      bit 11 : HT MPDU OK
 215  *      bit 12 : HT MPDU fail
 216  *      bit 15 : RX full drop
 217  */
 218 enum RXPHY_BITMASK {
 219         OFDM_PPDU_BIT = 0,
 220         OFDM_MPDU_OK_BIT,
 221         OFDM_MPDU_FAIL_BIT,
 222         CCK_PPDU_BIT,
 223         CCK_MPDU_OK_BIT,
 224         CCK_MPDU_FAIL_BIT,
 225         HT_PPDU_BIT,
 226         HT_MPDU_BIT,
 227         HT_MPDU_OK_BIT,
 228         HT_MPDU_FAIL_BIT,
 229 };
 230 
 231 enum ENCRY_CTRL_STATE {
 232         HW_CONTROL,             /*hw encryption& decryption*/
 233         SW_CONTROL,             /*sw encryption& decryption*/
 234         HW_ENCRY_SW_DECRY,      /*hw encryption & sw decryption*/
 235         SW_ENCRY_HW_DECRY       /*sw encryption & hw decryption*/
 236 };
 237 
 238 /* Bandwidth Offset */
 239 #define HAL_PRIME_CHNL_OFFSET_DONT_CARE 0
 240 #define HAL_PRIME_CHNL_OFFSET_LOWER     1
 241 #define HAL_PRIME_CHNL_OFFSET_UPPER     2
 242 /*=======================================================================*/
 243 void mp871xinit(struct _adapter *padapter);
 244 void mp871xdeinit(struct _adapter *padapter);
 245 u32 r8712_bb_reg_read(struct _adapter *Adapter, u16 offset);
 246 u8 r8712_bb_reg_write(struct _adapter *Adapter, u16 offset, u32 value);
 247 u32 r8712_rf_reg_read(struct _adapter *Adapter, u8 path, u8 offset);
 248 u8 r8712_rf_reg_write(struct _adapter *Adapter, u8 path,
 249                       u8 offset, u32 value);
 250 u32 r8712_get_bb_reg(struct _adapter *Adapter, u16 offset, u32 bitmask);
 251 u8 r8712_set_bb_reg(struct _adapter *Adapter, u16 offset,
 252                     u32 bitmask, u32 value);
 253 u32 r8712_get_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
 254                      u32 bitmask);
 255 u8 r8712_set_rf_reg(struct _adapter *Adapter, u8 path, u8 offset,
 256                     u32 bitmask, u32 value);
 257 
 258 void r8712_SetChannel(struct _adapter *pAdapter);
 259 void r8712_SetTxPower(struct _adapter *pAdapte);
 260 void r8712_SetTxAGCOffset(struct _adapter *pAdapter, u32 ulTxAGCOffset);
 261 void r8712_SetDataRate(struct _adapter *pAdapter);
 262 void r8712_SwitchBandwidth(struct _adapter *pAdapter);
 263 void r8712_SwitchAntenna(struct _adapter *pAdapter);
 264 void r8712_GetThermalMeter(struct _adapter *pAdapter, u32 *value);
 265 void r8712_SetContinuousTx(struct _adapter *pAdapter, u8 bStart);
 266 void r8712_SetSingleCarrierTx(struct _adapter *pAdapter, u8 bStart);
 267 void r8712_SetSingleToneTx(struct _adapter *pAdapter, u8 bStart);
 268 void r8712_SetCarrierSuppressionTx(struct _adapter *pAdapter, u8 bStart);
 269 void r8712_ResetPhyRxPktCount(struct _adapter *pAdapter);
 270 u32 r8712_GetPhyRxPktReceived(struct _adapter *pAdapter);
 271 u32 r8712_GetPhyRxPktCRC32Error(struct _adapter *pAdapter);
 272 
 273 #endif /*__RTL871X_MP_H_*/
 274 

/* [<][>][^][v][top][bottom][index][help] */