Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
nu11secur1ty
GitHub Repository: nu11secur1ty/Kali-Linux
Path: blob/master/ALFA-W1F1/RTL8814AU/hal/phydm/phydm_antdiv.h
1307 views
1
/******************************************************************************
2
*
3
* Copyright(c) 2007 - 2017 Realtek Corporation.
4
*
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.
8
*
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
12
* more details.
13
*
14
* The full GNU General Public License is included in this distribution in the
15
* file called LICENSE.
16
*
17
* Contact Information:
18
* wlanfae <[email protected]>
19
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
20
* Hsinchu 300, Taiwan.
21
*
22
* Larry Finger <[email protected]>
23
*
24
*****************************************************************************/
25
26
#ifndef __PHYDMANTDIV_H__
27
#define __PHYDMANTDIV_H__
28
29
/*@#define ANTDIV_VERSION "2.0" //2014.11.04*/
30
/*@#define ANTDIV_VERSION "2.1" //2015.01.13 Dino*/
31
/*@#define ANTDIV_VERSION "2.2" 2015.01.16 Dino*/
32
/*@#define ANTDIV_VERSION "3.1" 2015.07.29 YuChen,remove 92c 92d 8723a*/
33
/*@#define ANTDIV_VERSION "3.2" 2015.08.11 Stanley, disable antenna*/
34
/*@diversity when BT is enable for 8723B*/
35
/*@#define ANTDIV_VERSION "3.3" 2015.08.12 Stanley. 8723B does not*/
36
/*@need to check the antenna is control by BT,*/
37
/*@because antenna diversity only works when */
38
/*@BT is disable or radio off*/
39
/*@#define ANTDIV_VERSION "3.4" 2015.08.28 Dino 1.Add 8821A Smart */
40
/*@Antenna 2. Add 8188F SW S0S1 Antenna*/
41
/*@Diversity*/
42
/*@#define ANTDIV_VERSION "3.5" 2015.10.07 Stanley Always check antenna*/
43
/*@detection result from BT-coex. for 8723B,*/
44
/*@not from PHYDM*/
45
/*@#define ANTDIV_VERSION "3.6"*/ /*@2015.11.16 Stanley */
46
/*@#define ANTDIV_VERSION "3.7" 2015.11.20 Dino Add SmartAnt FAT Patch */
47
/*@#define ANTDIV_VERSION "3.8" 2015.12.21 Dino, Add SmartAnt dynamic*/
48
/*@training packet num */
49
/*@#define ANTDIV_VERSION "3.9" 2016.01.05 Dino, Add SmartAnt cmd for*/
50
/*@converting single & two smtant, and add cmd*/
51
/*@for adjust truth table */
52
#define ANTDIV_VERSION "4.0" /*@2017.05.25 Mark, Add SW antenna diversity*/
53
/*@for 8821c because HW transient issue */
54
55
/* @1 ============================================================
56
* 1 Definition
57
* 1 ============================================================
58
*/
59
60
#define ANTDIV_INIT 0xff
61
#define MAIN_ANT 1 /*@ant A or ant Main or S1*/
62
#define AUX_ANT 2 /*@AntB or ant Aux or S0*/
63
#define MAX_ANT 3 /* @3 for AP using*/
64
65
#define ANT1_2G 0
66
/* @= ANT2_5G for 8723D BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */
67
#define ANT2_2G 1
68
/* @= ANT1_5G for 8723D BTG S0 RX S0S1 diversity for 8723D, TX fixed at S1 */
69
/*smart antenna*/
70
#define SUPPORT_RF_PATH_NUM 4
71
#define SUPPORT_BEAM_PATTERN_NUM 4
72
#define NUM_ANTENNA_8821A 2
73
74
#define SUPPORT_BEAM_SET_PATTERN_NUM 16
75
76
#define NO_FIX_TX_ANT 0
77
#define FIX_TX_AT_MAIN 1
78
#define FIX_AUX_AT_MAIN 2
79
80
/* @Antenna Diversty Control type */
81
#define ODM_AUTO_ANT 0
82
#define ODM_FIX_MAIN_ANT 1
83
#define ODM_FIX_AUX_ANT 2
84
85
#define ODM_N_ANTDIV_SUPPORT (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B |\
86
ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A |\
87
ODM_RTL8197F | ODM_RTL8721D)
88
#define ODM_AC_ANTDIV_SUPPORT (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 |\
89
ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)
90
#define ODM_ANTDIV_SUPPORT (ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)
91
#define ODM_SMART_ANT_SUPPORT (ODM_RTL8188E | ODM_RTL8192E)
92
#define ODM_HL_SMART_ANT_TYPE1_SUPPORT (ODM_RTL8821 | ODM_RTL8822B)
93
94
#define ODM_ANTDIV_2G_SUPPORT_IC (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B |\
95
ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D |\
96
ODM_RTL8197F)
97
#define ODM_ANTDIV_5G_SUPPORT_IC (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 |\
98
ODM_RTL8821C | ODM_RTL8822B)
99
100
#define ODM_EVM_ANTDIV_IC (ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8822B)
101
102
#define ODM_ANTDIV_2G BIT(0)
103
#define ODM_ANTDIV_5G BIT(1)
104
105
#define ANTDIV_ON 1
106
#define ANTDIV_OFF 0
107
108
#define ANT_PATH_A 0
109
#define ANT_PATH_B 1
110
#define ANT_PATH_AB 2
111
112
#define FAT_ON 1
113
#define FAT_OFF 0
114
115
#define TX_BY_DESC 1
116
#define TX_BY_REG 0
117
118
#define RSSI_METHOD 0
119
#define EVM_METHOD 1
120
#define CRC32_METHOD 2
121
#define TP_METHOD 3
122
123
#define INIT_ANTDIV_TIMMER 0
124
#define CANCEL_ANTDIV_TIMMER 1
125
#define RELEASE_ANTDIV_TIMMER 2
126
127
#define CRC32_FAIL 1
128
#define CRC32_OK 0
129
130
#define evm_rssi_th_high 25
131
#define evm_rssi_th_low 20
132
133
#define NORMAL_STATE_MIAN 1
134
#define NORMAL_STATE_AUX 2
135
#define TRAINING_STATE 3
136
137
#define FORCE_RSSI_DIFF 10
138
139
#define HT_IDX 16
140
#define VHT_IDX 20
141
142
#define CSI_ON 1
143
#define CSI_OFF 0
144
145
#define DIVON_CSIOFF 1
146
#define DIVOFF_CSION 2
147
148
#define BDC_DIV_TRAIN_STATE 0
149
#define bdc_bfer_train_state 1
150
#define BDC_DECISION_STATE 2
151
#define BDC_BF_HOLD_STATE 3
152
#define BDC_DIV_HOLD_STATE 4
153
154
#define BDC_MODE_1 1
155
#define BDC_MODE_2 2
156
#define BDC_MODE_3 3
157
#define BDC_MODE_4 4
158
#define BDC_MODE_NULL 0xff
159
160
/*SW S0S1 antenna diversity*/
161
#define SWAW_STEP_INIT 0xff
162
#define SWAW_STEP_PEEK 0
163
#define SWAW_STEP_DETERMINE 1
164
165
#define RSSI_CHECK_RESET_PERIOD 10
166
#define RSSI_CHECK_THRESHOLD 50
167
168
/*@Hong Lin Smart antenna*/
169
#define HL_SMTANT_2WIRE_DATA_LEN 24
170
171
#if (RTL8723D_SUPPORT == 1)
172
#ifndef CONFIG_ANTDIV_PERIOD
173
#define CONFIG_ANTDIV_PERIOD 1
174
#endif
175
#endif
176
/* @1 ============================================================
177
* 1 structure
178
* 1 ============================================================
179
*/
180
181
182
struct sw_antenna_switch {
183
u8 double_chk_flag;
184
/*@If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than*/
185
/*@check this antenna again*/
186
u8 try_flag;
187
s32 pre_rssi;
188
u8 cur_antenna;
189
u8 pre_ant;
190
u8 rssi_trying;
191
u8 reset_idx;
192
u8 train_time;
193
u8 train_time_flag;
194
/*@base on RSSI difference between two antennas*/
195
struct phydm_timer_list sw_antdiv_timer;
196
u32 pkt_cnt_sw_ant_div_by_ctrl_frame;
197
boolean is_sw_ant_div_by_ctrl_frame;
198
199
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
200
#if USE_WORKITEM
201
RT_WORK_ITEM phydm_sw_antenna_switch_workitem;
202
#endif
203
#endif
204
205
/* @AntDect (Before link Antenna Switch check) need to be moved*/
206
u16 single_ant_counter;
207
u16 dual_ant_counter;
208
u16 aux_fail_detec_counter;
209
u16 retry_counter;
210
u8 swas_no_link_state;
211
u32 swas_no_link_bk_reg948;
212
boolean ANTA_ON; /*To indicate ant A is or not*/
213
boolean ANTB_ON; /*@To indicate ant B is on or not*/
214
boolean pre_aux_fail_detec;
215
boolean rssi_ant_dect_result;
216
u8 ant_5g;
217
u8 ant_2g;
218
};
219
220
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
221
#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
222
struct _BF_DIV_COEX_ {
223
boolean w_bfer_client[ODM_ASSOCIATE_ENTRY_NUM];
224
boolean w_bfee_client[ODM_ASSOCIATE_ENTRY_NUM];
225
u32 MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
226
u32 MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
227
228
u8 bd_ccoex_type_wbfer;
229
u8 num_txbfee_client;
230
u8 num_txbfer_client;
231
u8 bdc_try_counter;
232
u8 bdc_hold_counter;
233
u8 bdc_mode;
234
u8 bdc_active_mode;
235
u8 BDC_state;
236
u8 bdc_rx_idle_update_counter;
237
u8 num_client;
238
u8 pre_num_client;
239
u8 num_bf_tar;
240
u8 num_div_tar;
241
242
boolean is_all_div_sta_idle;
243
boolean is_all_bf_sta_idle;
244
boolean bdc_try_flag;
245
boolean BF_pass;
246
boolean DIV_pass;
247
};
248
#endif
249
#endif
250
251
struct phydm_fat_struct {
252
u8 bssid[6];
253
u8 antsel_rx_keep_0;
254
u8 antsel_rx_keep_1;
255
u8 antsel_rx_keep_2;
256
u8 antsel_rx_keep_3;
257
u32 ant_sum_rssi[7];
258
u32 ant_rssi_cnt[7];
259
u32 ant_ave_rssi[7];
260
u8 fat_state;
261
u8 fat_state_cnt;
262
u32 train_idx;
263
u8 antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
264
u8 antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
265
u8 antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
266
u16 main_ht_cnt[HT_IDX];
267
u16 aux_ht_cnt[HT_IDX];
268
u16 main_vht_cnt[VHT_IDX];
269
u16 aux_vht_cnt[VHT_IDX];
270
u16 main_sum[ODM_ASSOCIATE_ENTRY_NUM];
271
u16 aux_sum[ODM_ASSOCIATE_ENTRY_NUM];
272
u16 main_cnt[ODM_ASSOCIATE_ENTRY_NUM];
273
u16 aux_cnt[ODM_ASSOCIATE_ENTRY_NUM];
274
u16 main_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
275
u16 aux_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
276
u16 main_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
277
u16 aux_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
278
u8 rx_idle_ant;
279
u8 rx_idle_ant2;
280
u32 rvrt_val; /*all rvrt_val for pause API must set to u32*/
281
u8 ant_div_on_off;
282
u8 div_path_type;
283
boolean is_become_linked;
284
boolean get_stats;
285
u32 min_max_rssi;
286
u8 idx_ant_div_counter_2g;
287
u8 idx_ant_div_counter_5g;
288
u8 ant_div_2g_5g;
289
290
#ifdef ODM_EVM_ENHANCE_ANTDIV
291
/*@For 1SS RX phy rate*/
292
u32 main_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
293
u32 aux_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
294
u32 main_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
295
u32 aux_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
296
297
/*@For 2SS RX phy rate*/
298
u32 main_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];/*@2SS with A1+B*/
299
u32 aux_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];/*@2SS with A2+B*/
300
u32 main_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
301
u32 aux_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
302
303
boolean evm_method_enable;
304
u8 target_ant_evm;
305
u8 target_ant_crc32;
306
u8 target_ant_tp;
307
u8 target_ant_enhance;
308
u8 pre_target_ant_enhance;
309
u16 main_mpdu_ok_cnt;
310
u16 aux_mpdu_ok_cnt;
311
312
u32 crc32_ok_cnt;
313
u32 crc32_fail_cnt;
314
u32 main_crc32_ok_cnt;
315
u32 aux_crc32_ok_cnt;
316
u32 main_crc32_fail_cnt;
317
u32 aux_crc32_fail_cnt;
318
319
u32 main_tp;
320
u32 aux_tp;
321
u32 main_tp_cnt;
322
u32 aux_tp_cnt;
323
324
u8 pre_antdiv_rssi;
325
u8 pre_antdiv_tp;
326
#endif
327
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
328
u32 cck_ctrl_frame_cnt_main;
329
u32 cck_ctrl_frame_cnt_aux;
330
u32 ofdm_ctrl_frame_cnt_main;
331
u32 ofdm_ctrl_frame_cnt_aux;
332
u32 main_ctrl_sum;
333
u32 aux_ctrl_sum;
334
u32 main_ctrl_cnt;
335
u32 aux_ctrl_cnt;
336
#endif
337
u8 b_fix_tx_ant;
338
boolean fix_ant_bfee;
339
boolean enable_ctrl_frame_antdiv;
340
boolean use_ctrl_frame_antdiv;
341
boolean *is_no_csi_feedback;
342
boolean force_antdiv_type;
343
u8 antdiv_type_dbg;
344
u8 hw_antsw_occur;
345
u8 *p_force_tx_by_desc;
346
u8 force_tx_by_desc;
347
/*@A temp value, will hook to driver team's outer parameter later*/
348
u8 *p_default_s0_s1;
349
u8 default_s0_s1;
350
};
351
352
/* @1 ============================================================
353
* 1 enumeration
354
* 1 ============================================================
355
*/
356
357
enum fat_state /*@Fast antenna training*/
358
{
359
FAT_BEFORE_LINK_STATE = 0,
360
FAT_PREPARE_STATE = 1,
361
FAT_TRAINING_STATE = 2,
362
FAT_DECISION_STATE = 3
363
};
364
365
enum ant_div_type {
366
NO_ANTDIV = 0xFF,
367
CG_TRX_HW_ANTDIV = 0x01,
368
CGCS_RX_HW_ANTDIV = 0x02,
369
FIXED_HW_ANTDIV = 0x03,
370
CG_TRX_SMART_ANTDIV = 0x04,
371
CGCS_RX_SW_ANTDIV = 0x05,
372
S0S1_SW_ANTDIV = 0x06, /*@8723B intrnal switch S0 S1*/
373
S0S1_TRX_HW_ANTDIV = 0x07, /*TRX S0S1 diversity for 8723D*/
374
HL_SW_SMART_ANT_TYPE1 = 0x10,
375
/*@Hong-Lin Smart antenna use for 8821AE which is a 2 ant. entitys,*/
376
/*@and each ant. is equipped with 4 antenna patterns*/
377
HL_SW_SMART_ANT_TYPE2 = 0x11
378
/*@Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/
379
};
380
381
/* @1 ============================================================
382
* 1 function prototype
383
* 1 ============================================================
384
*/
385
386
void odm_stop_antenna_switch_dm(void *dm_void);
387
388
void phydm_enable_antenna_diversity(void *dm_void);
389
390
void odm_set_ant_config(void *dm_void, u8 ant_setting /* @0=A, 1=B, 2=C,....*/
391
);
392
393
#define sw_ant_div_rest_after_link odm_sw_ant_div_rest_after_link
394
395
void odm_sw_ant_div_rest_after_link(void *dm_void);
396
397
void odm_ant_div_on_off(void *dm_void, u8 swch, u8 path);
398
399
void odm_tx_by_tx_desc_or_reg(void *dm_void, u8 swch);
400
401
#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
402
403
void phydm_antdiv_reset_statistic(void *dm_void, u32 macid);
404
405
void odm_update_rx_idle_ant(void *dm_void, u8 ant);
406
407
void phydm_update_rx_idle_ant_pathb(void *dm_void, u8 ant);
408
409
void phydm_set_antdiv_val(void *dm_void, u32 *val_buf, u8 val_len);
410
411
#if (RTL8723B_SUPPORT == 1)
412
void odm_update_rx_idle_ant_8723b(void *dm_void, u8 ant, u32 default_ant,
413
u32 optional_ant);
414
#endif
415
416
#if (RTL8188F_SUPPORT == 1)
417
void phydm_update_rx_idle_antenna_8188F(void *dm_void, u32 default_ant);
418
#endif
419
420
#if (RTL8723D_SUPPORT == 1)
421
422
void phydm_set_tx_ant_pwr_8723d(void *dm_void, u8 ant);
423
424
void odm_update_rx_idle_ant_8723d(void *dm_void, u8 ant, u32 default_ant,
425
u32 optional_ant);
426
427
#endif
428
429
#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
430
431
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
432
void odm_sw_antdiv_callback(struct phydm_timer_list *timer);
433
434
void odm_sw_antdiv_workitem_callback(void *context);
435
436
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
437
438
void odm_sw_antdiv_workitem_callback(void *context);
439
440
void odm_sw_antdiv_callback(void *function_context);
441
442
#endif
443
444
void odm_s0s1_sw_ant_div_by_ctrl_frame(void *dm_void, u8 step);
445
446
void odm_antsel_statistics_ctrl(void *dm_void, u8 antsel_tr_mux,
447
u32 rx_pwdb_all);
448
449
void odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(void *dm_void,
450
void *phy_info_void,
451
void *pkt_info_void);
452
453
#endif
454
455
#ifdef ODM_EVM_ENHANCE_ANTDIV
456
void phydm_evm_sw_antdiv_init(void *dm_void);
457
458
void phydm_rx_rate_for_antdiv(void *dm_void, void *pkt_info_void);
459
460
void phydm_antdiv_reset_rx_rate(void *dm_void);
461
462
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
463
void phydm_evm_antdiv_callback(struct phydm_timer_list *timer);
464
465
void phydm_evm_antdiv_workitem_callback(void *context);
466
467
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
468
void phydm_evm_antdiv_callback(void *dm_void);
469
470
void phydm_evm_antdiv_workitem_callback(void *context);
471
472
#else
473
void phydm_evm_antdiv_callback(void *dm_void);
474
#endif
475
476
#endif
477
478
void odm_hw_ant_div(void *dm_void);
479
480
#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\
481
(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
482
void odm_fast_ant_training(
483
void *dm_void);
484
485
void odm_fast_ant_training_callback(void *dm_void);
486
487
void odm_fast_ant_training_work_item_callback(void *dm_void);
488
#endif
489
490
void odm_ant_div_init(void *dm_void);
491
492
void odm_ant_div(void *dm_void);
493
494
void odm_antsel_statistics(void *dm_void, void *phy_info_void,
495
u8 antsel_tr_mux, u32 mac_id, u32 utility, u8 method,
496
u8 is_cck_rate);
497
498
void odm_process_rssi_for_ant_div(void *dm_void, void *phy_info_void,
499
void *pkt_info_void);
500
501
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
502
void odm_set_tx_ant_by_tx_info(void *dm_void, u8 *desc, u8 mac_id);
503
504
#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
505
506
struct tx_desc;
507
/*@declared tx_desc here or compile error happened when enabled 8822B*/
508
509
void odm_set_tx_ant_by_tx_info(struct rtl8192cd_priv *priv,
510
struct tx_desc *pdesc, unsigned short aid);
511
512
#if 1 /*@def def CONFIG_WLAN_HAL*/
513
void odm_set_tx_ant_by_tx_info_hal(struct rtl8192cd_priv *priv,
514
void *pdesc_data, u16 aid);
515
#endif /*@#ifdef CONFIG_WLAN_HAL*/
516
#endif
517
518
void odm_ant_div_config(void *dm_void);
519
520
void odm_ant_div_timers(void *dm_void, u8 state);
521
522
void phydm_antdiv_debug(void *dm_void, char input[][16], u32 *_used,
523
char *output, u32 *_out_len);
524
525
void odm_ant_div_reset(void *dm_void);
526
527
void odm_antenna_diversity_init(void *dm_void);
528
529
void odm_antenna_diversity(void *dm_void);
530
#endif /*@#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY*/
531
#endif /*@#ifndef __ODMANTDIV_H__*/
532
533