1
2
3
4
5
6
7
8
9 #ifndef __HALDMOUTSRC_H__
10 #define __HALDMOUTSRC_H__
11
12 #include "odm_EdcaTurboCheck.h"
13 #include "odm_DIG.h"
14 #include "odm_PathDiv.h"
15 #include "odm_DynamicBBPowerSaving.h"
16 #include "odm_DynamicTxPower.h"
17 #include "odm_CfoTracking.h"
18 #include "odm_NoiseMonitor.h"
19
20 #define TP_MODE 0
21 #define RSSI_MODE 1
22 #define TRAFFIC_LOW 0
23 #define TRAFFIC_HIGH 1
24 #define NONE 0
25
26
27
28 #define DPK_DELTA_MAPPING_NUM 13
29 #define index_mapping_HP_NUM 15
30 #define OFDM_TABLE_SIZE 43
31 #define CCK_TABLE_SIZE 33
32 #define TXSCALE_TABLE_SIZE 37
33 #define TXPWR_TRACK_TABLE_SIZE 30
34 #define DELTA_SWINGIDX_SIZE 30
35 #define BAND_NUM 4
36
37
38
39
40 #define AFH_PSD 1
41 #define MODE_40M 0
42 #define PSD_TH2 3
43 #define PSD_CHMIN 20
44 #define SIR_STEP_SIZE 3
45 #define Smooth_Size_1 5
46 #define Smooth_TH_1 3
47 #define Smooth_Size_2 10
48 #define Smooth_TH_2 4
49 #define Smooth_Size_3 20
50 #define Smooth_TH_3 4
51 #define Smooth_Step_Size 5
52 #define Adaptive_SIR 1
53 #define PSD_RESCAN 4
54 #define PSD_SCAN_INTERVAL 700
55
56
57 #define DM_DIG_HIGH_PWR_IGI_LOWER_BOUND 0x22
58 #define DM_DIG_Gmode_HIGH_PWR_IGI_LOWER_BOUND 0x28
59 #define DM_DIG_HIGH_PWR_THRESHOLD 0x3a
60 #define DM_DIG_LOW_PWR_THRESHOLD 0x14
61
62
63 #define ANTTESTALL 0x00
64 #define ANTTESTA 0x01
65 #define ANTTESTB 0x02
66
67 #define PS_MODE_ACTIVE 0x01
68
69
70 #define MAIN_ANT 1
71 #define AUX_ANT 2
72 #define MAX_ANT 3
73
74
75 #define SW_ANTDIV 0
76 #define HW_ANTDIV 1
77
78
79
80
81
82
83
84
85 struct dynamic_primary_CCA {
86 u8 PriCCA_flag;
87 u8 intf_flag;
88 u8 intf_type;
89 u8 DupRTS_flag;
90 u8 Monitor_flag;
91 u8 CH_offset;
92 u8 MF_state;
93 };
94
95 typedef struct _Rate_Adaptive_Table_ {
96 u8 firstconnect;
97 } RA_T, *pRA_T;
98
99 typedef struct _RX_High_Power_ {
100 u8 RXHP_flag;
101 u8 PSD_func_trigger;
102 u8 PSD_bitmap_RXHP[80];
103 u8 Pre_IGI;
104 u8 Cur_IGI;
105 u8 Pre_pw_th;
106 u8 Cur_pw_th;
107 bool First_time_enter;
108 bool RXHP_enable;
109 u8 TP_Mode;
110 RT_TIMER PSDTimer;
111 } RXHP_T, *pRXHP_T;
112
113 #define ASSOCIATE_ENTRY_NUM 32
114 #define ODM_ASSOCIATE_ENTRY_NUM ASSOCIATE_ENTRY_NUM
115
116
117
118
119
120 #define SWAW_STEP_PEAK 0
121 #define SWAW_STEP_DETERMINE 1
122
123 #define TP_MODE 0
124 #define RSSI_MODE 1
125 #define TRAFFIC_LOW 0
126 #define TRAFFIC_HIGH 1
127 #define TRAFFIC_UltraLOW 2
128
129 typedef struct _SW_Antenna_Switch_ {
130 u8 Double_chk_flag;
131 u8 try_flag;
132 s32 PreRSSI;
133 u8 CurAntenna;
134 u8 PreAntenna;
135 u8 RSSI_Trying;
136 u8 TestMode;
137 u8 bTriggerAntennaSwitch;
138 u8 SelectAntennaMap;
139 u8 RSSI_target;
140 u8 reset_idx;
141 u16 Single_Ant_Counter;
142 u16 Dual_Ant_Counter;
143 u16 Aux_FailDetec_Counter;
144 u16 Retry_Counter;
145
146
147 u8 SWAS_NoLink_State;
148 u32 SWAS_NoLink_BK_Reg860;
149 u32 SWAS_NoLink_BK_Reg92c;
150 u32 SWAS_NoLink_BK_Reg948;
151 bool ANTA_ON;
152 bool ANTB_ON;
153 bool Pre_Aux_FailDetec;
154 bool RSSI_AntDect_bResult;
155 u8 Ant5G;
156 u8 Ant2G;
157
158 s32 RSSI_sum_A;
159 s32 RSSI_sum_B;
160 s32 RSSI_cnt_A;
161 s32 RSSI_cnt_B;
162
163 u64 lastTxOkCnt;
164 u64 lastRxOkCnt;
165 u64 TXByteCnt_A;
166 u64 TXByteCnt_B;
167 u64 RXByteCnt_A;
168 u64 RXByteCnt_B;
169 u8 TrafficLoad;
170 u8 Train_time;
171 u8 Train_time_flag;
172 RT_TIMER SwAntennaSwitchTimer;
173 RT_TIMER SwAntennaSwitchTimer_8723B;
174 u32 PktCnt_SWAntDivByCtrlFrame;
175 bool bSWAntDivByCtrlFrame;
176 } SWAT_T, *pSWAT_T;
177
178
179
180
181 typedef struct _ODM_RATE_ADAPTIVE {
182 u8 Type;
183 u8 LdpcThres;
184 bool bUseLdpc;
185 bool bLowerRtsRate;
186 u8 HighRSSIThresh;
187 u8 LowRSSIThresh;
188 u8 RATRState;
189
190 } ODM_RATE_ADAPTIVE, *PODM_RATE_ADAPTIVE;
191
192 #define IQK_MAC_REG_NUM 4
193 #define IQK_ADDA_REG_NUM 16
194 #define IQK_BB_REG_NUM_MAX 10
195 #define IQK_BB_REG_NUM 9
196 #define HP_THERMAL_NUM 8
197
198 #define AVG_THERMAL_NUM 8
199 #define IQK_Matrix_REG_NUM 8
200 #define IQK_Matrix_Settings_NUM (14 + 24 + 21)
201
202
203
204
205 #define DM_Type_ByFW 0
206 #define DM_Type_ByDriver 1
207
208
209
210
211 #define MAX_PATH_NUM_92CS 2
212 #define MAX_PATH_NUM_8188E 1
213 #define MAX_PATH_NUM_8192E 2
214 #define MAX_PATH_NUM_8723B 1
215 #define MAX_PATH_NUM_8812A 2
216 #define MAX_PATH_NUM_8821A 1
217 #define MAX_PATH_NUM_8814A 4
218 #define MAX_PATH_NUM_8822B 2
219
220 #define IQK_THRESHOLD 8
221 #define DPK_THRESHOLD 4
222
223 struct odm_phy_info {
224
225
226
227
228 u8 rx_pwd_ba11;
229
230 u8 signal_quality;
231 s8 rx_mimo_signal_quality[4];
232 u8 rx_mimo_evm_dbm[4];
233
234 u8 rx_mimo_signal_strength[4];
235
236 u16 cfo_short[4];
237 u16 cfo_tail[4];
238
239 s8 rx_power;
240
241
242
243
244
245 s8 recv_signal_power;
246 u8 bt_rx_rssi_percentage;
247 u8 signal_strength;
248
249 s8 rx_pwr[4];
250
251 u8 rx_snr[4];
252 u8 band_width;
253 u8 bt_coex_pwr_adjust;
254 };
255
256 struct odm_packet_info {
257 u8 data_rate;
258 u8 station_id;
259 bool bssid_match;
260 bool to_self;
261 bool is_beacon;
262 };
263
264 struct odm_phy_dbg_info {
265
266 s8 RxSNRdB[4];
267 u32 NumQryPhyStatus;
268 u32 NumQryPhyStatusCCK;
269 u32 NumQryPhyStatusOFDM;
270 u8 NumQryBeaconPkt;
271
272 s32 RxEVM[4];
273
274 };
275
276 struct odm_mac_status_info {
277 u8 test;
278 };
279
280 typedef enum tag_Dynamic_ODM_Support_Ability_Type {
281
282 ODM_DIG = 0x00000001,
283 ODM_HIGH_POWER = 0x00000002,
284 ODM_CCK_CCA_TH = 0x00000004,
285 ODM_FA_STATISTICS = 0x00000008,
286 ODM_RAMASK = 0x00000010,
287 ODM_RSSI_MONITOR = 0x00000020,
288 ODM_SW_ANTDIV = 0x00000040,
289 ODM_HW_ANTDIV = 0x00000080,
290 ODM_BB_PWRSV = 0x00000100,
291 ODM_2TPATHDIV = 0x00000200,
292 ODM_1TPATHDIV = 0x00000400,
293 ODM_PSD2AFH = 0x00000800
294 } ODM_Ability_E;
295
296
297
298
299
300 typedef struct _ODM_STA_INFO {
301
302 bool bUsed;
303
304 u8 IOTPeer;
305
306
307
308 u8 RSSI_Path[4];
309 u8 RSSI_Ave;
310 u8 RXEVM[4];
311 u8 RXSNR[4];
312
313
314
315
316
317
318
319
320
321
322
323 } ODM_STA_INFO_T, *PODM_STA_INFO_T;
324
325
326
327
328 typedef enum _ODM_Common_Info_Definition {
329
330
331
332 ODM_CMNINFO_PLATFORM = 0,
333 ODM_CMNINFO_ABILITY,
334 ODM_CMNINFO_INTERFACE,
335 ODM_CMNINFO_MP_TEST_CHIP,
336 ODM_CMNINFO_IC_TYPE,
337 ODM_CMNINFO_CUT_VER,
338 ODM_CMNINFO_FAB_VER,
339 ODM_CMNINFO_RF_TYPE,
340 ODM_CMNINFO_RFE_TYPE,
341 ODM_CMNINFO_BOARD_TYPE,
342 ODM_CMNINFO_PACKAGE_TYPE,
343 ODM_CMNINFO_EXT_LNA,
344 ODM_CMNINFO_5G_EXT_LNA,
345 ODM_CMNINFO_EXT_PA,
346 ODM_CMNINFO_5G_EXT_PA,
347 ODM_CMNINFO_GPA,
348 ODM_CMNINFO_APA,
349 ODM_CMNINFO_GLNA,
350 ODM_CMNINFO_ALNA,
351 ODM_CMNINFO_EXT_TRSW,
352 ODM_CMNINFO_PATCH_ID,
353 ODM_CMNINFO_BINHCT_TEST,
354 ODM_CMNINFO_BWIFI_TEST,
355 ODM_CMNINFO_SMART_CONCURRENT,
356
357
358
359
360 ODM_CMNINFO_MAC_PHY_MODE,
361 ODM_CMNINFO_TX_UNI,
362 ODM_CMNINFO_RX_UNI,
363 ODM_CMNINFO_WM_MODE,
364 ODM_CMNINFO_BAND,
365 ODM_CMNINFO_SEC_CHNL_OFFSET,
366 ODM_CMNINFO_SEC_MODE,
367 ODM_CMNINFO_BW,
368 ODM_CMNINFO_CHNL,
369 ODM_CMNINFO_FORCED_RATE,
370
371 ODM_CMNINFO_DMSP_GET_VALUE,
372 ODM_CMNINFO_BUDDY_ADAPTOR,
373 ODM_CMNINFO_DMSP_IS_MASTER,
374 ODM_CMNINFO_SCAN,
375 ODM_CMNINFO_POWER_SAVING,
376 ODM_CMNINFO_ONE_PATH_CCA,
377 ODM_CMNINFO_DRV_STOP,
378 ODM_CMNINFO_PNP_IN,
379 ODM_CMNINFO_INIT_ON,
380 ODM_CMNINFO_ANT_TEST,
381 ODM_CMNINFO_NET_CLOSED,
382 ODM_CMNINFO_MP_MODE,
383
384 ODM_CMNINFO_FORCED_IGI_LB,
385 ODM_CMNINFO_IS1ANTENNA,
386 ODM_CMNINFO_RFDEFAULTPATH,
387
388
389
390 ODM_CMNINFO_WIFI_DIRECT,
391 ODM_CMNINFO_WIFI_DISPLAY,
392 ODM_CMNINFO_LINK_IN_PROGRESS,
393 ODM_CMNINFO_LINK,
394 ODM_CMNINFO_STATION_STATE,
395 ODM_CMNINFO_RSSI_MIN,
396 ODM_CMNINFO_DBG_COMP,
397 ODM_CMNINFO_DBG_LEVEL,
398 ODM_CMNINFO_RA_THRESHOLD_HIGH,
399 ODM_CMNINFO_RA_THRESHOLD_LOW,
400 ODM_CMNINFO_RF_ANTENNA_TYPE,
401 ODM_CMNINFO_BT_ENABLED,
402 ODM_CMNINFO_BT_HS_CONNECT_PROCESS,
403 ODM_CMNINFO_BT_HS_RSSI,
404 ODM_CMNINFO_BT_OPERATION,
405 ODM_CMNINFO_BT_LIMITED_DIG,
406 ODM_CMNINFO_BT_DISABLE_EDCA,
407
408
409
410 ODM_CMNINFO_STA_STATUS,
411 ODM_CMNINFO_PHY_STATUS,
412 ODM_CMNINFO_MAC_STATUS,
413
414 ODM_CMNINFO_MAX,
415 } ODM_CMNINFO_E;
416
417
418 typedef enum _ODM_Support_Ability_Definition {
419
420
421
422 ODM_BB_DIG = BIT0,
423 ODM_BB_RA_MASK = BIT1,
424 ODM_BB_DYNAMIC_TXPWR = BIT2,
425 ODM_BB_FA_CNT = BIT3,
426 ODM_BB_RSSI_MONITOR = BIT4,
427 ODM_BB_CCK_PD = BIT5,
428 ODM_BB_ANT_DIV = BIT6,
429 ODM_BB_PWR_SAVE = BIT7,
430 ODM_BB_PWR_TRAIN = BIT8,
431 ODM_BB_RATE_ADAPTIVE = BIT9,
432 ODM_BB_PATH_DIV = BIT10,
433 ODM_BB_PSD = BIT11,
434 ODM_BB_RXHP = BIT12,
435 ODM_BB_ADAPTIVITY = BIT13,
436 ODM_BB_CFO_TRACKING = BIT14,
437
438
439 ODM_MAC_EDCA_TURBO = BIT16,
440 ODM_MAC_EARLY_MODE = BIT17,
441
442
443 ODM_RF_TX_PWR_TRACK = BIT24,
444 ODM_RF_RX_GAIN_TRACK = BIT25,
445 ODM_RF_CALIBRATION = BIT26,
446 } ODM_ABILITY_E;
447
448
449 typedef enum tag_ODM_Support_Interface_Definition {
450 ODM_ITRF_SDIO = 0x4,
451 ODM_ITRF_ALL = 0x7,
452 } ODM_INTERFACE_E;
453
454
455 typedef enum tag_ODM_Support_IC_Type_Definition {
456 ODM_RTL8723B = BIT8,
457 } ODM_IC_TYPE_E;
458
459
460 typedef enum tag_ODM_Cut_Version_Definition {
461 ODM_CUT_A = 0,
462 ODM_CUT_B = 1,
463 ODM_CUT_C = 2,
464 ODM_CUT_D = 3,
465 ODM_CUT_E = 4,
466 ODM_CUT_F = 5,
467
468 ODM_CUT_I = 8,
469 ODM_CUT_J = 9,
470 ODM_CUT_K = 10,
471 ODM_CUT_TEST = 15,
472 } ODM_CUT_VERSION_E;
473
474
475 typedef enum tag_ODM_Fab_Version_Definition {
476 ODM_TSMC = 0,
477 ODM_UMC = 1,
478 } ODM_FAB_E;
479
480
481
482
483
484 typedef enum tag_ODM_RF_Path_Bit_Definition {
485 ODM_RF_TX_A = BIT0,
486 ODM_RF_TX_B = BIT1,
487 ODM_RF_TX_C = BIT2,
488 ODM_RF_TX_D = BIT3,
489 ODM_RF_RX_A = BIT4,
490 ODM_RF_RX_B = BIT5,
491 ODM_RF_RX_C = BIT6,
492 ODM_RF_RX_D = BIT7,
493 } ODM_RF_PATH_E;
494
495 typedef enum tag_ODM_RF_Type_Definition {
496 ODM_1T1R = 0,
497 ODM_1T2R = 1,
498 ODM_2T2R = 2,
499 ODM_2T3R = 3,
500 ODM_2T4R = 4,
501 ODM_3T3R = 5,
502 ODM_3T4R = 6,
503 ODM_4T4R = 7,
504 } ODM_RF_TYPE_E;
505
506
507
508
509
510
511
512
513
514
515
516 typedef enum tag_ODM_MAC_PHY_Mode_Definition {
517 ODM_SMSP = 0,
518 ODM_DMSP = 1,
519 ODM_DMDP = 2,
520 } ODM_MAC_PHY_MODE_E;
521
522 typedef enum tag_BT_Coexist_Definition {
523 ODM_BT_BUSY = 1,
524 ODM_BT_ON = 2,
525 ODM_BT_OFF = 3,
526 ODM_BT_NONE = 4,
527 } ODM_BT_COEXIST_E;
528
529
530 typedef enum tag_Operation_Mode_Definition {
531 ODM_NO_LINK = BIT0,
532 ODM_LINK = BIT1,
533 ODM_SCAN = BIT2,
534 ODM_POWERSAVE = BIT3,
535 ODM_AP_MODE = BIT4,
536 ODM_CLIENT_MODE = BIT5,
537 ODM_AD_HOC = BIT6,
538 ODM_WIFI_DIRECT = BIT7,
539 ODM_WIFI_DISPLAY = BIT8,
540 } ODM_OPERATION_MODE_E;
541
542
543 typedef enum tag_Wireless_Mode_Definition {
544 ODM_WM_UNKNOW = 0x0,
545 ODM_WM_B = BIT0,
546 ODM_WM_G = BIT1,
547 ODM_WM_A = BIT2,
548 ODM_WM_N24G = BIT3,
549 ODM_WM_N5G = BIT4,
550 ODM_WM_AUTO = BIT5,
551 ODM_WM_AC = BIT6,
552 } ODM_WIRELESS_MODE_E;
553
554
555 typedef enum tag_Band_Type_Definition {
556 ODM_BAND_2_4G = 0,
557 ODM_BAND_5G,
558 ODM_BAND_ON_BOTH,
559 ODM_BANDMAX
560 } ODM_BAND_TYPE_E;
561
562
563 typedef enum tag_Secondary_Channel_Offset_Definition {
564 ODM_DONT_CARE = 0,
565 ODM_BELOW = 1,
566 ODM_ABOVE = 2
567 } ODM_SEC_CHNL_OFFSET_E;
568
569
570 typedef enum tag_Security_Definition {
571 ODM_SEC_OPEN = 0,
572 ODM_SEC_WEP40 = 1,
573 ODM_SEC_TKIP = 2,
574 ODM_SEC_RESERVE = 3,
575 ODM_SEC_AESCCMP = 4,
576 ODM_SEC_WEP104 = 5,
577 ODM_WEP_WPA_MIXED = 6,
578 ODM_SEC_SMS4 = 7,
579 } ODM_SECURITY_E;
580
581
582 typedef enum tag_Bandwidth_Definition {
583 ODM_BW20M = 0,
584 ODM_BW40M = 1,
585 ODM_BW80M = 2,
586 ODM_BW160M = 3,
587 ODM_BW10M = 4,
588 } ODM_BW_E;
589
590
591
592
593 typedef enum tag_Board_Definition {
594 ODM_BOARD_DEFAULT = 0,
595 ODM_BOARD_MINICARD = BIT(0),
596 ODM_BOARD_SLIM = BIT(1),
597 ODM_BOARD_BT = BIT(2),
598 ODM_BOARD_EXT_PA = BIT(3),
599 ODM_BOARD_EXT_LNA = BIT(4),
600 ODM_BOARD_EXT_TRSW = BIT(5),
601 ODM_BOARD_EXT_PA_5G = BIT(6),
602 ODM_BOARD_EXT_LNA_5G = BIT(7),
603 } ODM_BOARD_TYPE_E;
604
605 typedef enum tag_ODM_Package_Definition {
606 ODM_PACKAGE_DEFAULT = 0,
607 ODM_PACKAGE_QFN68 = BIT(0),
608 ODM_PACKAGE_TFBGA90 = BIT(1),
609 ODM_PACKAGE_TFBGA79 = BIT(2),
610 } ODM_Package_TYPE_E;
611
612 typedef enum tag_ODM_TYPE_GPA_Definition {
613 TYPE_GPA0 = 0,
614 TYPE_GPA1 = BIT(1)|BIT(0)
615 } ODM_TYPE_GPA_E;
616
617 typedef enum tag_ODM_TYPE_APA_Definition {
618 TYPE_APA0 = 0,
619 TYPE_APA1 = BIT(1)|BIT(0)
620 } ODM_TYPE_APA_E;
621
622 typedef enum tag_ODM_TYPE_GLNA_Definition {
623 TYPE_GLNA0 = 0,
624 TYPE_GLNA1 = BIT(2)|BIT(0),
625 TYPE_GLNA2 = BIT(3)|BIT(1),
626 TYPE_GLNA3 = BIT(3)|BIT(2)|BIT(1)|BIT(0)
627 } ODM_TYPE_GLNA_E;
628
629 typedef enum tag_ODM_TYPE_ALNA_Definition {
630 TYPE_ALNA0 = 0,
631 TYPE_ALNA1 = BIT(2)|BIT(0),
632 TYPE_ALNA2 = BIT(3)|BIT(1),
633 TYPE_ALNA3 = BIT(3)|BIT(2)|BIT(1)|BIT(0)
634 } ODM_TYPE_ALNA_E;
635
636
637 typedef enum tag_CCA_Path {
638 ODM_CCA_2R = 0,
639 ODM_CCA_1R_A = 1,
640 ODM_CCA_1R_B = 2,
641 } ODM_CCA_PATH_E;
642
643 typedef struct _ODM_RA_Info_ {
644 u8 RateID;
645 u32 RateMask;
646 u32 RAUseRate;
647 u8 RateSGI;
648 u8 RssiStaRA;
649 u8 PreRssiStaRA;
650 u8 SGIEnable;
651 u8 DecisionRate;
652 u8 PreRate;
653 u8 HighestRate;
654 u8 LowestRate;
655 u32 NscUp;
656 u32 NscDown;
657 u16 RTY[5];
658 u32 TOTAL;
659 u16 DROP;
660 u8 Active;
661 u16 RptTime;
662 u8 RAWaitingCounter;
663 u8 RAPendingCounter;
664 u8 PTActive;
665 u8 PTTryState;
666 u8 PTStage;
667 u8 PTStopCount;
668 u8 PTPreRate;
669 u8 PTPreRssi;
670 u8 PTModeSS;
671 u8 RAstage;
672 u8 PTSmoothFactor;
673 } ODM_RA_INFO_T, *PODM_RA_INFO_T;
674
675 typedef struct _IQK_MATRIX_REGS_SETTING {
676 bool bIQKDone;
677 s32 Value[3][IQK_Matrix_REG_NUM];
678 bool bBWIqkResultSaved[3];
679 } IQK_MATRIX_REGS_SETTING, *PIQK_MATRIX_REGS_SETTING;
680
681
682
683 typedef struct ODM_RF_Calibration_Structure {
684
685
686 u32 RegA24;
687 s32 RegE94;
688 s32 RegE9C;
689 s32 RegEB4;
690 s32 RegEBC;
691
692 u8 TXPowercount;
693 bool bTXPowerTrackingInit;
694 bool bTXPowerTracking;
695 u8 TxPowerTrackControl;
696 u8 TM_Trigger;
697 u8 InternalPA5G[2];
698
699 u8 ThermalMeter[2];
700 u8 ThermalValue;
701 u8 ThermalValue_LCK;
702 u8 ThermalValue_IQK;
703 u8 ThermalValue_DPK;
704 u8 ThermalValue_AVG[AVG_THERMAL_NUM];
705 u8 ThermalValue_AVG_index;
706 u8 ThermalValue_RxGain;
707 u8 ThermalValue_Crystal;
708 u8 ThermalValue_DPKstore;
709 u8 ThermalValue_DPKtrack;
710 bool TxPowerTrackingInProgress;
711
712 bool bReloadtxpowerindex;
713 u8 bRfPiEnable;
714 u32 TXPowerTrackingCallbackCnt;
715
716
717 u8 bCCKinCH14;
718 u8 CCK_index;
719 u8 OFDM_index[MAX_RF_PATH];
720 s8 PowerIndexOffset[MAX_RF_PATH];
721 s8 DeltaPowerIndex[MAX_RF_PATH];
722 s8 DeltaPowerIndexLast[MAX_RF_PATH];
723 bool bTxPowerChanged;
724
725 u8 ThermalValue_HP[HP_THERMAL_NUM];
726 u8 ThermalValue_HP_index;
727 IQK_MATRIX_REGS_SETTING IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];
728 bool bNeedIQK;
729 bool bIQKInProgress;
730 u8 Delta_IQK;
731 u8 Delta_LCK;
732 s8 BBSwingDiff2G, BBSwingDiff5G;
733 u8 DeltaSwingTableIdx_2GCCKA_P[DELTA_SWINGIDX_SIZE];
734 u8 DeltaSwingTableIdx_2GCCKA_N[DELTA_SWINGIDX_SIZE];
735 u8 DeltaSwingTableIdx_2GCCKB_P[DELTA_SWINGIDX_SIZE];
736 u8 DeltaSwingTableIdx_2GCCKB_N[DELTA_SWINGIDX_SIZE];
737 u8 DeltaSwingTableIdx_2GA_P[DELTA_SWINGIDX_SIZE];
738 u8 DeltaSwingTableIdx_2GA_N[DELTA_SWINGIDX_SIZE];
739 u8 DeltaSwingTableIdx_2GB_P[DELTA_SWINGIDX_SIZE];
740 u8 DeltaSwingTableIdx_2GB_N[DELTA_SWINGIDX_SIZE];
741 u8 DeltaSwingTableIdx_5GA_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
742 u8 DeltaSwingTableIdx_5GA_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
743 u8 DeltaSwingTableIdx_5GB_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
744 u8 DeltaSwingTableIdx_5GB_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
745 u8 DeltaSwingTableIdx_2GA_P_8188E[DELTA_SWINGIDX_SIZE];
746 u8 DeltaSwingTableIdx_2GA_N_8188E[DELTA_SWINGIDX_SIZE];
747
748
749
750
751 u32 RegC04;
752 u32 Reg874;
753 u32 RegC08;
754 u32 RegB68;
755 u32 RegB6C;
756 u32 Reg870;
757 u32 Reg860;
758 u32 Reg864;
759
760 bool bIQKInitialized;
761 bool bLCKInProgress;
762 bool bAntennaDetected;
763 u32 ADDA_backup[IQK_ADDA_REG_NUM];
764 u32 IQK_MAC_backup[IQK_MAC_REG_NUM];
765 u32 IQK_BB_backup_recover[9];
766 u32 IQK_BB_backup[IQK_BB_REG_NUM];
767 u32 TxIQC_8723B[2][3][2];
768 u32 RxIQC_8723B[2][2][2];
769
770
771 u32 APKoutput[2][2];
772 u8 bAPKdone;
773 u8 bAPKThermalMeterIgnore;
774
775
776 bool bDPKFail;
777 u8 bDPdone;
778 u8 bDPPathAOK;
779 u8 bDPPathBOK;
780
781 u32 TxLOK[2];
782
783 } ODM_RF_CAL_T, *PODM_RF_CAL_T;
784
785
786
787
788 typedef struct _FAST_ANTENNA_TRAINNING_ {
789 u8 Bssid[6];
790 u8 antsel_rx_keep_0;
791 u8 antsel_rx_keep_1;
792 u8 antsel_rx_keep_2;
793 u8 antsel_rx_keep_3;
794 u32 antSumRSSI[7];
795 u32 antRSSIcnt[7];
796 u32 antAveRSSI[7];
797 u8 FAT_State;
798 u32 TrainIdx;
799 u8 antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
800 u8 antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
801 u8 antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
802 u32 MainAnt_Sum[ODM_ASSOCIATE_ENTRY_NUM];
803 u32 AuxAnt_Sum[ODM_ASSOCIATE_ENTRY_NUM];
804 u32 MainAnt_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
805 u32 AuxAnt_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
806 u8 RxIdleAnt;
807 bool bBecomeLinked;
808 u32 MinMaxRSSI;
809 u8 idx_AntDiv_counter_2G;
810 u8 idx_AntDiv_counter_5G;
811 u32 AntDiv_2G_5G;
812 u32 CCK_counter_main;
813 u32 CCK_counter_aux;
814 u32 OFDM_counter_main;
815 u32 OFDM_counter_aux;
816
817 u32 CCK_CtrlFrame_Cnt_main;
818 u32 CCK_CtrlFrame_Cnt_aux;
819 u32 OFDM_CtrlFrame_Cnt_main;
820 u32 OFDM_CtrlFrame_Cnt_aux;
821 u32 MainAnt_CtrlFrame_Sum;
822 u32 AuxAnt_CtrlFrame_Sum;
823 u32 MainAnt_CtrlFrame_Cnt;
824 u32 AuxAnt_CtrlFrame_Cnt;
825
826 } FAT_T, *pFAT_T;
827
828 typedef enum _FAT_STATE {
829 FAT_NORMAL_STATE = 0,
830 FAT_TRAINING_STATE = 1,
831 } FAT_STATE_E, *PFAT_STATE_E;
832
833 typedef enum _ANT_DIV_TYPE {
834 NO_ANTDIV = 0xFF,
835 CG_TRX_HW_ANTDIV = 0x01,
836 CGCS_RX_HW_ANTDIV = 0x02,
837 FIXED_HW_ANTDIV = 0x03,
838 CG_TRX_SMART_ANTDIV = 0x04,
839 CGCS_RX_SW_ANTDIV = 0x05,
840 S0S1_SW_ANTDIV = 0x06
841 } ANT_DIV_TYPE_E, *PANT_DIV_TYPE_E;
842
843 typedef struct _ODM_PATH_DIVERSITY_ {
844 u8 RespTxPath;
845 u8 PathSel[ODM_ASSOCIATE_ENTRY_NUM];
846 u32 PathA_Sum[ODM_ASSOCIATE_ENTRY_NUM];
847 u32 PathB_Sum[ODM_ASSOCIATE_ENTRY_NUM];
848 u32 PathA_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
849 u32 PathB_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
850 } PATHDIV_T, *pPATHDIV_T;
851
852 typedef enum _BASEBAND_CONFIG_PHY_REG_PG_VALUE_TYPE{
853 PHY_REG_PG_RELATIVE_VALUE = 0,
854 PHY_REG_PG_EXACT_VALUE = 1
855 } PHY_REG_PG_TYPE;
856
857
858
859
860 typedef struct _ANT_DETECTED_INFO {
861 bool bAntDetected;
862 u32 dBForAntA;
863 u32 dBForAntB;
864 u32 dBForAntO;
865 } ANT_DETECTED_INFO, *PANT_DETECTED_INFO;
866
867
868
869
870 typedef struct DM_Out_Source_Dynamic_Mechanism_Structure {
871
872
873
874
875 struct adapter *Adapter;
876
877 bool odm_ready;
878
879 PHY_REG_PG_TYPE PhyRegPgValueType;
880 u8 PhyRegPgVersion;
881
882 u64 DebugComponents;
883 u32 DebugLevel;
884
885 u32 NumQryPhyStatusAll;
886 u32 LastNumQryPhyStatusAll;
887 u32 RxPWDBAve;
888 bool MPDIG_2G;
889 u8 Times_2G;
890
891
892 bool bCckHighPower;
893 u8 RFPathRxEnable;
894 u8 ControlChannel;
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915 u8 SupportPlatform;
916
917 u32 SupportAbility;
918
919 u8 SupportInterface;
920
921 u32 SupportICType;
922
923 u8 CutVersion;
924
925 u8 FabVersion;
926
927 u8 RFType;
928 u8 RFEType;
929
930 u8 BoardType;
931 u8 PackageType;
932 u8 TypeGLNA;
933 u8 TypeGPA;
934 u8 TypeALNA;
935 u8 TypeAPA;
936
937 u8 ExtLNA;
938 u8 ExtLNA5G;
939
940 u8 ExtPA;
941 u8 ExtPA5G;
942
943 u8 ExtTRSW;
944 u8 PatchID;
945 bool bInHctTest;
946 bool bWIFITest;
947
948 bool bDualMacSmartConcurrent;
949 u32 BK_SupportAbility;
950 u8 AntDivType;
951
952
953
954
955
956
957
958 u8 u8_temp;
959 bool bool_temp;
960 struct adapter *adapter_temp;
961
962
963 u8 *pMacPhyMode;
964
965 u64 *pNumTxBytesUnicast;
966
967 u64 *pNumRxBytesUnicast;
968
969 u8 *pwirelessmode;
970
971 u8 *pBandType;
972
973 u8 *pSecChOffset;
974
975 u8 *pSecurity;
976
977 u8 *pBandWidth;
978
979 u8 *pChannel;
980 bool DPK_Done;
981
982
983 bool *pbGetValueFromOtherMac;
984 struct adapter **pBuddyAdapter;
985 bool *pbMasterOfDMSP;
986
987 bool *pbScanInProcess;
988 bool *pbPowerSaving;
989
990 u8 *pOnePathCCA;
991
992 u8 *pAntennaTest;
993 bool *pbNet_closed;
994 u8 *mp_mode;
995
996 u8 *pu1ForcedIgiLb;
997
998 bool *pIs1Antenna;
999 u8 *pRFDefaultPath;
1000
1001
1002
1003 u16 *pForcedDataRate;
1004
1005 bool bLinkInProcess;
1006 bool bWIFI_Direct;
1007 bool bWIFI_Display;
1008 bool bLinked;
1009
1010 bool bsta_state;
1011 u8 RSSI_Min;
1012 u8 InterfaceIndex;
1013 bool bIsMPChip;
1014 bool bOneEntryOnly;
1015
1016 bool bBtEnabled;
1017 bool bBtConnectProcess;
1018 u8 btHsRssi;
1019 bool bBtHsOperation;
1020 bool bBtDisableEdcaTurbo;
1021 bool bBtLimitedDig;
1022
1023 u8 RSSI_A;
1024 u8 RSSI_B;
1025 u64 RSSI_TRSW;
1026 u64 RSSI_TRSW_H;
1027 u64 RSSI_TRSW_L;
1028 u64 RSSI_TRSW_iso;
1029
1030 u8 RxRate;
1031 bool bNoisyState;
1032 u8 TxRate;
1033 u8 LinkedInterval;
1034 u8 preChannel;
1035 u32 TxagcOffsetValueA;
1036 bool IsTxagcOffsetPositiveA;
1037 u32 TxagcOffsetValueB;
1038 bool IsTxagcOffsetPositiveB;
1039 u64 lastTxOkCnt;
1040 u64 lastRxOkCnt;
1041 u32 BbSwingOffsetA;
1042 bool IsBbSwingOffsetPositiveA;
1043 u32 BbSwingOffsetB;
1044 bool IsBbSwingOffsetPositiveB;
1045 s8 TH_L2H_ini;
1046 s8 TH_EDCCA_HL_diff;
1047 s8 IGI_Base;
1048 u8 IGI_target;
1049 bool ForceEDCCA;
1050 u8 AdapEn_RSSI;
1051 s8 Force_TH_H;
1052 s8 Force_TH_L;
1053 u8 IGI_LowerBound;
1054 u8 antdiv_rssi;
1055 u8 AntType;
1056 u8 pre_AntType;
1057 u8 antdiv_period;
1058 u8 antdiv_select;
1059 u8 NdpaPeriod;
1060 bool H2C_RARpt_connect;
1061
1062
1063 bool adaptivity_flag;
1064 bool NHM_disable;
1065 bool TxHangFlg;
1066 bool Carrier_Sense_enable;
1067 u8 tolerance_cnt;
1068 u64 NHMCurTxOkcnt;
1069 u64 NHMCurRxOkcnt;
1070 u64 NHMLastTxOkcnt;
1071 u64 NHMLastRxOkcnt;
1072 u8 txEdcca1;
1073 u8 txEdcca0;
1074 s8 H2L_lb;
1075 s8 L2H_lb;
1076 u8 Adaptivity_IGI_upper;
1077 u8 NHM_cnt_0;
1078
1079 ODM_NOISE_MONITOR noise_level;
1080
1081
1082
1083
1084 PSTA_INFO_T pODM_StaInfo[ODM_ASSOCIATE_ENTRY_NUM];
1085
1086
1087
1088
1089
1090 bool RaSupport88E;
1091
1092
1093
1094
1095 struct odm_phy_dbg_info PhyDbgInfo;
1096
1097
1098
1099 struct odm_mac_status_info *pMacInfo;
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112 FAT_T DM_FatTable;
1113 DIG_T DM_DigTable;
1114 PS_T DM_PSTable;
1115 struct dynamic_primary_CCA DM_PriCCA;
1116 RXHP_T DM_RXHP_Table;
1117 RA_T DM_RA_Table;
1118 false_ALARM_STATISTICS FalseAlmCnt;
1119 false_ALARM_STATISTICS FlaseAlmCntBuddyAdapter;
1120 SWAT_T DM_SWAT_Table;
1121 bool RSSI_test;
1122 CFO_TRACKING DM_CfoTrack;
1123
1124 EDCA_T DM_EDCA_Table;
1125 u32 WMMEDCA_BE;
1126 PATHDIV_T DM_PathDiv;
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143 bool *pbDriverStopped;
1144 bool *pbDriverIsGoingToPnpSetPowerSleep;
1145 bool *pinit_adpt_in_progress;
1146
1147
1148 bool bUserAssignLevel;
1149 RT_TIMER PSDTimer;
1150 u8 RSSI_BT;
1151 bool bPSDinProcess;
1152 bool bPSDactive;
1153 bool bDMInitialGainEnable;
1154
1155
1156 RT_TIMER MPT_DIGTimer;
1157
1158
1159 u8 bUseRAMask;
1160
1161 ODM_RATE_ADAPTIVE RateAdaptive;
1162
1163 ANT_DETECTED_INFO AntDetectedInfo;
1164
1165 ODM_RF_CAL_T RFCalibrateInfo;
1166
1167
1168
1169
1170 u8 BbSwingIdxOfdm[MAX_RF_PATH];
1171 u8 BbSwingIdxOfdmCurrent;
1172 u8 BbSwingIdxOfdmBase[MAX_RF_PATH];
1173 bool BbSwingFlagOfdm;
1174 u8 BbSwingIdxCck;
1175 u8 BbSwingIdxCckCurrent;
1176 u8 BbSwingIdxCckBase;
1177 u8 DefaultOfdmIndex;
1178 u8 DefaultCckIndex;
1179 bool BbSwingFlagCck;
1180
1181 s8 Absolute_OFDMSwingIdx[MAX_RF_PATH];
1182 s8 Remnant_OFDMSwingIdx[MAX_RF_PATH];
1183 s8 Remnant_CCKSwingIdx;
1184 s8 Modify_TxAGC_Value;
1185 bool Modify_TxAGC_Flag_PathA;
1186 bool Modify_TxAGC_Flag_PathB;
1187 bool Modify_TxAGC_Flag_PathC;
1188 bool Modify_TxAGC_Flag_PathD;
1189 bool Modify_TxAGC_Flag_PathA_CCK;
1190
1191 s8 KfreeOffset[MAX_RF_PATH];
1192
1193
1194
1195
1196
1197 RT_TIMER PathDivSwitchTimer;
1198
1199 RT_TIMER CCKPathDiversityTimer;
1200 RT_TIMER FastAntTrainingTimer;
1201
1202
1203
1204 #if (BEAMFORMING_SUPPORT == 1)
1205 RT_BEAMFORMING_INFO BeamformingInfo;
1206 #endif
1207 } DM_ODM_T, *PDM_ODM_T;
1208
1209 #define ODM_RF_PATH_MAX 2
1210
1211 typedef enum _ODM_RF_RADIO_PATH {
1212 ODM_RF_PATH_A = 0,
1213 ODM_RF_PATH_B = 1,
1214 ODM_RF_PATH_C = 2,
1215 ODM_RF_PATH_D = 3,
1216 ODM_RF_PATH_AB,
1217 ODM_RF_PATH_AC,
1218 ODM_RF_PATH_AD,
1219 ODM_RF_PATH_BC,
1220 ODM_RF_PATH_BD,
1221 ODM_RF_PATH_CD,
1222 ODM_RF_PATH_ABC,
1223 ODM_RF_PATH_ACD,
1224 ODM_RF_PATH_BCD,
1225 ODM_RF_PATH_ABCD,
1226
1227 } ODM_RF_RADIO_PATH_E, *PODM_RF_RADIO_PATH_E;
1228
1229 typedef enum _ODM_RF_CONTENT {
1230 odm_radioa_txt = 0x1000,
1231 odm_radiob_txt = 0x1001,
1232 odm_radioc_txt = 0x1002,
1233 odm_radiod_txt = 0x1003
1234 } ODM_RF_CONTENT;
1235
1236 typedef enum _ODM_BB_Config_Type {
1237 CONFIG_BB_PHY_REG,
1238 CONFIG_BB_AGC_TAB,
1239 CONFIG_BB_AGC_TAB_2G,
1240 CONFIG_BB_AGC_TAB_5G,
1241 CONFIG_BB_PHY_REG_PG,
1242 CONFIG_BB_PHY_REG_MP,
1243 CONFIG_BB_AGC_TAB_DIFF,
1244 } ODM_BB_Config_Type, *PODM_BB_Config_Type;
1245
1246 typedef enum _ODM_RF_Config_Type {
1247 CONFIG_RF_RADIO,
1248 CONFIG_RF_TXPWR_LMT,
1249 } ODM_RF_Config_Type, *PODM_RF_Config_Type;
1250
1251 typedef enum _ODM_FW_Config_Type {
1252 CONFIG_FW_NIC,
1253 CONFIG_FW_NIC_2,
1254 CONFIG_FW_AP,
1255 CONFIG_FW_WoWLAN,
1256 CONFIG_FW_WoWLAN_2,
1257 CONFIG_FW_AP_WoWLAN,
1258 CONFIG_FW_BT,
1259 } ODM_FW_Config_Type;
1260
1261
1262 typedef enum _RT_STATUS {
1263 RT_STATUS_SUCCESS,
1264 RT_STATUS_FAILURE,
1265 RT_STATUS_PENDING,
1266 RT_STATUS_RESOURCE,
1267 RT_STATUS_INVALID_CONTEXT,
1268 RT_STATUS_INVALID_PARAMETER,
1269 RT_STATUS_NOT_SUPPORT,
1270 RT_STATUS_OS_API_FAILED,
1271 } RT_STATUS, *PRT_STATUS;
1272
1273 #ifdef REMOVE_PACK
1274 #pragma pack()
1275 #endif
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288 #define LNA_Low_Gain_1 0x64
1289 #define LNA_Low_Gain_2 0x5A
1290 #define LNA_Low_Gain_3 0x58
1291
1292 #define FA_RXHP_TH1 5000
1293 #define FA_RXHP_TH2 1500
1294 #define FA_RXHP_TH3 800
1295 #define FA_RXHP_TH4 600
1296 #define FA_RXHP_TH5 500
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310 #define DM_RATR_STA_INIT 0
1311 #define DM_RATR_STA_HIGH 1
1312 #define DM_RATR_STA_MIDDLE 2
1313 #define DM_RATR_STA_LOW 3
1314
1315
1316
1317
1318
1319 typedef enum tag_1R_CCA_Type_Definition {
1320 CCA_1R = 0,
1321 CCA_2R = 1,
1322 CCA_MAX = 2,
1323 } DM_1R_CCA_E;
1324
1325 typedef enum tag_RF_Type_Definition {
1326 RF_Save = 0,
1327 RF_Normal = 1,
1328 RF_MAX = 2,
1329 } DM_RF_E;
1330
1331
1332
1333
1334 typedef enum tag_SW_Antenna_Switch_Definition {
1335 Antenna_A = 1,
1336 Antenna_B = 2,
1337 Antenna_MAX = 3,
1338 } DM_SWAS_E;
1339
1340
1341 #define MAX_ANTENNA_DETECTION_CNT 10
1342
1343
1344
1345
1346 extern u32 OFDMSwingTable[OFDM_TABLE_SIZE];
1347 extern u8 CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8];
1348 extern u8 CCKSwingTable_Ch14[CCK_TABLE_SIZE][8];
1349
1350 extern u32 OFDMSwingTable_New[OFDM_TABLE_SIZE];
1351 extern u8 CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8];
1352 extern u8 CCKSwingTable_Ch14_New[CCK_TABLE_SIZE][8];
1353
1354 extern u32 TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE];
1355
1356
1357
1358
1359 #define IS_STA_VALID(pSta) (pSta)
1360
1361
1362
1363
1364
1365 #define SWAW_STEP_PEAK 0
1366 #define SWAW_STEP_DETERMINE 1
1367
1368
1369
1370 #define dm_CheckTXPowerTracking ODM_TXPowerTrackingCheck
1371 void ODM_TXPowerTrackingCheck(PDM_ODM_T pDM_Odm);
1372
1373 bool ODM_RAStateCheck(
1374 PDM_ODM_T pDM_Odm,
1375 s32 RSSI,
1376 bool bForceUpdate,
1377 u8 *pRATRState
1378 );
1379
1380 #define dm_SWAW_RSSI_Check ODM_SwAntDivChkPerPktRssi
1381 void ODM_SwAntDivChkPerPktRssi(
1382 PDM_ODM_T pDM_Odm,
1383 u8 StationID,
1384 struct odm_phy_info *pPhyInfo
1385 );
1386
1387 u32 ODM_Get_Rate_Bitmap(
1388 PDM_ODM_T pDM_Odm,
1389 u32 macid,
1390 u32 ra_mask,
1391 u8 rssi_level
1392 );
1393
1394 #if (BEAMFORMING_SUPPORT == 1)
1395 BEAMFORMING_CAP Beamforming_GetEntryBeamCapByMacId(PMGNT_INFO pMgntInfo, u8 MacId);
1396 #endif
1397
1398 void odm_TXPowerTrackingInit(PDM_ODM_T pDM_Odm);
1399
1400 void ODM_DMInit(PDM_ODM_T pDM_Odm);
1401
1402 void ODM_DMWatchdog(PDM_ODM_T pDM_Odm);
1403
1404 void ODM_CmnInfoInit(PDM_ODM_T pDM_Odm, ODM_CMNINFO_E CmnInfo, u32 Value);
1405
1406 void ODM_CmnInfoHook(PDM_ODM_T pDM_Odm, ODM_CMNINFO_E CmnInfo, void *pValue);
1407
1408 void ODM_CmnInfoPtrArrayHook(
1409 PDM_ODM_T pDM_Odm,
1410 ODM_CMNINFO_E CmnInfo,
1411 u16 Index,
1412 void *pValue
1413 );
1414
1415 void ODM_CmnInfoUpdate(PDM_ODM_T pDM_Odm, u32 CmnInfo, u64 Value);
1416
1417 void ODM_InitAllTimers(PDM_ODM_T pDM_Odm);
1418
1419 void ODM_CancelAllTimers(PDM_ODM_T pDM_Odm);
1420
1421 void ODM_ReleaseAllTimers(PDM_ODM_T pDM_Odm);
1422
1423 void ODM_AntselStatistics_88C(
1424 PDM_ODM_T pDM_Odm,
1425 u8 MacId,
1426 u32 PWDBAll,
1427 bool isCCKrate
1428 );
1429
1430 void ODM_DynamicARFBSelect(PDM_ODM_T pDM_Odm, u8 rate, bool Collision_State);
1431
1432 #endif