123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285 |
- /******************************************************************************
- *
- * 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_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_*/
|