1 /******************************************************************************
3 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 * You should have received a copy of the GNU General Public License along with
15 * this program; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
19 ******************************************************************************/
23 #define MAX_MP_XMITBUF_SZ 2048
24 #define NR_MP_XMITFRAME 8
30 struct pkt_attrib attrib;
38 uint mem[(MAX_MP_XMITBUF_SZ >> 2)];
49 typedef void(*wi_act_func)(void* padapter);
56 struct pkt_attrib attrib;
57 //struct tx_desc desc;
62 u32 buf_size, write_size;
66 #define MP_MAX_LINES 1000
67 #define MP_MAX_LINES_BYTES 256
90 typedef void (*MPT_WORK_ITEM_HANDLER)(IN void * Adapter);
91 typedef struct _MPT_CONTEXT
93 // Indicate if we have started Mass Production Test.
96 // Indicate if the driver is unloading or unloaded.
100 _timer MPh2c_timeout_timer;
101 // Event used to sync H2c for BT control
107 /* 8190 PCI does not support NDIS_WORK_ITEM. */
108 // Work Item for Mass Production Test.
109 //NDIS_WORK_ITEM MptWorkItem;
110 // RT_WORK_ITEM MptWorkItem;
111 // Event used to sync the case unloading driver and MptWorkItem is still in progress.
112 // NDIS_EVENT MptWorkItemEvent;
113 // To protect the following variables.
114 // NDIS_SPIN_LOCK MptWorkItemSpinLock;
115 // Indicate a MptWorkItem is scheduled and not yet finished.
116 bool bMptWorkItemInProgress;
117 // An instance which implements function and context of MptWorkItem.
118 MPT_WORK_ITEM_HANDLER CurrMptAct;
120 // 1=Start, 0=Stop from UI.
122 // _TEST_MODE, defined in MPT_Req2.h
124 // Variable needed in each implementation of CurrMptAct.
125 u32 MptActType; // Type of action performed in CurrMptAct.
126 // The Offset of IO operation is depend of MptActType.
128 // The Value of IO operation is depend of MptActType.
130 // The RfPath of IO operation is depend of MptActType.
133 WIRELESS_MODE MptWirelessModeToSw; // Wireless mode to switch.
134 u8 MptChannelToSw; // Channel to switch.
135 u8 MptInitGainToSet; // Initial gain to set.
136 //u32 bMptAntennaA; // true if we want to use antenna A.
137 u32 MptBandWidth; // bandwidth to switch.
138 u32 MptRateIndex; // rate index.
139 // Register value kept for Single Carrier Tx test.
141 // Register value kept for Single Carrier Tx test.
143 // For MP Tx Power index
144 u8 TxPwrLevel[2]; // rf-A, rf-B
146 // Content of RCR Regsiter for Mass Production Test.
148 // true if we only receive packets with specific pattern.
149 bool bMptFilterPattern;
150 // Rx OK count, statistics used in Mass Production Test.
152 // Rx CRC32 error count, statistics used in Mass Production Test.
155 bool bCckContTx; // true if we are in CCK Continuous Tx test.
156 bool bOfdmContTx; // true if we are in OFDM Continuous Tx test.
157 bool bStartContTx; // true if we have start Continuous Tx test.
158 // true if we are in Single Carrier Tx test.
160 // true if we are in Carrier Suppression Tx Test.
161 bool bCarrierSuppression;
162 //true if we are in Single Tone Tx test.
165 // ACK counter asked by K.Y..
166 bool bMptEnableAckCounter;
169 // SD3 Willis For 8192S to save 1T/2T RF table for ACUT Only fro ACUT delete later ~~~!
170 //s8 BufOfLines[2][MAX_LINES_HWCONFIG_TXT][MAX_BYTES_LINE_HWCONFIG_TXT];
171 //s8 BufOfLines[2][MP_MAX_LINES][MP_MAX_LINES_BYTES];
172 //s4Byte RfReadLine[2];
174 u8 APK_bound[2]; //for APK path A/path B
183 u4Byte backup0x58_RF_A;
184 u4Byte backup0x58_RF_B;
191 u1Byte mptOutBuf[100];
193 }MPT_CONTEXT, *PMPT_CONTEXT;
197 #define EFUSE_MAP_SIZE 512
199 #define EFUSE_MAX_SIZE 512
202 //#define RTPRIV_IOCTL_MP ( SIOCIWFIRSTPRIV + 0x17)
232 MP_DISABLE_BT_COEXIST,
237 #ifdef CONFIG_AP_WOWLAN
249 u32 mode;//0 for normal type packet, 1 for loopback packet (16bytes TXCMD)
254 struct mp_wiparam workparam;
255 // u8 act_in_progress;
264 u32 rx_bssidpktcount;
266 u32 rx_pktcount_filter_out;
267 u32 rx_crcerrpktcount;
269 bool rx_bindicatePkt;
270 struct recv_stat rxstat;
275 u8 prime_channel_offset;
282 // u32 curr_crystalcap;
291 // uint ForcedDataRate;
293 u8 mac_filter[ETH_ALEN];
296 struct wlan_network mp_network;
297 NDIS_802_11_MAC_ADDRESS network_macaddr;
299 u8 *pallocated_mp_xmitframe_buf;
300 u8 *pmp_xmtframe_buf;
301 _queue free_mp_xmitqueue;
302 u32 free_mp_xmitframe_cnt;
311 typedef struct _IOCMD_STRUCT_ {
317 struct rf_reg_param {
323 struct bb_reg_param {
328 typedef struct _MP_FIRMWARE {
329 FIRMWARE_SOURCE eFWSource;
334 u8 myBTFwBuffer[0x8000];
336 } RT_MP_FIRMWARE, *PRT_MP_FIRMWARE;
341 //=======================================================================
346 /* Hardware Registers */
347 #define BB_REG_BASE_ADDR 0x800
350 typedef enum _MP_MODE_ {
355 MP_SINGLE_CARRIER_TX,
356 MP_CARRIER_SUPPRISSION_TX,
363 #define MAX_RF_PATH_NUMS RF_PATH_MAX
366 extern u8 mpdatarate[NumRates];
368 /* MP set force data rate base on the definition. */
369 typedef enum _MPT_RATE_INDEX
372 MPT_RATE_1M =0 , /* 0 */
375 MPT_RATE_11M, /* 3 */
385 MPT_RATE_54M, /* 11 */
388 MPT_RATE_MCS0, /* 12 */
395 MPT_RATE_MCS7, /* 19 */
403 MPT_RATE_MCS15, /* 27 */
404 /* VHT rate. Total: 20*/
405 MPT_RATE_VHT1SS_MCS0 = 100,// To reserve MCS16~MCS31, the index starts from #100.
406 MPT_RATE_VHT1SS_MCS1, // #101
407 MPT_RATE_VHT1SS_MCS2,
408 MPT_RATE_VHT1SS_MCS3,
409 MPT_RATE_VHT1SS_MCS4,
410 MPT_RATE_VHT1SS_MCS5,
411 MPT_RATE_VHT1SS_MCS6, // #106
412 MPT_RATE_VHT1SS_MCS7,
413 MPT_RATE_VHT1SS_MCS8,
414 MPT_RATE_VHT1SS_MCS9,
415 MPT_RATE_VHT2SS_MCS0,
416 MPT_RATE_VHT2SS_MCS1, // #111
417 MPT_RATE_VHT2SS_MCS2,
418 MPT_RATE_VHT2SS_MCS3,
419 MPT_RATE_VHT2SS_MCS4,
420 MPT_RATE_VHT2SS_MCS5,
421 MPT_RATE_VHT2SS_MCS6, // #116
422 MPT_RATE_VHT2SS_MCS7,
423 MPT_RATE_VHT2SS_MCS8,
424 MPT_RATE_VHT2SS_MCS9,
426 }MPT_RATE_E, *PMPT_RATE_E;
428 #define MAX_TX_PWR_INDEX_N_MODE 64 // 0x3F
430 typedef enum _POWER_MODE_ {
435 // The following enumeration is used to define the value of Reg0xD00[30:28] or JaguarReg0x914[18:16].
436 typedef enum _OFDM_TX_MODE {
438 OFDM_ContinuousTx = 1,
439 OFDM_SingleCarrier = 2,
444 #define RX_PKT_BROADCAST 1
445 #define RX_PKT_DEST_ADDR 2
446 #define RX_PKT_PHY_MATCH 3
448 #define Mac_OFDM_OK 0x00000000
449 #define Mac_OFDM_Fail 0x10000000
450 #define Mac_OFDM_FasleAlarm 0x20000000
451 #define Mac_CCK_OK 0x30000000
452 #define Mac_CCK_Fail 0x40000000
453 #define Mac_CCK_FasleAlarm 0x50000000
454 #define Mac_HT_OK 0x60000000
455 #define Mac_HT_Fail 0x70000000
456 #define Mac_HT_FasleAlarm 0x90000000
457 #define Mac_DropPacket 0xA0000000
459 typedef enum _ENCRY_CTRL_STATE_ {
460 HW_CONTROL, //hw encryption& decryption
461 SW_CONTROL, //sw encryption& decryption
462 HW_ENCRY_SW_DECRY, //hw encryption & sw decryption
463 SW_ENCRY_HW_DECRY //sw encryption & hw decryption
466 typedef enum _MPT_TXPWR_DEF{
468 MPT_OFDM, // L and HT OFDM
472 #define REG_RF_BB_GAIN_OFFSET 0x7f
473 #define RF_GAIN_OFFSET_MASK 0xfffff
475 //=======================================================================
476 //extern struct mp_xmit_frame *alloc_mp_xmitframe(struct mp_priv *pmp_priv);
477 //extern int free_mp_xmitframe(struct xmit_priv *pxmitpriv, struct mp_xmit_frame *pmp_xmitframe);
479 extern s32 init_mp_priv(PADAPTER padapter);
480 extern void free_mp_priv(struct mp_priv *pmp_priv);
481 extern s32 MPT_InitializeAdapter(PADAPTER padapter, u8 Channel);
482 extern void MPT_DeInitAdapter(PADAPTER padapter);
483 extern s32 mp_start_test(PADAPTER padapter);
484 extern void mp_stop_test(PADAPTER padapter);
486 //=======================================================================
487 //extern void IQCalibrateBcut(PADAPTER pAdapter);
489 //extern u32 bb_reg_read(PADAPTER Adapter, u16 offset);
490 //extern u8 bb_reg_write(PADAPTER Adapter, u16 offset, u32 value);
491 //extern u32 rf_reg_read(PADAPTER Adapter, u8 path, u8 offset);
492 //extern u8 rf_reg_write(PADAPTER Adapter, u8 path, u8 offset, u32 value);
494 //extern u32 get_bb_reg(PADAPTER Adapter, u16 offset, u32 bitmask);
495 //extern u8 set_bb_reg(PADAPTER Adapter, u16 offset, u32 bitmask, u32 value);
496 //extern u32 get_rf_reg(PADAPTER Adapter, u8 path, u8 offset, u32 bitmask);
497 //extern u8 set_rf_reg(PADAPTER Adapter, u8 path, u8 offset, u32 bitmask, u32 value);
499 extern u32 _read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask);
500 extern void _write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask, u32 val);
502 extern u32 read_macreg(_adapter *padapter, u32 addr, u32 sz);
503 extern void write_macreg(_adapter *padapter, u32 addr, u32 val, u32 sz);
504 extern u32 read_bbreg(_adapter *padapter, u32 addr, u32 bitmask);
505 extern void write_bbreg(_adapter *padapter, u32 addr, u32 bitmask, u32 val);
506 extern u32 read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr);
507 extern void write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 val);
509 extern void SetChannel(PADAPTER pAdapter);
510 extern void SetBandwidth(PADAPTER pAdapter);
511 extern int SetTxPower(PADAPTER pAdapter);
512 extern void SetAntennaPathPower(PADAPTER pAdapter);
513 //extern void SetTxAGCOffset(PADAPTER pAdapter, u32 ulTxAGCOffset);
514 extern void SetDataRate(PADAPTER pAdapter);
516 extern void SetAntenna(PADAPTER pAdapter);
518 //extern void SetCrystalCap(PADAPTER pAdapter);
520 extern s32 SetThermalMeter(PADAPTER pAdapter, u8 target_ther);
521 extern void GetThermalMeter(PADAPTER pAdapter, u8 *value);
523 extern void SetContinuousTx(PADAPTER pAdapter, u8 bStart);
524 extern void SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart);
525 extern void SetSingleToneTx(PADAPTER pAdapter, u8 bStart);
526 extern void SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
527 extern void PhySetTxPowerLevel(PADAPTER pAdapter);
529 extern void fill_txdesc_for_mp(PADAPTER padapter, u8 *ptxdesc);
530 extern void SetPacketTx(PADAPTER padapter);
531 extern void SetPacketRx(PADAPTER pAdapter, u8 bStartRx);
533 extern void ResetPhyRxPktCount(PADAPTER pAdapter);
534 extern u32 GetPhyRxPktReceived(PADAPTER pAdapter);
535 extern u32 GetPhyRxPktCRC32Error(PADAPTER pAdapter);
537 extern s32 SetPowerTracking(PADAPTER padapter, u8 enable);
538 extern void GetPowerTracking(PADAPTER padapter, u8 *enable);
540 extern u32 mp_query_psd(PADAPTER pAdapter, u8 *data);
543 extern void Hal_SetAntenna(PADAPTER pAdapter);
544 extern void Hal_SetBandwidth(PADAPTER pAdapter);
546 extern void Hal_SetTxPower(PADAPTER pAdapter);
547 extern void Hal_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
548 extern void Hal_SetSingleToneTx ( PADAPTER pAdapter , u8 bStart );
549 extern void Hal_SetSingleCarrierTx (PADAPTER pAdapter, u8 bStart);
550 extern void Hal_SetContinuousTx (PADAPTER pAdapter, u8 bStart);
551 extern void Hal_SetBandwidth(PADAPTER pAdapter);
553 extern void Hal_SetDataRate(PADAPTER pAdapter);
554 extern void Hal_SetChannel(PADAPTER pAdapter);
555 extern void Hal_SetAntennaPathPower(PADAPTER pAdapter);
556 extern s32 Hal_SetThermalMeter(PADAPTER pAdapter, u8 target_ther);
557 extern s32 Hal_SetPowerTracking(PADAPTER padapter, u8 enable);
558 extern void Hal_GetPowerTracking(PADAPTER padapter, u8 * enable);
559 extern void Hal_GetThermalMeter(PADAPTER pAdapter, u8 *value);
560 extern void Hal_mpt_SwitchRfSetting(PADAPTER pAdapter);
561 extern void Hal_MPT_CCKTxPowerAdjust(PADAPTER Adapter, bool bInCH14);
562 extern void Hal_MPT_CCKTxPowerAdjustbyIndex(PADAPTER pAdapter, bool beven);
563 extern void Hal_SetCCKTxPower(PADAPTER pAdapter, u8 * TxPower);
564 extern void Hal_SetOFDMTxPower(PADAPTER pAdapter, u8 * TxPower);
565 extern void Hal_TriggerRFThermalMeter(PADAPTER pAdapter);
566 extern u8 Hal_ReadRFThermalMeter(PADAPTER pAdapter);
567 extern void Hal_SetCCKContinuousTx(PADAPTER pAdapter, u8 bStart);
568 extern void Hal_SetOFDMContinuousTx(PADAPTER pAdapter, u8 bStart);
569 extern void Hal_ProSetCrystalCap (PADAPTER pAdapter , u32 CrystalCapVal);
570 //extern void _rtw_mp_xmit_priv(struct xmit_priv *pxmitpriv);
571 extern void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter ,bool bMain);
572 extern u32 mpt_ProQueryCalTxPower(PADAPTER pAdapter,u8 RfPath);
573 extern void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart);
574 extern u8 MptToMgntRate(u32 MptRateIdx);