1 /* SPDX-License-Identifier: GPL-2.0 */
2 /******************************************************************************
4 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
6 ******************************************************************************/
10 #define MAX_MP_XMITBUF_SZ 2048
11 #define NR_MP_XMITFRAME 8
15 struct list_head list;
17 struct pkt_attrib attrib;
23 struct adapter *padapter;
25 uint mem[(MAX_MP_XMITBUF_SZ >> 2)];
36 typedef void(*wi_act_func)(void* padapter);
43 struct pkt_attrib attrib;
44 /* struct tx_desc desc; */
49 u32 buf_size, write_size;
53 #define MP_MAX_LINES 1000
54 #define MP_MAX_LINES_BYTES 256
56 typedef void (*MPT_WORK_ITEM_HANDLER)(void *Adapter);
57 typedef struct _MPT_CONTEXT
59 /* Indicate if we have started Mass Production Test. */
62 /* Indicate if the driver is unloading or unloaded. */
66 _timer MPh2c_timeout_timer;
67 /* Event used to sync H2c for BT control */
73 /* 8190 PCI does not support NDIS_WORK_ITEM. */
74 /* Work Item for Mass Production Test. */
75 /* NDIS_WORK_ITEM MptWorkItem; */
76 /* RT_WORK_ITEM MptWorkItem; */
77 /* Event used to sync the case unloading driver and MptWorkItem is still in progress. */
78 /* NDIS_EVENT MptWorkItemEvent; */
79 /* To protect the following variables. */
80 /* NDIS_SPIN_LOCK MptWorkItemSpinLock; */
81 /* Indicate a MptWorkItem is scheduled and not yet finished. */
82 bool bMptWorkItemInProgress;
83 /* An instance which implements function and context of MptWorkItem. */
84 MPT_WORK_ITEM_HANDLER CurrMptAct;
86 /* 1 =Start, 0 =Stop from UI. */
88 /* _TEST_MODE, defined in MPT_Req2.h */
90 /* Variable needed in each implementation of CurrMptAct. */
91 u32 MptActType; /* Type of action performed in CurrMptAct. */
92 /* The Offset of IO operation is depend of MptActType. */
94 /* The Value of IO operation is depend of MptActType. */
96 /* The RfPath of IO operation is depend of MptActType. */
99 enum WIRELESS_MODE MptWirelessModeToSw; /* Wireless mode to switch. */
100 u8 MptChannelToSw; /* Channel to switch. */
101 u8 MptInitGainToSet; /* Initial gain to set. */
102 u32 MptBandWidth; /* bandwidth to switch. */
103 u32 MptRateIndex; /* rate index. */
104 /* Register value kept for Single Carrier Tx test. */
106 /* Register value kept for Single Carrier Tx test. */
108 /* For MP Tx Power index */
109 u8 TxPwrLevel[2]; /* rf-A, rf-B */
111 /* Content of RCR Regsiter for Mass Production Test. */
113 /* true if we only receive packets with specific pattern. */
114 bool bMptFilterPattern;
115 /* Rx OK count, statistics used in Mass Production Test. */
117 /* Rx CRC32 error count, statistics used in Mass Production Test. */
120 bool bCckContTx; /* true if we are in CCK Continuous Tx test. */
121 bool bOfdmContTx; /* true if we are in OFDM Continuous Tx test. */
122 bool bStartContTx; /* true if we have start Continuous Tx test. */
123 /* true if we are in Single Carrier Tx test. */
125 /* true if we are in Carrier Suppression Tx Test. */
126 bool bCarrierSuppression;
127 /* true if we are in Single Tone Tx test. */
130 /* ACK counter asked by K.Y.. */
131 bool bMptEnableAckCounter;
134 /* SD3 Willis For 8192S to save 1T/2T RF table for ACUT Only fro ACUT delete later ~~~! */
135 /* s8 BufOfLines[2][MAX_LINES_HWCONFIG_TXT][MAX_BYTES_LINE_HWCONFIG_TXT]; */
136 /* s8 BufOfLines[2][MP_MAX_LINES][MP_MAX_LINES_BYTES]; */
137 /* s32 RfReadLine[2]; */
139 u8 APK_bound[2]; /* for APK path A/path B */
158 }MPT_CONTEXT, *PMPT_CONTEXT;
162 #define EFUSE_MAP_SIZE 512
164 #define EFUSE_MAX_SIZE 512
167 /* define RTPRIV_IOCTL_MP (SIOCIWFIRSTPRIV + 0x17) */
197 MP_DISABLE_BT_COEXIST,
202 #ifdef CONFIG_AP_WOWLAN
211 struct adapter *papdater;
214 u32 mode;/* 0 for normal type packet, 1 for loopback packet (16bytes TXCMD) */
218 /* OID cmd handler */
219 struct mp_wiparam workparam;
220 /* u8 act_in_progress; */
229 u32 rx_bssidpktcount;
231 u32 rx_pktcount_filter_out;
232 u32 rx_crcerrpktcount;
234 bool rx_bindicatePkt;
235 struct recv_stat rxstat;
240 u8 prime_channel_offset;
247 /* u32 curr_crystalcap; */
251 /* u8 curr_rfpath; */
256 /* uint ForcedDataRate; */
258 u8 mac_filter[ETH_ALEN];
261 struct wlan_network mp_network;
262 NDIS_802_11_MAC_ADDRESS network_macaddr;
264 u8 *pallocated_mp_xmitframe_buf;
265 u8 *pmp_xmtframe_buf;
266 struct __queue free_mp_xmitqueue;
267 u32 free_mp_xmitframe_cnt;
276 typedef struct _IOCMD_STRUCT_ {
282 struct rf_reg_param {
288 struct bb_reg_param {
296 /* Hardware Registers */
297 #define BB_REG_BASE_ADDR 0x800
305 MP_SINGLE_CARRIER_TX,
306 MP_CARRIER_SUPPRISSION_TX,
312 #define MAX_RF_PATH_NUMS RF_PATH_MAX
314 extern u8 mpdatarate[NumRates];
316 /* MP set force data rate base on the definition. */
317 enum MPT_RATE_INDEX {
319 MPT_RATE_1M = 0 , /* 0 */
322 MPT_RATE_11M, /* 3 */
332 MPT_RATE_54M, /* 11 */
335 MPT_RATE_MCS0, /* 12 */
342 MPT_RATE_MCS7, /* 19 */
350 MPT_RATE_MCS15, /* 27 */
351 /* VHT rate. Total: 20*/
352 MPT_RATE_VHT1SS_MCS0 = 100,/* To reserve MCS16~MCS31, the index starts from #100. */
353 MPT_RATE_VHT1SS_MCS1, /* #101 */
354 MPT_RATE_VHT1SS_MCS2,
355 MPT_RATE_VHT1SS_MCS3,
356 MPT_RATE_VHT1SS_MCS4,
357 MPT_RATE_VHT1SS_MCS5,
358 MPT_RATE_VHT1SS_MCS6, /* #106 */
359 MPT_RATE_VHT1SS_MCS7,
360 MPT_RATE_VHT1SS_MCS8,
361 MPT_RATE_VHT1SS_MCS9,
362 MPT_RATE_VHT2SS_MCS0,
363 MPT_RATE_VHT2SS_MCS1, /* #111 */
364 MPT_RATE_VHT2SS_MCS2,
365 MPT_RATE_VHT2SS_MCS3,
366 MPT_RATE_VHT2SS_MCS4,
367 MPT_RATE_VHT2SS_MCS5,
368 MPT_RATE_VHT2SS_MCS6, /* #116 */
369 MPT_RATE_VHT2SS_MCS7,
370 MPT_RATE_VHT2SS_MCS8,
371 MPT_RATE_VHT2SS_MCS9,
375 #define MAX_TX_PWR_INDEX_N_MODE 64 /* 0x3F */
382 /* The following enumeration is used to define the value of Reg0xD00[30:28] or JaguarReg0x914[18:16]. */
385 OFDM_ContinuousTx = 1,
386 OFDM_SingleCarrier = 2,
390 #define RX_PKT_BROADCAST 1
391 #define RX_PKT_DEST_ADDR 2
392 #define RX_PKT_PHY_MATCH 3
394 #define Mac_OFDM_OK 0x00000000
395 #define Mac_OFDM_Fail 0x10000000
396 #define Mac_OFDM_FasleAlarm 0x20000000
397 #define Mac_CCK_OK 0x30000000
398 #define Mac_CCK_Fail 0x40000000
399 #define Mac_CCK_FasleAlarm 0x50000000
400 #define Mac_HT_OK 0x60000000
401 #define Mac_HT_Fail 0x70000000
402 #define Mac_HT_FasleAlarm 0x90000000
403 #define Mac_DropPacket 0xA0000000
405 enum ENCRY_CTRL_STATE {
406 HW_CONTROL, /* hw encryption& decryption */
407 SW_CONTROL, /* sw encryption& decryption */
408 HW_ENCRY_SW_DECRY, /* hw encryption & sw decryption */
409 SW_ENCRY_HW_DECRY /* sw encryption & hw decryption */
414 MPT_OFDM, /* L and HT OFDM */
418 #define REG_RF_BB_GAIN_OFFSET 0x7f
419 #define RF_GAIN_OFFSET_MASK 0xfffff
422 /* struct mp_xmit_frame *alloc_mp_xmitframe(struct mp_priv *pmp_priv); */
423 /* int free_mp_xmitframe(struct xmit_priv *pxmitpriv, struct mp_xmit_frame *pmp_xmitframe); */
425 s32 init_mp_priv(struct adapter *padapter);
426 void free_mp_priv(struct mp_priv *pmp_priv);
427 s32 MPT_InitializeAdapter(struct adapter *padapter, u8 Channel);
428 void MPT_DeInitAdapter(struct adapter *padapter);
429 s32 mp_start_test(struct adapter *padapter);
430 void mp_stop_test(struct adapter *padapter);
432 u32 _read_rfreg(struct adapter *padapter, u8 rfpath, u32 addr, u32 bitmask);
433 void _write_rfreg(struct adapter *padapter, u8 rfpath, u32 addr, u32 bitmask, u32 val);
435 u32 read_macreg(struct adapter *padapter, u32 addr, u32 sz);
436 void write_macreg(struct adapter *padapter, u32 addr, u32 val, u32 sz);
437 u32 read_bbreg(struct adapter *padapter, u32 addr, u32 bitmask);
438 void write_bbreg(struct adapter *padapter, u32 addr, u32 bitmask, u32 val);
439 u32 read_rfreg(struct adapter *padapter, u8 rfpath, u32 addr);
440 void write_rfreg(struct adapter *padapter, u8 rfpath, u32 addr, u32 val);
442 void SetChannel(struct adapter *padapter);
443 void SetBandwidth(struct adapter *padapter);
444 int SetTxPower(struct adapter *padapter);
445 void SetAntennaPathPower(struct adapter *padapter);
446 void SetDataRate(struct adapter *padapter);
448 void SetAntenna(struct adapter *padapter);
450 s32 SetThermalMeter(struct adapter *padapter, u8 target_ther);
451 void GetThermalMeter(struct adapter *padapter, u8 *value);
453 void SetContinuousTx(struct adapter *padapter, u8 bStart);
454 void SetSingleCarrierTx(struct adapter *padapter, u8 bStart);
455 void SetSingleToneTx(struct adapter *padapter, u8 bStart);
456 void SetCarrierSuppressionTx(struct adapter *padapter, u8 bStart);
457 void PhySetTxPowerLevel(struct adapter *padapter);
459 void fill_txdesc_for_mp(struct adapter *padapter, u8 *ptxdesc);
460 void SetPacketTx(struct adapter *padapter);
461 void SetPacketRx(struct adapter *padapter, u8 bStartRx);
463 void ResetPhyRxPktCount(struct adapter *padapter);
464 u32 GetPhyRxPktReceived(struct adapter *padapter);
465 u32 GetPhyRxPktCRC32Error(struct adapter *padapter);
467 s32 SetPowerTracking(struct adapter *padapter, u8 enable);
468 void GetPowerTracking(struct adapter *padapter, u8 *enable);
470 u32 mp_query_psd(struct adapter *padapter, u8 *data);
472 void Hal_SetAntenna(struct adapter *padapter);
473 void Hal_SetBandwidth(struct adapter *padapter);
475 void Hal_SetTxPower(struct adapter *padapter);
476 void Hal_SetCarrierSuppressionTx(struct adapter *padapter, u8 bStart);
477 void Hal_SetSingleToneTx (struct adapter *padapter , u8 bStart);
478 void Hal_SetSingleCarrierTx (struct adapter *padapter, u8 bStart);
479 void Hal_SetContinuousTx (struct adapter *padapter, u8 bStart);
480 void Hal_SetBandwidth(struct adapter *padapter);
482 void Hal_SetDataRate(struct adapter *padapter);
483 void Hal_SetChannel(struct adapter *padapter);
484 void Hal_SetAntennaPathPower(struct adapter *padapter);
485 s32 Hal_SetThermalMeter(struct adapter *padapter, u8 target_ther);
486 s32 Hal_SetPowerTracking(struct adapter *padapter, u8 enable);
487 void Hal_GetPowerTracking(struct adapter *padapter, u8 * enable);
488 void Hal_GetThermalMeter(struct adapter *padapter, u8 *value);
489 void Hal_mpt_SwitchRfSetting(struct adapter *padapter);
490 void Hal_MPT_CCKTxPowerAdjust(struct adapter * Adapter, bool bInCH14);
491 void Hal_MPT_CCKTxPowerAdjustbyIndex(struct adapter *padapter, bool beven);
492 void Hal_SetCCKTxPower(struct adapter *padapter, u8 * TxPower);
493 void Hal_SetOFDMTxPower(struct adapter *padapter, u8 * TxPower);
494 void Hal_TriggerRFThermalMeter(struct adapter *padapter);
495 u8 Hal_ReadRFThermalMeter(struct adapter *padapter);
496 void Hal_SetCCKContinuousTx(struct adapter *padapter, u8 bStart);
497 void Hal_SetOFDMContinuousTx(struct adapter *padapter, u8 bStart);
498 void Hal_ProSetCrystalCap (struct adapter *padapter , u32 CrystalCapVal);
499 void MP_PHY_SetRFPathSwitch(struct adapter *padapter , bool bMain);
500 u32 mpt_ProQueryCalTxPower(struct adapter *padapter, u8 RfPath);
501 void MPT_PwrCtlDM(struct adapter *padapter, u32 bstart);
502 u8 MptToMgntRate(u32 MptRateIdx);
504 #endif /* _RTW_MP_H_ */