/* SPDX-License-Identifier: GPL-2.0 */
|
/******************************************************************************
|
*
|
* Copyright(c) 2007 - 2010 Realtek Corporation. All rights reserved.
|
*
|
* 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_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_*/
|