cregit-Linux how code gets into the kernel

Release 4.11 drivers/staging/rtl8712/rtl871x_mp.h

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


Overall Contributors

PersonTokensPropCommitsCommitProp
Larry Finger89499.67%125.00%
Ali Bahar10.11%125.00%
Raphaël Beamonte10.11%125.00%
Tapasweni Pathak10.11%125.00%
Total897100.00%4100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.