hc
2024-05-09 b9d5c334faa47a75f1f28e72d203fc0334e8471d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
/******************************************************************************
 *
 * Copyright(c) 2007 - 2019 Realtek Corporation.
 *
 * 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.
 *
 *****************************************************************************/
/*-------------------------------------------------------------------------------
 
   For type defines and data structure defines
 
--------------------------------------------------------------------------------*/
 
 
#ifndef __DRV_TYPES_H__
#define __DRV_TYPES_H__
 
#include <drv_conf.h>
#include <basic_types.h>
#include <osdep_service.h>
#include <rtw_byteorder.h>
#include <wlan_bssdef.h>
#include <wifi.h>
#include <ieee80211.h>
#ifdef CONFIG_ARP_KEEP_ALIVE
   #include <net/neighbour.h>
   #include <net/arp.h>
#endif
 
#ifdef PLATFORM_OS_XP
   #include <drv_types_xp.h>
#endif
 
#ifdef PLATFORM_OS_CE
   #include <drv_types_ce.h>
#endif
 
#ifdef PLATFORM_LINUX
   #include <drv_types_linux.h>
#endif
 
enum _NIC_VERSION {
 
   RTL8711_NIC,
   RTL8712_NIC,
   RTL8713_NIC,
   RTL8716_NIC
 
};
 
typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;
 
#include <rtw_debug.h>
#include <cmn_info/rtw_sta_info.h>
#include <rtw_rf.h>
#include "../core/rtw_chplan.h"
 
#ifdef CONFIG_80211N_HT
   #include <rtw_ht.h>
#endif
 
#ifdef CONFIG_80211AC_VHT
   #include <rtw_vht.h>
#endif
 
#include <rtw_cmd.h>
#include <cmd_osdep.h>
#include <rtw_security.h>
#include <rtw_xmit.h>
#include <xmit_osdep.h>
#include <rtw_recv.h>
#include <rtw_rm.h>
 
#ifdef CONFIG_BEAMFORMING
   #include <rtw_beamforming.h>
#endif
 
#include <recv_osdep.h>
#include <rtw_efuse.h>
#include <rtw_sreset.h>
#include <hal_intf.h>
#include <hal_com.h>
#include<hal_com_h2c.h>
#include <hal_com_led.h>
#include "../hal/hal_dm.h"
#include <rtw_qos.h>
#include <rtw_pwrctrl.h>
#include <rtw_mlme.h>
#include <mlme_osdep.h>
#include <rtw_io.h>
#include <rtw_ioctl.h>
#include <rtw_ioctl_set.h>
#include <rtw_ioctl_query.h>
#include <osdep_intf.h>
#include <rtw_eeprom.h>
#include <sta_info.h>
#include <rtw_event.h>
#include <rtw_mlme_ext.h>
#include <rtw_mi.h>
#include <rtw_ap.h>
#ifdef CONFIG_RTW_MESH
#include "../core/mesh/rtw_mesh.h"
#endif
#include <rtw_efuse.h>
#include <rtw_version.h>
#include <rtw_odm.h>
 
#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
   #include <rtw_mem.h>
#endif
 
#include <rtw_p2p.h>
 
#ifdef CONFIG_TDLS
   #include <rtw_tdls.h>
#endif /* CONFIG_TDLS */
 
#ifdef CONFIG_WAPI_SUPPORT
   #include <rtw_wapi.h>
#endif /* CONFIG_WAPI_SUPPORT */
 
#ifdef CONFIG_MP_INCLUDED
   #include <rtw_mp.h>
#endif /* CONFIG_MP_INCLUDED */
 
#ifdef CONFIG_BR_EXT
   #include <rtw_br_ext.h>
#endif /* CONFIG_BR_EXT */
 
#ifdef CONFIG_IOL
   #include <rtw_iol.h>
#endif /* CONFIG_IOL */
 
#include <ip.h>
#include <if_ether.h>
#include <ethernet.h>
#include <circ_buf.h>
 
#include <rtw_android.h>
 
#include <rtw_btcoex_wifionly.h>
#include <rtw_btcoex.h>
 
#ifdef CONFIG_MCC_MODE
   #include <rtw_mcc.h>
#endif /*CONFIG_MCC_MODE */
 
#ifdef CONFIG_RTW_REPEATER_SON
   #include <rtw_rson.h>
#endif /*CONFIG_RTW_REPEATER_SON */
 
#define SPEC_DEV_ID_NONE BIT(0)
#define SPEC_DEV_ID_DISABLE_HT BIT(1)
#define SPEC_DEV_ID_ENABLE_PS BIT(2)
#define SPEC_DEV_ID_RF_CONFIG_1T1R BIT(3)
#define SPEC_DEV_ID_RF_CONFIG_2T2R BIT(4)
#define SPEC_DEV_ID_ASSIGN_IFNAME BIT(5)
 
struct specific_device_id {
 
   u32        flags;
 
   u16        idVendor;
   u16        idProduct;
 
};
 
struct registry_priv {
   u8    chip_version;
   u8    rfintfs;
   u8    lbkmode;
   u8    hci;
   NDIS_802_11_SSID    ssid;
   u8    network_mode;    /* infra, ad-hoc, auto */
   u8    channel;/* ad-hoc support requirement */
   u8    wireless_mode;/* A, B, G, auto */
   u8    scan_mode;/* active, passive */
   u8    radio_enable;
   u8    preamble;/* long, short, auto */
   u8    vrtl_carrier_sense;/* Enable, Disable, Auto */
   u8    vcs_type;/* RTS/CTS, CTS-to-self */
   u16    rts_thresh;
   u16  frag_thresh;
   u8    adhoc_tx_pwr;
   u8    soft_ap;
   u8    power_mgnt;
   u8    ips_mode;
   u8    lps_level;
#ifdef CONFIG_LPS_1T1R
   u8    lps_1t1r;
#endif
   u8    lps_chk_by_tp;
#ifdef CONFIG_WOWLAN
   u8    wow_power_mgnt;
   u8    wow_lps_level;
   #ifdef CONFIG_LPS_1T1R
   u8    wow_lps_1t1r;
   #endif
#endif /* CONFIG_WOWLAN */
   u8    smart_ps;
#ifdef CONFIG_WMMPS_STA
   u8    wmm_smart_ps;
#endif /* CONFIG_WMMPS_STA */
   u8   usb_rxagg_mode;
   u8    dynamic_agg_enable;
   u8    long_retry_lmt;
   u8    short_retry_lmt;
   u16    busy_thresh;
   u16    max_bss_cnt;
   u8    ack_policy;
   u8    mp_mode;
#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
   u8 mp_customer_str;
#endif
   u8  mp_dm;
   u8    software_encrypt;
   u8    software_decrypt;
#ifdef CONFIG_TX_EARLY_MODE
   u8   early_mode;
#endif
#ifdef CONFIG_NARROWBAND_SUPPORTING
   u8    rtw_nb_config;
#endif
   u8    acm_method;
   /* WMM */
   u8    wmm_enable;
#ifdef CONFIG_WMMPS_STA
   /* uapsd (unscheduled automatic power-save delivery) = a kind of wmmps */
   u8    uapsd_max_sp_len;
   /* BIT0: AC_VO UAPSD, BIT1: AC_VI UAPSD, BIT2: AC_BK UAPSD, BIT3: AC_BE UAPSD */
   u8    uapsd_ac_enable;
#endif /* CONFIG_WMMPS_STA */
 
   WLAN_BSSID_EX    dev_network;
 
#if CONFIG_TX_AC_LIFETIME
   u8 tx_aclt_flags;
   struct tx_aclt_conf_t tx_aclt_confs[TX_ACLT_CONF_NUM];
#endif
 
   u8 tx_bw_mode;
#ifdef CONFIG_AP_MODE
   u8 bmc_tx_rate;
#endif
#ifdef CONFIG_80211N_HT
   u8    ht_enable;
   /* 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz */
   /* 2.4G use bit 0 ~ 3, 5G use bit 4 ~ 7 */
   /* 0x21 means enable 2.4G 40MHz & 5G 80MHz */
   u8    bw_mode;
   u8    ampdu_enable;/* for tx */
   u8    rx_stbc;
   u8    rx_ampdu_amsdu;/* Rx A-MPDU Supports A-MSDU is permitted */
   u8    tx_ampdu_amsdu;/* Tx A-MPDU Supports A-MSDU is permitted */
   u8 rx_ampdu_sz_limit_by_nss_bw[4][4]; /* 1~4SS, BW20~BW160 */
   /* Short GI support Bit Map */
   /* BIT0 - 20MHz, 1: support, 0: non-support */
   /* BIT1 - 40MHz, 1: support, 0: non-support */
   /* BIT2 - 80MHz, 1: support, 0: non-support */
   /* BIT3 - 160MHz, 1: support, 0: non-support */
   u8    short_gi;
   /* BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx */
   u8    ldpc_cap;
   /* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
   u8    stbc_cap;
   #if defined(CONFIG_RTW_TX_NPATH_EN)
   u8    tx_npath;
   #endif
   #if defined(CONFIG_RTW_PATH_DIV)
   u8 path_div;
   #endif
   /*
    * BIT0: Enable VHT SU Beamformer
    * BIT1: Enable VHT SU Beamformee
    * BIT2: Enable VHT MU Beamformer, depend on VHT SU Beamformer
    * BIT3: Enable VHT MU Beamformee, depend on VHT SU Beamformee
    * BIT4: Enable HT Beamformer
    * BIT5: Enable HT Beamformee
    */
   u8    beamform_cap;
   u8    beamformer_rf_num;
   u8    beamformee_rf_num;
#endif /* CONFIG_80211N_HT */
 
#ifdef CONFIG_80211AC_VHT
   u8    vht_enable; /* 0:disable, 1:enable, 2:auto */
   u8    ampdu_factor;
   u8 vht_rx_mcs_map[2];
#endif /* CONFIG_80211AC_VHT */
 
   u8    lowrate_two_xmit;
 
   u8    low_power ;
 
   u8    wifi_spec;/* !turbo_mode */
 
   u8 rf_path; /*rf_config*/
   u8 tx_nss;
   u8 rx_nss;
 
   char alpha2[2];
   u8    channel_plan;
   u8    excl_chs[MAX_CHANNEL_NUM];
   u8    full_ch_in_p2p_handshake; /* 0: reply only softap channel, 1: reply full channel list*/
 
#ifdef CONFIG_BT_COEXIST
   u8    btcoex;
   u8    bt_iso;
   u8    bt_sco;
   u8    bt_ampdu;
   u8    ant_num;
   u8    single_ant_path;
#endif
   BOOLEAN    bAcceptAddbaReq;
 
   u8    antdiv_cfg;
   u8    antdiv_type;
   u8    drv_ant_band_switch;
 
   u8    switch_usb_mode;
 
   u8    usbss_enable;/* 0:disable,1:enable */
   u8    hwpdn_mode;/* 0:disable,1:enable,2:decide by EFUSE config */
   u8    hwpwrp_detect;/* 0:disable,1:enable */
 
   u8    hw_wps_pbc;/* 0:disable,1:enable */
 
#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
   char    adaptor_info_caching_file_path[PATH_LENGTH_MAX];
#endif
 
#ifdef CONFIG_LAYER2_ROAMING
   u8    max_roaming_times; /* the max number driver will try to roaming */
#endif
 
#ifdef CONFIG_IOL
   u8 fw_iol; /* enable iol without other concern */
#endif
 
#ifdef CONFIG_80211D
   u8 enable80211d;
#endif
 
   u8 ifname[16];
   u8 if2name[16];
 
   u8 notch_filter;
 
   /* for pll reference clock selction */
   u8 pll_ref_clk_sel;
 
   /* define for tx power adjust */
#if CONFIG_TXPWR_LIMIT
   u8    RegEnableTxPowerLimit;
#endif
   u8    RegEnableTxPowerByRate;
 
   u8 target_tx_pwr_valid;
   s8 target_tx_pwr_2g[RF_PATH_MAX][RATE_SECTION_NUM];
#if CONFIG_IEEE80211_BAND_5GHZ
   s8 target_tx_pwr_5g[RF_PATH_MAX][RATE_SECTION_NUM - 1];
#endif
 
   u8 tsf_update_pause_factor;
   u8 tsf_update_restore_factor;
 
   s8    TxBBSwing_2G;
   s8    TxBBSwing_5G;
   u8    AmplifierType_2G;
   u8    AmplifierType_5G;
   u8    bEn_RFE;
   u8    RFE_Type;
   u8    PowerTracking_Type;
   u8    GLNA_Type;
   u8  check_fw_ps;
   u8    RegPwrTrimEnable;
 
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
   u8    load_phy_file;
   u8    RegDecryptCustomFile;
#endif
#ifdef CONFIG_CONCURRENT_MODE
   u8 virtual_iface_num;
#ifdef CONFIG_P2P
   u8 sel_p2p_iface;
#endif
#endif
   u8 qos_opt_enable;
 
   u8 hiq_filter;
   u8 adaptivity_en;
   u8 adaptivity_mode;
   s8 adaptivity_th_l2h_ini;
   s8 adaptivity_th_edcca_hl_diff;
 
   u8 boffefusemask;
   BOOLEAN bFileMaskEfuse;
   BOOLEAN bBTFileMaskEfuse;
#ifdef CONFIG_RTW_ACS
   u8 acs_auto_scan;
   u8 acs_mode;
#endif
 
#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
   u8 nm_mode;
#endif
   u32    reg_rxgain_offset_2g;
   u32    reg_rxgain_offset_5gl;
   u32    reg_rxgain_offset_5gm;
   u32    reg_rxgain_offset_5gh;
 
#ifdef CONFIG_DFS_MASTER
   u8 dfs_region_domain;
#endif
 
#ifdef CONFIG_MCC_MODE
   u8 en_mcc;
   u32 rtw_mcc_single_tx_cri;
   u32 rtw_mcc_ap_bw20_target_tx_tp;
   u32 rtw_mcc_ap_bw40_target_tx_tp;
   u32 rtw_mcc_ap_bw80_target_tx_tp;
   u32 rtw_mcc_sta_bw20_target_tx_tp;
   u32 rtw_mcc_sta_bw40_target_tx_tp;
   u32 rtw_mcc_sta_bw80_target_tx_tp;
   s8 rtw_mcc_policy_table_idx;
   u8 rtw_mcc_duration;
   u8 rtw_mcc_enable_runtime_duration;
   u8 rtw_mcc_phydm_offload;
#endif /* CONFIG_MCC_MODE */
 
#ifdef CONFIG_RTW_NAPI
   u8 en_napi;
#ifdef CONFIG_RTW_NAPI_DYNAMIC
   u32 napi_threshold;    /* unit: Mbps */
#endif /* CONFIG_RTW_NAPI_DYNAMIC */
#ifdef CONFIG_RTW_GRO
   u8 en_gro;
#endif /* CONFIG_RTW_GRO */
#endif /* CONFIG_RTW_NAPI */
 
#ifdef CONFIG_WOWLAN
   u8 wakeup_event;
   u8 suspend_type;
#endif
 
#ifdef CONFIG_SUPPORT_TRX_SHARED
   u8 trx_share_mode;
#endif
   u8 check_hw_status;
   u8 wowlan_sta_mix_mode;
 
#ifdef CONFIG_PCI_HCI
   u32 pci_aspm_config;
   u32 pci_dynamic_aspm_linkctrl;
#endif
 
   u8 iqk_fw_offload;
   u8 ch_switch_offload;
 
#ifdef CONFIG_TDLS
   u8 en_tdls;
#endif
 
#ifdef CONFIG_ADVANCE_OTA
   u8    adv_ota;
#endif
 
#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
   u8 fw_param_init;
#endif
#ifdef CONFIG_DYNAMIC_SOML
   u8 dyn_soml_en;
   u8 dyn_soml_train_num;
   u8 dyn_soml_interval;
   u8 dyn_soml_period;
   u8 dyn_soml_delay;
#endif
#ifdef CONFIG_FW_HANDLE_TXBCN
   u8 fw_tbtt_rpt;
#endif
 
#ifdef DBG_LA_MODE
   u8 la_mode_en;
#endif
   u32 phydm_ability;
   u32 halrf_ability;
#ifdef CONFIG_TDMADIG
   u8 tdmadig_en;
   u8 tdmadig_mode;
   u8 tdmadig_dynamic;
#endif/*CONFIG_TDMADIG*/
#ifdef CONFIG_RTW_MESH
   u8 peer_alive_based_preq;
#endif
 
   /*
    * vht_2g4: use VHT rate on 2.4G or not
    * 0: deny
    * 1: allow
    */
   u8 vht_2g4;
};
 
/* For registry parameters */
#define RGTRY_OFT(field) ((u32)FIELD_OFFSET(struct registry_priv, field))
#define RGTRY_SZ(field)   sizeof(((struct registry_priv *) 0)->field)
 
#define GetRegAmplifierType2G(_Adapter)    (_Adapter->registrypriv.AmplifierType_2G)
#define GetRegAmplifierType5G(_Adapter)    (_Adapter->registrypriv.AmplifierType_5G)
 
#define GetRegTxBBSwing_2G(_Adapter)    (_Adapter->registrypriv.TxBBSwing_2G)
#define GetRegTxBBSwing_5G(_Adapter)    (_Adapter->registrypriv.TxBBSwing_5G)
 
#define GetRegbENRFEType(_Adapter)    (_Adapter->registrypriv.bEn_RFE)
#define GetRegRFEType(_Adapter)    (_Adapter->registrypriv.RFE_Type)
#define GetRegGLNAType(_Adapter)    (_Adapter->registrypriv.GLNA_Type)
#define GetRegPowerTrackingType(_Adapter)    (_Adapter->registrypriv.PowerTracking_Type)
 
#define WOWLAN_IS_STA_MIX_MODE(_Adapter)    (_Adapter->registrypriv.wowlan_sta_mix_mode)
#define BSSID_OFT(field) ((u32)FIELD_OFFSET(WLAN_BSSID_EX, field))
#define BSSID_SZ(field)   sizeof(((PWLAN_BSSID_EX) 0)->field)
 
#define BW_MODE_2G(bw_mode) ((bw_mode) & 0x0F)
#define BW_MODE_5G(bw_mode) ((bw_mode) >> 4)
#ifdef CONFIG_80211N_HT
#define REGSTY_BW_2G(regsty) BW_MODE_2G((regsty)->bw_mode)
#define REGSTY_BW_5G(regsty) BW_MODE_5G((regsty)->bw_mode)
#else
#define REGSTY_BW_2G(regsty) CHANNEL_WIDTH_20
#define REGSTY_BW_5G(regsty) CHANNEL_WIDTH_20
#endif
#define REGSTY_IS_BW_2G_SUPPORT(regsty, bw) (REGSTY_BW_2G((regsty)) >= (bw))
#define REGSTY_IS_BW_5G_SUPPORT(regsty, bw) (REGSTY_BW_5G((regsty)) >= (bw))
 
#define REGSTY_IS_11AC_ENABLE(regsty) ((regsty)->vht_enable != 0)
#define REGSTY_IS_11AC_AUTO(regsty) ((regsty)->vht_enable == 2)
 
#define rtw_is_vht_2g4(adapter)        ((adapter)->registrypriv.vht_2g4 != 0)
#define rtw_set_vht_2g4(adapter, enable) \
           ((adapter)->registrypriv.vht_2g4 = (enable ? 1 : 0))
 
typedef struct rtw_if_operations {
   int __must_check (*read)(struct dvobj_priv *d, unsigned int addr, void *buf,
               size_t len, bool fixed);
   int __must_check (*write)(struct dvobj_priv *d, unsigned int addr, void *buf,
                size_t len, bool fixed);
} RTW_IF_OPS, *PRTW_IF_OPS;
 
#ifdef CONFIG_SDIO_HCI
   #include <drv_types_sdio.h>
   #define INTF_DATA    SDIO_DATA
   #define INTF_OPS    PRTW_IF_OPS
#elif defined(CONFIG_GSPI_HCI)
   #include <drv_types_gspi.h>
   #define INTF_DATA GSPI_DATA
#elif defined(CONFIG_PCI_HCI)
   #include <drv_types_pci.h>
#endif
 
#define get_hw_port(adapter) (adapter->hw_port)
 
#ifdef CONFIG_CONCURRENT_MODE
   #define is_primary_adapter(adapter) (adapter->adapter_type == PRIMARY_ADAPTER)
   #define is_vir_adapter(adapter) (adapter->adapter_type == VIRTUAL_ADAPTER)
#else
   #define is_primary_adapter(adapter) (1)
   #define is_vir_adapter(adapter) (0)
#endif
#define GET_PRIMARY_ADAPTER(padapter) (((_adapter *)padapter)->dvobj->padapters[IFACE_ID0])
#define GET_IFACE_NUMS(padapter) (((_adapter *)padapter)->dvobj->iface_nums)
#define GET_ADAPTER(padapter, iface_id) (((_adapter *)padapter)->dvobj->padapters[iface_id])
 
#define GetDefaultAdapter(padapter)    padapter
 
enum _IFACE_ID {
   IFACE_ID0, /*PRIMARY_ADAPTER*/
   IFACE_ID1,
   IFACE_ID2,
   IFACE_ID3,
   IFACE_ID4,
   IFACE_ID5,
   IFACE_ID6,
   IFACE_ID7,
   IFACE_ID_MAX,
};
 
#define VIF_START_ID    1
 
#ifdef CONFIG_DBG_COUNTER
 
struct rx_logs {
   u32 intf_rx;
   u32 intf_rx_err_recvframe;
   u32 intf_rx_err_skb;
   u32 intf_rx_report;
   u32 core_rx;
   u32 core_rx_pre;
   u32 core_rx_pre_ver_err;
   u32 core_rx_pre_mgmt;
   u32 core_rx_pre_mgmt_err_80211w;
   u32 core_rx_pre_mgmt_err;
   u32 core_rx_pre_ctrl;
   u32 core_rx_pre_ctrl_err;
   u32 core_rx_pre_data;
   u32 core_rx_pre_data_wapi_seq_err;
   u32 core_rx_pre_data_wapi_key_err;
   u32 core_rx_pre_data_handled;
   u32 core_rx_pre_data_err;
   u32 core_rx_pre_data_unknown;
   u32 core_rx_pre_unknown;
   u32 core_rx_enqueue;
   u32 core_rx_dequeue;
   u32 core_rx_post;
   u32 core_rx_post_decrypt;
   u32 core_rx_post_decrypt_wep;
   u32 core_rx_post_decrypt_tkip;
   u32 core_rx_post_decrypt_aes;
   u32 core_rx_post_decrypt_wapi;
   u32 core_rx_post_decrypt_hw;
   u32 core_rx_post_decrypt_unknown;
   u32 core_rx_post_decrypt_err;
   u32 core_rx_post_defrag_err;
   u32 core_rx_post_portctrl_err;
   u32 core_rx_post_indicate;
   u32 core_rx_post_indicate_in_oder;
   u32 core_rx_post_indicate_reoder;
   u32 core_rx_post_indicate_err;
   u32 os_indicate;
   u32 os_indicate_ap_mcast;
   u32 os_indicate_ap_forward;
   u32 os_indicate_ap_self;
   u32 os_indicate_err;
   u32 os_netif_ok;
   u32 os_netif_err;
};
 
struct tx_logs {
   u32 os_tx;
   u32 os_tx_err_up;
   u32 os_tx_err_xmit;
   u32 os_tx_m2u;
   u32 os_tx_m2u_ignore_fw_linked;
   u32 os_tx_m2u_ignore_self;
   u32 os_tx_m2u_entry;
   u32 os_tx_m2u_entry_err_xmit;
   u32 os_tx_m2u_entry_err_skb;
   u32 os_tx_m2u_stop;
   u32 core_tx;
   u32 core_tx_err_pxmitframe;
   u32 core_tx_err_brtx;
   u32 core_tx_upd_attrib;
   u32 core_tx_upd_attrib_adhoc;
   u32 core_tx_upd_attrib_sta;
   u32 core_tx_upd_attrib_ap;
   u32 core_tx_upd_attrib_unknown;
   u32 core_tx_upd_attrib_dhcp;
   u32 core_tx_upd_attrib_icmp;
   u32 core_tx_upd_attrib_active;
   u32 core_tx_upd_attrib_err_ucast_sta;
   u32 core_tx_upd_attrib_err_ucast_ap_link;
   u32 core_tx_upd_attrib_err_sta;
   u32 core_tx_upd_attrib_err_link;
   u32 core_tx_upd_attrib_err_sec;
   u32 core_tx_ap_enqueue_warn_fwstate;
   u32 core_tx_ap_enqueue_warn_sta;
   u32 core_tx_ap_enqueue_warn_nosta;
   u32 core_tx_ap_enqueue_warn_link;
   u32 core_tx_ap_enqueue_warn_trigger;
   u32 core_tx_ap_enqueue_mcast;
   u32 core_tx_ap_enqueue_ucast;
   u32 core_tx_ap_enqueue;
   u32 intf_tx;
   u32 intf_tx_pending_ac;
   u32 intf_tx_pending_fw_under_survey;
   u32 intf_tx_pending_fw_under_linking;
   u32 intf_tx_pending_xmitbuf;
   u32 intf_tx_enqueue;
   u32 core_tx_enqueue;
   u32 core_tx_enqueue_class;
   u32 core_tx_enqueue_class_err_sta;
   u32 core_tx_enqueue_class_err_nosta;
   u32 core_tx_enqueue_class_err_fwlink;
   u32 intf_tx_direct;
   u32 intf_tx_direct_err_coalesce;
   u32 intf_tx_dequeue;
   u32 intf_tx_dequeue_err_coalesce;
   u32 intf_tx_dump_xframe;
   u32 intf_tx_dump_xframe_err_txdesc;
   u32 intf_tx_dump_xframe_err_port;
};
 
struct int_logs {
   u32 all;
   u32 err;
   u32 tbdok;
   u32 tbder;
   u32 bcnderr;
   u32 bcndma;
   u32 bcndma_e;
   u32 rx;
   u32 rx_rdu;
   u32 rx_fovw;
   u32 txfovw;
   u32 mgntok;
   u32 highdok;
   u32 bkdok;
   u32 bedok;
   u32 vidok;
   u32 vodok;
};
 
#endif /* CONFIG_DBG_COUNTER */
 
struct debug_priv {
   u32 dbg_sdio_free_irq_error_cnt;
   u32 dbg_sdio_alloc_irq_error_cnt;
   u32 dbg_sdio_free_irq_cnt;
   u32 dbg_sdio_alloc_irq_cnt;
   u32 dbg_sdio_deinit_error_cnt;
   u32 dbg_sdio_init_error_cnt;
   u32 dbg_suspend_error_cnt;
   u32 dbg_suspend_cnt;
   u32 dbg_resume_cnt;
   u32 dbg_resume_error_cnt;
   u32 dbg_deinit_fail_cnt;
   u32 dbg_carddisable_cnt;
   u32 dbg_carddisable_error_cnt;
   u32 dbg_ps_insuspend_cnt;
   u32    dbg_dev_unload_inIPS_cnt;
   u32 dbg_wow_leave_ps_fail_cnt;
   u32 dbg_scan_pwr_state_cnt;
   u32 dbg_downloadfw_pwr_state_cnt;
   u32 dbg_fw_read_ps_state_fail_cnt;
   u32 dbg_leave_ips_fail_cnt;
   u32 dbg_leave_lps_fail_cnt;
   u32 dbg_h2c_leave32k_fail_cnt;
   u32 dbg_diswow_dload_fw_fail_cnt;
   u32 dbg_enwow_dload_fw_fail_cnt;
   u32 dbg_ips_drvopen_fail_cnt;
   u32 dbg_poll_fail_cnt;
   u32 dbg_rpwm_toogle_cnt;
   u32 dbg_rpwm_timeout_fail_cnt;
   u32 dbg_sreset_cnt;
   u32 dbg_fw_mem_dl_error_cnt;
   u64 dbg_rx_fifo_last_overflow;
   u64 dbg_rx_fifo_curr_overflow;
   u64 dbg_rx_fifo_diff_overflow;
};
 
struct rtw_traffic_statistics {
   /* tx statistics */
   u64    tx_bytes;
   u64    tx_pkts;
   u64    tx_drop;
   u64    cur_tx_bytes;
   u64    last_tx_bytes;
   u32    cur_tx_tp; /* Tx throughput in Mbps. */
 
   /* rx statistics */
   u64    rx_bytes;
   u64    rx_pkts;
   u64    rx_drop;
   u64    cur_rx_bytes;
   u64    last_rx_bytes;
   u32    cur_rx_tp; /* Rx throughput in Mbps. */
};
 
#define SEC_CAP_CHK_BMC    BIT0
 
#define SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH    BIT0
 
struct sec_cam_bmp {
   u32 m0;
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
   u32 m1;
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
   u32 m2;
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
   u32 m3;
#endif
};
 
struct cam_ctl_t {
   _lock lock;
 
   u8 sec_cap;
   u32 flags;
 
   u8 num;
   struct sec_cam_bmp used;
 
   _mutex sec_cam_access_mutex;
};
 
struct sec_cam_ent {
   u16 ctrl;
   u8 mac[ETH_ALEN];
   u8 key[16];
};
 
#define KEY_FMT "%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
#define KEY_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
   ((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9], ((u8 *)(x))[10], ((u8 *)(x))[11], \
   ((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15]
 
#define RTW_DEFAULT_MGMT_MACID 1
 
struct macid_bmp {
   u32 m0;
#if (MACID_NUM_SW_LIMIT > 32)
   u32 m1;
#endif
#if (MACID_NUM_SW_LIMIT > 64)
   u32 m2;
#endif
#if (MACID_NUM_SW_LIMIT > 96)
   u32 m3;
#endif
};
 
#ifdef CONFIG_CLIENT_PORT_CFG
struct clt_port_t{
   _lock lock;
   u8 bmp;
   s8 num;
};
#define get_clt_num(adapter) (adapter_to_dvobj(adapter)->clt_port.num)
#endif
 
struct macid_ctl_t {
   _lock lock;
   u8 num;
   struct macid_bmp used;
   struct macid_bmp bmc;
   struct macid_bmp if_g[CONFIG_IFACE_NUMBER];
   struct macid_bmp ch_g[2]; /* 2 ch concurrency */
 
   u8 iface_bmc[CONFIG_IFACE_NUMBER]; /* bmc TX macid for each iface*/
 
   u8 h2c_msr[MACID_NUM_SW_LIMIT];
   u8 bw[MACID_NUM_SW_LIMIT];
   u8 vht_en[MACID_NUM_SW_LIMIT];
   u32 rate_bmp0[MACID_NUM_SW_LIMIT];
   u32 rate_bmp1[MACID_NUM_SW_LIMIT];
   u8 op_num[H2C_MSR_ROLE_MAX]; /* number of macid having h2c_msr's OPMODE = 1 for specific ROLE */
 
   struct sta_info *sta[MACID_NUM_SW_LIMIT]; /* corresponding stainfo when macid is not shared */
 
   /* macid sleep registers */
#ifdef CONFIG_PROTSEL_MACSLEEP
   u16 reg_sleep_ctrl;
   u16 reg_sleep_info;
#else
   u16 reg_sleep_m0;
#if (MACID_NUM_SW_LIMIT > 32)
   u16 reg_sleep_m1;
#endif
#if (MACID_NUM_SW_LIMIT > 64)
   u16 reg_sleep_m2;
#endif
#if (MACID_NUM_SW_LIMIT > 96)
   u16 reg_sleep_m3;
#endif
#endif
};
 
/* used for rf_ctl_t.rate_bmp_cck_ofdm */
#define RATE_BMP_CCK        0x000F
#define RATE_BMP_OFDM        0xFFF0
#define RATE_BMP_HAS_CCK(_bmp_cck_ofdm)        (_bmp_cck_ofdm & RATE_BMP_CCK)
#define RATE_BMP_HAS_OFDM(_bmp_cck_ofdm)    (_bmp_cck_ofdm & RATE_BMP_OFDM)
#define RATE_BMP_GET_CCK(_bmp_cck_ofdm)        (_bmp_cck_ofdm & RATE_BMP_CCK)
#define RATE_BMP_GET_OFDM(_bmp_cck_ofdm)    ((_bmp_cck_ofdm & RATE_BMP_OFDM) >> 4)
 
/* used for rf_ctl_t.rate_bmp_ht_by_bw */
#define RATE_BMP_HT_1SS        0x000000FF
#define RATE_BMP_HT_2SS        0x0000FF00
#define RATE_BMP_HT_3SS        0x00FF0000
#define RATE_BMP_HT_4SS        0xFF000000
#define RATE_BMP_HAS_HT_1SS(_bmp_ht)        (_bmp_ht & RATE_BMP_HT_1SS)
#define RATE_BMP_HAS_HT_2SS(_bmp_ht)        (_bmp_ht & RATE_BMP_HT_2SS)
#define RATE_BMP_HAS_HT_3SS(_bmp_ht)        (_bmp_ht & RATE_BMP_HT_3SS)
#define RATE_BMP_HAS_HT_4SS(_bmp_ht)        (_bmp_ht & RATE_BMP_HT_4SS)
#define RATE_BMP_GET_HT_1SS(_bmp_ht)        (_bmp_ht & RATE_BMP_HT_1SS)
#define RATE_BMP_GET_HT_2SS(_bmp_ht)        ((_bmp_ht & RATE_BMP_HT_2SS) >> 8)
#define RATE_BMP_GET_HT_3SS(_bmp_ht)        ((_bmp_ht & RATE_BMP_HT_3SS) >> 16)
#define RATE_BMP_GET_HT_4SS(_bmp_ht)        ((_bmp_ht & RATE_BMP_HT_4SS) >> 24)
 
/* used for rf_ctl_t.rate_bmp_vht_by_bw */
#define RATE_BMP_VHT_1SS    0x00000003FF
#define RATE_BMP_VHT_2SS    0x00000FFC00
#define RATE_BMP_VHT_3SS    0x003FF00000
#define RATE_BMP_VHT_4SS    0xFFC0000000
#define RATE_BMP_HAS_VHT_1SS(_bmp_vht)        (_bmp_vht & RATE_BMP_VHT_1SS)
#define RATE_BMP_HAS_VHT_2SS(_bmp_vht)        (_bmp_vht & RATE_BMP_VHT_2SS)
#define RATE_BMP_HAS_VHT_3SS(_bmp_vht)        (_bmp_vht & RATE_BMP_VHT_3SS)
#define RATE_BMP_HAS_VHT_4SS(_bmp_vht)        (_bmp_vht & RATE_BMP_VHT_4SS)
#define RATE_BMP_GET_VHT_1SS(_bmp_vht)        ((u16)(_bmp_vht & RATE_BMP_VHT_1SS))
#define RATE_BMP_GET_VHT_2SS(_bmp_vht)        ((u16)((_bmp_vht & RATE_BMP_VHT_2SS) >> 10))
#define RATE_BMP_GET_VHT_3SS(_bmp_vht)        ((u16)((_bmp_vht & RATE_BMP_VHT_3SS) >> 20))
#define RATE_BMP_GET_VHT_4SS(_bmp_vht)        ((u16)((_bmp_vht & RATE_BMP_VHT_4SS) >> 30))
 
#define TXPWR_LMT_REF_VHT_FROM_HT    BIT0
#define TXPWR_LMT_REF_HT_FROM_VHT    BIT1
 
#define TXPWR_LMT_HAS_CCK_1T    BIT0
#define TXPWR_LMT_HAS_CCK_2T    BIT1
#define TXPWR_LMT_HAS_CCK_3T    BIT2
#define TXPWR_LMT_HAS_CCK_4T    BIT3
#define TXPWR_LMT_HAS_OFDM_1T    BIT4
#define TXPWR_LMT_HAS_OFDM_2T    BIT5
#define TXPWR_LMT_HAS_OFDM_3T    BIT6
#define TXPWR_LMT_HAS_OFDM_4T    BIT7
 
#define OFFCHS_NONE            0
#define OFFCHS_LEAVING_OP    1
#define OFFCHS_LEAVE_OP        2
#define OFFCHS_BACKING_OP    3
 
struct rf_ctl_t {
   const struct country_chplan *country_ent;
   u8 ChannelPlan;
   u8 max_chan_nums;
   RT_CHANNEL_INFO channel_set[MAX_CHANNEL_NUM];
   struct p2p_channels channel_list;
 
   _mutex offch_mutex;
   u8 offch_state;
 
   /* used for debug or by tx power limit */
   u16 rate_bmp_cck_ofdm;        /* 20MHz */
   u32 rate_bmp_ht_by_bw[2];    /* 20MHz, 40MHz. 4SS supported */
   u64 rate_bmp_vht_by_bw[4];    /* 20MHz, 40MHz, 80MHz, 160MHz. 4SS supported */
 
#if CONFIG_TXPWR_LIMIT
   u8 highest_ht_rate_bw_bmp;
   u8 highest_vht_rate_bw_bmp;
 
   _mutex txpwr_lmt_mutex;
   _list reg_exc_list;
   u8 regd_exc_num;
   _list txpwr_lmt_list;
   u8 txpwr_regd_num;
   const char *regd_name;
 
   u8 txpwr_lmt_2g_cck_ofdm_state;
   #if CONFIG_IEEE80211_BAND_5GHZ
   u8 txpwr_lmt_5g_cck_ofdm_state;
   u8 txpwr_lmt_5g_20_40_ref;
   #endif
#endif
 
   bool ch_sel_within_same_band;
 
#if CONFIG_DFS
   u8 csa_ch;
 
#ifdef CONFIG_DFS_MASTER
   u8 dfs_region_domain;
   _timer radar_detect_timer;
   bool radar_detect_by_others;
   u8 radar_detect_enabled;
   bool radar_detected;
 
   u8 radar_detect_ch;
   u8 radar_detect_bw;
   u8 radar_detect_offset;
 
   systime cac_start_time;
   systime cac_end_time;
   u8 cac_force_stop;
 
#if CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
   u8 dfs_slave_with_rd;
#endif
   u8 dfs_ch_sel_d_flags;
 
   u8 dbg_dfs_fake_radar_detect_cnt;
   u8 dbg_dfs_radar_detect_trigger_non;
   u8 dbg_dfs_choose_dfs_ch_first;
#endif /* CONFIG_DFS_MASTER */
#endif /* CONFIG_DFS */
};
 
#define RTW_CAC_STOPPED 0
#ifdef CONFIG_DFS_MASTER
#define IS_CAC_STOPPED(rfctl) ((rfctl)->cac_end_time == RTW_CAC_STOPPED)
#define IS_CH_WAITING(rfctl) (!IS_CAC_STOPPED(rfctl) && rtw_time_after((rfctl)->cac_end_time, rtw_get_current_time()))
#define IS_UNDER_CAC(rfctl) (IS_CH_WAITING(rfctl) && rtw_time_after(rtw_get_current_time(), (rfctl)->cac_start_time))
#define IS_RADAR_DETECTED(rfctl) ((rfctl)->radar_detected)
#else
#define IS_CAC_STOPPED(rfctl) 1
#define IS_CH_WAITING(rfctl) 0
#define IS_UNDER_CAC(rfctl) 0
#define IS_RADAR_DETECTED(rfctl) 0
#endif /* CONFIG_DFS_MASTER */
 
#if CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
#define IS_DFS_SLAVE_WITH_RD(rfctl) ((rfctl)->dfs_slave_with_rd)
#else
#define IS_DFS_SLAVE_WITH_RD(rfctl) 0
#endif
 
#ifdef CONFIG_MBSSID_CAM
#define TOTAL_MBID_CAM_NUM    8
#define INVALID_CAM_ID            0xFF
struct mbid_cam_ctl_t {
   _lock lock;
   u8 bitmap;
   ATOMIC_T mbid_entry_num;
};
struct mbid_cam_cache {
   u8 iface_id;
   /*u8 role;*/ /*WIFI_STATION_STATE or WIFI_AP_STATE*/
   u8 mac_addr[ETH_ALEN];
};
#endif /*CONFIG_MBSSID_CAM*/
 
#ifdef RTW_HALMAC
struct halmac_indicator {
   struct submit_ctx *sctx;
   u8 *buffer;
   u32 buf_size;
   u32 ret_size;
   u32 status;
};
 
struct halmacpriv {
   /* flags */
 
   /* For asynchronous functions */
   struct halmac_indicator *indicator;
 
   /* Hardware parameters */
#ifdef CONFIG_SDIO_HCI
   /* Store hardware tx queue page number setting */
   u16 txpage[HW_QUEUE_ENTRY];
#endif /* CONFIG_SDIO_HCI */
};
#endif /* RTW_HALMAC */
 
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
/*info for H2C-0x2C*/
struct dft_info {
   u8 port_id;
   u8 mac_id;
};
#endif
 
#ifdef CONFIG_HW_P0_TSF_SYNC
struct tsf_info {
   u8 sync_port;/*port_x's tsf sync to port_0*/
   u8 offset; /*tsf timer offset*/
};
#endif
 
struct protsel {
   _mutex mutex;        /* protect this structure */
   ATOMIC_T refcnt;    /* reference count */
   u32 sel;        /* save the last sel port */
};
 
#ifdef CONFIG_RTL8814B
#define MAX_BULKOUT_NUM 7
#ifdef CONFIG_USB_HCI
#define MAX_ENDPOINT_NUM 8
#endif
#else
#define MAX_BULKOUT_NUM 4
#ifdef CONFIG_USB_HCI
#define MAX_ENDPOINT_NUM 6
#endif
#endif
 
struct dvobj_priv {
   /*-------- below is common data --------*/
   u8    chip_type;
   u8    HardwareType;
   u8    interface_type;/*USB,SDIO,SPI,PCI*/
 
   ATOMIC_T    bSurpriseRemoved;
   ATOMIC_T    bDriverStopped;
 
   s32    processing_dev_remove;
 
   struct debug_priv drv_dbg;
 
   _mutex hw_init_mutex;
   _mutex h2c_fwcmd_mutex;
 
   _mutex ioctrl_mutex;
 
#ifdef CONFIG_RTW_CUSTOMER_STR
   _mutex customer_str_mutex;
   struct submit_ctx *customer_str_sctx;
   u8 customer_str[RTW_CUSTOMER_STR_LEN];
#endif
 
   _mutex setch_mutex;
   _mutex setbw_mutex;
   _mutex rf_read_reg_mutex;
#ifdef CONFIG_SDIO_INDIRECT_ACCESS
   _mutex sd_indirect_access_mutex;
#endif
 
#ifdef CONFIG_SYSON_INDIRECT_ACCESS
   _mutex syson_indirect_access_mutex;    /* System On Reg R/W */
#endif
 
   unsigned char    oper_channel; /* saved channel info when call set_channel_bw */
   unsigned char    oper_bwmode;
   unsigned char    oper_ch_offset;/* PRIME_CHNL_OFFSET */
   systime on_oper_ch_time;
 
   _adapter *padapters[CONFIG_IFACE_NUMBER];/*IFACE_ID_MAX*/
   u8 iface_nums; /* total number of ifaces used runtime */
   struct mi_state iface_state;
 
#ifdef CONFIG_AP_MODE
   #ifdef CONFIG_SUPPORT_MULTI_BCN
   u8        nr_ap_if; /* total interface number of ap /go /mesh / nan mode. */
   u16        inter_bcn_space; /* unit:ms */
   _queue    ap_if_q;
   u8        vap_map;
   u8        fw_bcn_offload;
   u8        vap_tbtt_rpt_map;
   #endif /*CONFIG_SUPPORT_MULTI_BCN*/
   #ifdef CONFIG_RTW_REPEATER_SON
   struct rtw_rson_struct  rson_data;
   #endif
#endif
#ifdef CONFIG_CLIENT_PORT_CFG
   struct clt_port_t clt_port;
#endif
 
#ifdef CONFIG_HW_P0_TSF_SYNC
   struct tsf_info p0_tsf;
#endif
   systime periodic_tsf_update_etime;
   _timer periodic_tsf_update_end_timer;
 
   struct macid_ctl_t macid_ctl;
 
   struct cam_ctl_t cam_ctl;
   struct sec_cam_ent cam_cache[SEC_CAM_ENT_NUM_SW_LIMIT];
 
#ifdef CONFIG_MBSSID_CAM
   struct mbid_cam_ctl_t mbid_cam_ctl;
   struct mbid_cam_cache mbid_cam_cache[TOTAL_MBID_CAM_NUM];
#endif
 
   struct rf_ctl_t rf_ctl;
 
#if CONFIG_TX_AC_LIFETIME
   struct tx_aclt_conf_t tx_aclt_force_val;
   u8 tx_aclt_flags;
   struct tx_aclt_conf_t tx_aclt_confs[TX_ACLT_CONF_NUM];
#endif
 
   /* In /Out Pipe information */
   int    RtInPipe[2];
   int    RtOutPipe[MAX_BULKOUT_NUM];
   u8    Queue2Pipe[HW_QUEUE_ENTRY];/* for out pipe mapping */
 
   u8    irq_alloc;
   ATOMIC_T continual_io_error;
 
   ATOMIC_T disable_func;
 
   u8 xmit_block;
   _lock xmit_block_lock;
 
   struct pwrctrl_priv pwrctl_priv;
 
   struct rtw_traffic_statistics    traffic_stat;
 
#ifdef PLATFORM_LINUX
   _thread_hdl_ rtnl_lock_holder;
 
   #if defined(CONFIG_IOCTL_CFG80211) && defined(RTW_SINGLE_WIPHY)
   struct wiphy *wiphy;
   #endif
#endif /* PLATFORM_LINUX */
 
#ifdef CONFIG_SWTIMER_BASED_TXBCN
   _timer txbcn_timer;
#endif
   _timer dynamic_chk_timer; /* dynamic/periodic check timer */
   
#ifdef CONFIG_RTW_NAPI_DYNAMIC
   u8 en_napi_dynamic;
#endif /* CONFIG_RTW_NAPI_DYNAMIC */
 
#ifdef RTW_HALMAC
   void *halmac;
   struct halmacpriv hmpriv;
#endif /* RTW_HALMAC */
 
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
   /*info for H2C-0x2C*/
   struct dft_info dft;
#endif
 
#ifdef CONFIG_RTW_WIFI_HAL
   u32 nodfs;
#endif
 
   /*-------- below is for SDIO INTERFACE --------*/
 
#ifdef INTF_DATA
   INTF_DATA intf_data;
#endif
#ifdef INTF_OPS
   INTF_OPS intf_ops;
#endif
 
   /*-------- below is for USB INTERFACE --------*/
 
#ifdef CONFIG_USB_HCI
 
   u8    usb_speed; /* 1.1, 2.0 or 3.0 */
   u8    nr_endpoint;
   u8    RtNumInPipes;
   u8    RtNumOutPipes;
   int    ep_num[MAX_ENDPOINT_NUM]; /* endpoint number */
 
   int    RegUsbSS;
 
   _sema    usb_suspend_sema;
 
#ifdef CONFIG_USB_VENDOR_REQ_MUTEX
   _mutex  usb_vendor_req_mutex;
#endif
 
#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC
   u8 *usb_alloc_vendor_req_buf;
   u8 *usb_vendor_req_buf;
#endif
 
#ifdef PLATFORM_LINUX
   struct usb_interface *pusbintf;
   struct usb_device *pusbdev;
#endif/* PLATFORM_LINUX */
 
#ifdef PLATFORM_FREEBSD
   struct usb_interface *pusbintf;
   struct usb_device *pusbdev;
#endif/* PLATFORM_FREEBSD */
 
#endif/* CONFIG_USB_HCI */
 
   /*-------- below is for PCIE INTERFACE --------*/
 
#ifdef CONFIG_PCI_HCI
 
#ifdef PLATFORM_LINUX
   struct pci_dev *ppcidev;
 
   /* PCI MEM map */
   unsigned long    pci_mem_end;    /* shared mem end    */
   unsigned long    pci_mem_start;    /* shared mem start    */
 
   /* PCI IO map */
   unsigned long    pci_base_addr;    /* device I/O address    */
 
#ifdef RTK_129X_PLATFORM
   unsigned long    ctrl_start;
   /* PCI MASK addr */
   unsigned long    mask_addr;
 
   /* PCI TRANSLATE addr */
   unsigned long    tran_addr;
 
   _lock   io_reg_lock;
#endif
 
   /* PciBridge */
   struct pci_priv    pcipriv;
 
   unsigned int irq; /* get from pci_dev.irq, store to net_device.irq */
   u16    irqline;
   u8    irq_enabled;
   RT_ISR_CONTENT    isr_content;
   _lock    irq_th_lock;
 
   u8    bdma64;
#endif/* PLATFORM_LINUX */
 
#endif/* CONFIG_PCI_HCI */
 
#ifdef CONFIG_MCC_MODE
   struct mcc_obj_priv mcc_objpriv;
#endif /*CONFIG_MCC_MODE */
 
#ifdef CONFIG_RTW_TPT_MODE
   u8 tpt_mode; /* RTK T/P Testing Mode, 0:default mode */
   u32 edca_be_ul;
   u32 edca_be_dl;
#endif 
   /* also for RTK T/P Testing Mode */ 
   u8 scan_deny;
 
   /* protect sel to safely access */
#ifdef CONFIG_PROTSEL_PORT
   struct protsel protsel_port;
#endif
#ifdef CONFIG_PROTSEL_ATIMDTIM
   struct protsel protsel_atimdtim;
#endif
#ifdef CONFIG_PROTSEL_MACSLEEP
   struct protsel protsel_macsleep;
#endif
};
 
#define DEV_STA_NUM(_dvobj)            MSTATE_STA_NUM(&((_dvobj)->iface_state))
#define DEV_STA_LD_NUM(_dvobj)        MSTATE_STA_LD_NUM(&((_dvobj)->iface_state))
#define DEV_STA_LG_NUM(_dvobj)        MSTATE_STA_LG_NUM(&((_dvobj)->iface_state))
#define DEV_TDLS_LD_NUM(_dvobj)        MSTATE_TDLS_LD_NUM(&((_dvobj)->iface_state))
#define DEV_AP_NUM(_dvobj)            MSTATE_AP_NUM(&((_dvobj)->iface_state))
#define DEV_AP_STARTING_NUM(_dvobj)    MSTATE_AP_STARTING_NUM(&((_dvobj)->iface_state))
#define DEV_AP_LD_NUM(_dvobj)        MSTATE_AP_LD_NUM(&((_dvobj)->iface_state))
#define DEV_ADHOC_NUM(_dvobj)        MSTATE_ADHOC_NUM(&((_dvobj)->iface_state))
#define DEV_ADHOC_LD_NUM(_dvobj)    MSTATE_ADHOC_LD_NUM(&((_dvobj)->iface_state))
#define DEV_MESH_NUM(_dvobj)        MSTATE_MESH_NUM(&((_dvobj)->iface_state))
#define DEV_MESH_LD_NUM(_dvobj)        MSTATE_MESH_LD_NUM(&((_dvobj)->iface_state))
#define DEV_P2P_DV_NUM(_dvobj)        MSTATE_P2P_DV_NUM(&((_dvobj)->iface_state))
#define DEV_P2P_GC_NUM(_dvobj)        MSTATE_P2P_GC_NUM(&((_dvobj)->iface_state))
#define DEV_P2P_GO_NUM(_dvobj)        MSTATE_P2P_GO_NUM(&((_dvobj)->iface_state))
#define DEV_SCAN_NUM(_dvobj)        MSTATE_SCAN_NUM(&((_dvobj)->iface_state))
#define DEV_WPS_NUM(_dvobj)            MSTATE_WPS_NUM(&((_dvobj)->iface_state))
#define DEV_ROCH_NUM(_dvobj)        MSTATE_ROCH_NUM(&((_dvobj)->iface_state))
#define DEV_MGMT_TX_NUM(_dvobj)        MSTATE_MGMT_TX_NUM(&((_dvobj)->iface_state))
#define DEV_U_CH(_dvobj)            MSTATE_U_CH(&((_dvobj)->iface_state))
#define DEV_U_BW(_dvobj)            MSTATE_U_BW(&((_dvobj)->iface_state))
#define DEV_U_OFFSET(_dvobj)        MSTATE_U_OFFSET(&((_dvobj)->iface_state))
 
#define dvobj_to_pwrctl(dvobj) (&(dvobj->pwrctl_priv))
#define pwrctl_to_dvobj(pwrctl) container_of(pwrctl, struct dvobj_priv, pwrctl_priv)
#define dvobj_to_macidctl(dvobj) (&(dvobj->macid_ctl))
#define dvobj_to_sec_camctl(dvobj) (&(dvobj->cam_ctl))
#define dvobj_to_regsty(dvobj) (&(dvobj->padapters[IFACE_ID0]->registrypriv))
#if defined(CONFIG_IOCTL_CFG80211) && defined(RTW_SINGLE_WIPHY)
#define dvobj_to_wiphy(dvobj) ((dvobj)->wiphy)
#endif
#define dvobj_to_rfctl(dvobj) (&(dvobj->rf_ctl))
#define rfctl_to_dvobj(rfctl) container_of((rfctl), struct dvobj_priv, rf_ctl)
 
static inline void dev_set_surprise_removed(struct dvobj_priv *dvobj)
{
   ATOMIC_SET(&dvobj->bSurpriseRemoved, _TRUE);
}
static inline void dev_clr_surprise_removed(struct dvobj_priv *dvobj)
{
   ATOMIC_SET(&dvobj->bSurpriseRemoved, _FALSE);
}
static inline void dev_set_drv_stopped(struct dvobj_priv *dvobj)
{
   ATOMIC_SET(&dvobj->bDriverStopped, _TRUE);
}
static inline void dev_clr_drv_stopped(struct dvobj_priv *dvobj)
{
   ATOMIC_SET(&dvobj->bDriverStopped, _FALSE);
}
#define dev_is_surprise_removed(dvobj)    (ATOMIC_READ(&dvobj->bSurpriseRemoved) == _TRUE)
#define dev_is_drv_stopped(dvobj)        (ATOMIC_READ(&dvobj->bDriverStopped) == _TRUE)
 
#ifdef PLATFORM_LINUX
static inline struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
{
   /* todo: get interface type from dvobj and the return the dev accordingly */
#ifdef RTW_DVOBJ_CHIP_HW_TYPE
#endif
 
#ifdef CONFIG_USB_HCI
   return &dvobj->pusbintf->dev;
#endif
#ifdef CONFIG_SDIO_HCI
   return &dvobj->intf_data.func->dev;
#endif
#ifdef CONFIG_GSPI_HCI
   return &dvobj->intf_data.func->dev;
#endif
#ifdef CONFIG_PCI_HCI
   return &dvobj->ppcidev->dev;
#endif
}
#endif
 
_adapter *dvobj_get_port0_adapter(struct dvobj_priv *dvobj);
_adapter *dvobj_get_unregisterd_adapter(struct dvobj_priv *dvobj);
_adapter *dvobj_get_adapter_by_addr(struct dvobj_priv *dvobj, u8 *addr);
#define dvobj_get_primary_adapter(dvobj)    ((dvobj)->padapters[IFACE_ID0])
 
enum _hw_port {
   HW_PORT0,
   HW_PORT1,
   HW_PORT2,
   HW_PORT3,
   HW_PORT4,
   MAX_HW_PORT,
};
 
#ifdef CONFIG_CLIENT_PORT_CFG
enum _client_port {
   CLT_PORT0 = HW_PORT1,
   CLT_PORT1 = HW_PORT2,
   CLT_PORT2 = HW_PORT3,
   CLT_PORT3 = HW_PORT4,
   CLT_PORT_INVALID = HW_PORT0,
};
 
#define MAX_CLIENT_PORT_NUM    4
#define get_clt_port(adapter) (adapter->client_port)
#endif
 
enum _ADAPTER_TYPE {
   PRIMARY_ADAPTER,
   VIRTUAL_ADAPTER,
   MAX_ADAPTER = 0xFF,
};
 
typedef enum _DRIVER_STATE {
   DRIVER_NORMAL = 0,
   DRIVER_DISAPPEAR = 1,
   DRIVER_REPLACE_DONGLE = 2,
} DRIVER_STATE;
 
#ifdef CONFIG_RTW_NAPI
enum _NAPI_STATE {
   NAPI_DISABLE = 0,
   NAPI_ENABLE = 1,
};
#endif
 
#ifdef CONFIG_MAC_LOOPBACK_DRIVER
typedef struct loopbackdata {
   _sema    sema;
   _thread_hdl_ lbkthread;
   u8 bstop;
   u32 cnt;
   u16 size;
   u16 txsize;
   u8 txbuf[0x8000];
   u16 rxsize;
   u8 rxbuf[0x8000];
   u8 msg[100];
 
} LOOPBACKDATA, *PLOOPBACKDATA;
#endif
 
#define ADAPTER_TX_BW_2G(adapter) BW_MODE_2G((adapter)->driver_tx_bw_mode)
#define ADAPTER_TX_BW_5G(adapter) BW_MODE_5G((adapter)->driver_tx_bw_mode)
 
struct _ADAPTER {
   int    DriverState;/* for disable driver using module, use dongle to replace module. */
   int    pid[3];/* process id from UI, 0:wps, 1:hostapd, 2:dhcpcd */
   int    bDongle;/* build-in module or external dongle */
 
   #if defined(CONFIG_AP_MODE) && defined(CONFIG_SUPPORT_MULTI_BCN)
   _list    list;
   u8 vap_id;
   #endif
   struct dvobj_priv *dvobj;
   struct    mlme_priv mlmepriv;
   struct    mlme_ext_priv mlmeextpriv;
   struct    cmd_priv    cmdpriv;
   struct    evt_priv    evtpriv;
 
#ifdef CONFIG_RTW_80211K
   struct    rm_priv        rmpriv;
#endif
   /* struct    io_queue    *pio_queue; */
   struct    io_priv    iopriv;
   struct    xmit_priv    xmitpriv;
   struct    recv_priv    recvpriv;
   struct    sta_priv    stapriv;
   struct    security_priv    securitypriv;
   _lock   security_key_mutex; /* add for CONFIG_IEEE80211W, none 11w also can use */
   struct    registry_priv    registrypriv;
 
#ifdef CONFIG_RTW_NAPI
   struct    napi_struct napi;
   u8    napi_state;
#endif
 
#ifdef CONFIG_MP_INCLUDED
   struct    mp_priv    mppriv;
#endif
 
#ifdef CONFIG_AP_MODE
   struct    hostapd_priv    *phostapdpriv;
#endif
 
#ifdef CONFIG_IOCTL_CFG80211
#ifdef CONFIG_P2P
   struct cfg80211_wifidirect_info    cfg80211_wdinfo;
#endif /* CONFIG_P2P */
#endif /* CONFIG_IOCTL_CFG80211 */
   u32    setband;
   ATOMIC_T bandskip;
 
#ifdef CONFIG_P2P
   struct wifidirect_info    wdinfo;
#endif /* CONFIG_P2P */
 
#ifdef CONFIG_TDLS
   struct tdls_info    tdlsinfo;
#endif /* CONFIG_TDLS */
 
#ifdef CONFIG_WAPI_SUPPORT
   u8    WapiSupport;
   RT_WAPI_T    wapiInfo;
#endif
 
#ifdef CONFIG_RTW_REPEATER_SON
   u8    rtw_rson_scanstage;
#endif
 
#ifdef CONFIG_WFD
   struct wifi_display_info wfd_info;
#endif /* CONFIG_WFD */
 
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
   struct bt_coex_info coex_info;
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 
   ERROR_CODE        LastError; /* <20130613, Kordan> Only the functions associated with MP records the error code by now. */
 
   void *HalData;
   u32 hal_data_sz;
   struct hal_ops    hal_func;
 
   u32    IsrContent;
   u32    ImrContent;
 
   u8    EepromAddressSize;
   u8    bDriverIsGoingToUnload;
   u8    init_adpt_in_progress;
   u8    bHaltInProgress;
#ifdef CONFIG_GPIO_API
   u8    pre_gpio_pin;
   struct gpio_int_priv {
       u8 interrupt_mode;
       u8 interrupt_enable_mask;
       void (*callback[8])(u8 level);
   } gpiointpriv;
#endif
   _thread_hdl_ cmdThread;
#ifdef CONFIG_EVENT_THREAD_MODE
   _thread_hdl_ evtThread;
#endif
#ifdef CONFIG_XMIT_THREAD_MODE
   _thread_hdl_ xmitThread;
#endif
#ifdef CONFIG_RECV_THREAD_MODE
   _thread_hdl_ recvThread;
#endif
   u8 registered;
 
   void (*intf_start)(_adapter *adapter);
   void (*intf_stop)(_adapter *adapter);
 
#ifdef PLATFORM_LINUX
   _nic_hdl pnetdev;
   char old_ifname[IFNAMSIZ];
 
   /* used by rtw_rereg_nd_name related function */
   struct rereg_nd_name_data {
       _nic_hdl old_pnetdev;
       char old_ifname[IFNAMSIZ];
       u8 old_ips_mode;
       u8 old_bRegUseLed;
   } rereg_nd_name_priv;
 
   u8 ndev_unregistering;
   int bup;
   struct net_device_stats stats;
   struct iw_statistics iwstats;
   struct proc_dir_entry *dir_dev;/* for proc directory */
   struct proc_dir_entry *dir_odm;
 
#ifdef CONFIG_MCC_MODE
   struct proc_dir_entry *dir_mcc;
#endif /* CONFIG_MCC_MODE */
 
#ifdef CONFIG_IOCTL_CFG80211
   struct wireless_dev *rtw_wdev;
   struct rtw_wdev_priv wdev_data;
 
#if !defined(RTW_SINGLE_WIPHY)
   struct wiphy *wiphy;
#endif
 
#endif /* CONFIG_IOCTL_CFG80211 */
 
#endif /* PLATFORM_LINUX */
 
#ifdef PLATFORM_FREEBSD
   _nic_hdl pifp;
   int bup;
   _lock glock;
#endif /* PLATFORM_FREEBSD */
   u8 mac_addr[ETH_ALEN];
   int net_closed;
 
   u8 netif_up;
 
   u8 bLinkInfoDump;
   /*    Added by Albert 2012/10/26 */
   /*    The driver will show up the desired channel number when this flag is 1. */
   u8 bNotifyChannelChange;
   u8 bsta_tp_dump;
#ifdef CONFIG_P2P
   /*    Added by Albert 2012/12/06 */
   /*    The driver will show the current P2P status when the upper application reads it. */
   u8 bShowGetP2PState;
#endif
#ifdef CONFIG_AUTOSUSPEND
   u8    bDisableAutosuspend;
#endif
 
   u8 isprimary; /* is primary adapter or not */
   /* notes:
   **    if isprimary is true, the adapter_type value is 0, iface_id is IFACE_ID0 for PRIMARY_ADAPTER
   **    if isprimary is false, the adapter_type value is 1, iface_id is IFACE_ID1 for VIRTUAL_ADAPTER
   **    refer to iface_id if iface_nums>2 and isprimary is false and the adapter_type value is 0xff.*/
   u8 adapter_type;/*be used in  Multi-interface to recognize whether is PRIMARY_ADAPTER  or not(PRIMARY_ADAPTER/VIRTUAL_ADAPTER) .*/
   u8 hw_port; /*interface port type, it depends on HW port */
 
   #ifdef CONFIG_CLIENT_PORT_CFG
   u8 client_id;
   u8 client_port;
   #endif
   /*struct tsf_info tsf;*//*reserve define for 8814B*/
 
   /*extend to support multi interface*/
   u8 iface_id;
 
#ifdef CONFIG_BR_EXT
   _lock                    br_ext_lock;
   /* unsigned int            macclone_completed; */
   struct nat25_network_db_entry    *nethash[NAT25_HASH_SIZE];
   int                pppoe_connection_in_progress;
   unsigned char            pppoe_addr[MACADDRLEN];
   unsigned char            scdb_mac[MACADDRLEN];
   unsigned char            scdb_ip[4];
   struct nat25_network_db_entry    *scdb_entry;
   unsigned char            br_mac[MACADDRLEN];
   unsigned char            br_ip[4];
 
   struct br_ext_info        ethBrExtInfo;
#endif /* CONFIG_BR_EXT */
 
#ifdef CONFIG_MAC_LOOPBACK_DRIVER
   PLOOPBACKDATA ploopback;
#endif
#ifdef CONFIG_AP_MODE
   u8 bmc_tx_rate;
#endif
 
   /* for debug purpose */
   u8 fix_rate;
   u8 fix_bw;
   u8 data_fb; /* data rate fallback, valid only when fix_rate is not 0xff */
   u8 power_offset;
   u8 driver_tx_bw_mode;
   u8 rsvd_page_offset;
   u8 rsvd_page_num;
#ifdef CONFIG_SUPPORT_FIFO_DUMP
   u8 fifo_sel;
   u32 fifo_addr;
   u32 fifo_size;
#endif
 
   u8 driver_vcs_en; /* Enable=1, Disable=0 driver control vrtl_carrier_sense for tx */
   u8 driver_vcs_type;/* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. */
   u8 driver_ampdu_spacing;/* driver control AMPDU Density for peer sta's rx */
   u8 driver_rx_ampdu_factor;/* 0xff: disable drv ctrl, 0:8k, 1:16k, 2:32k, 3:64k; */
   u8 driver_rx_ampdu_spacing;  /* driver control Rx AMPDU Density */
   u8 fix_rx_ampdu_accept;
   u8 fix_rx_ampdu_size; /* 0~127, TODO:consider each sta and each TID */
#ifdef CONFIG_TX_AMSDU
   u8 tx_amsdu;
   u16 tx_amsdu_rate;
#endif
   u8 driver_tx_max_agg_num; /*fix tx desc max agg num , 0xff: disable drv ctrl*/
#ifdef DBG_RX_COUNTER_DUMP
   u8 dump_rx_cnt_mode;/*BIT0:drv,BIT1:mac,BIT2:phy*/
   u32 drv_rx_cnt_ok;
   u32 drv_rx_cnt_crcerror;
   u32 drv_rx_cnt_drop;
#endif
 
#ifdef CONFIG_DBG_COUNTER
   struct rx_logs rx_logs;
   struct tx_logs tx_logs;
   struct int_logs int_logs;
#endif
 
#ifdef CONFIG_MCC_MODE
   struct mcc_adapter_priv mcc_adapterpriv;
#endif /* CONFIG_MCC_MODE */
 
#ifdef CONFIG_RTW_MESH
   struct rtw_mesh_cfg mesh_cfg;
   struct rtw_mesh_info mesh_info;
   _timer mesh_path_timer;
   _timer mesh_path_root_timer;
   _timer mesh_atlm_param_req_timer; /* airtime link metrics param request timer */
   _workitem mesh_work;
   unsigned long wrkq_flags;
#endif /* CONFIG_RTW_MESH */
};
 
#define adapter_to_dvobj(adapter) ((adapter)->dvobj)
#define adapter_to_regsty(adapter) dvobj_to_regsty(adapter_to_dvobj((adapter)))
#define adapter_to_pwrctl(adapter) dvobj_to_pwrctl(adapter_to_dvobj((adapter)))
#define adapter_wdev_data(adapter) (&((adapter)->wdev_data))
#if defined(RTW_SINGLE_WIPHY)
#define adapter_to_wiphy(adapter) dvobj_to_wiphy(adapter_to_dvobj(adapter))
#else
#define adapter_to_wiphy(adapter) ((adapter)->wiphy)
#endif
 
#define adapter_to_rfctl(adapter) dvobj_to_rfctl(adapter_to_dvobj((adapter)))
#define adapter_to_macidctl(adapter) dvobj_to_macidctl(adapter_to_dvobj((adapter)))
 
#define adapter_mac_addr(adapter) (adapter->mac_addr)
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
#define adapter_pno_mac_addr(adapter) \
   ((adapter_wdev_data(adapter))->pno_mac_addr)
#endif
 
#define adapter_to_chset(adapter) (adapter_to_rfctl((adapter))->channel_set)
 
#define mlme_to_adapter(mlme) container_of((mlme), struct _ADAPTER, mlmepriv)
#define tdls_info_to_adapter(tdls) container_of((tdls), struct _ADAPTER, tdlsinfo)
 
#define rtw_get_chip_type(adapter) (((PADAPTER)adapter)->dvobj->chip_type)
#define rtw_get_hw_type(adapter) (((PADAPTER)adapter)->dvobj->HardwareType)
#define rtw_get_intf_type(adapter) (((PADAPTER)adapter)->dvobj->interface_type)
 
#define rtw_get_mi_nums(adapter) (((PADAPTER)adapter)->dvobj->iface_nums)
 
static inline void rtw_set_surprise_removed(_adapter *padapter)
{
   dev_set_surprise_removed(adapter_to_dvobj(padapter));
}
static inline void rtw_clr_surprise_removed(_adapter *padapter)
{
   dev_clr_surprise_removed(adapter_to_dvobj(padapter));
}
static inline void rtw_set_drv_stopped(_adapter *padapter)
{
   dev_set_drv_stopped(adapter_to_dvobj(padapter));
}
static inline void rtw_clr_drv_stopped(_adapter *padapter)
{
   dev_clr_drv_stopped(adapter_to_dvobj(padapter));
}
#define rtw_is_surprise_removed(padapter)    (dev_is_surprise_removed(adapter_to_dvobj(padapter)))
#define rtw_is_drv_stopped(padapter)        (dev_is_drv_stopped(adapter_to_dvobj(padapter)))
 
/*
 * Function disabled.
 *   */
#define DF_TX_BIT        BIT0            /*write_port_cancel*/
#define DF_RX_BIT        BIT1            /*read_port_cancel*/
#define DF_IO_BIT        BIT2
 
/* #define RTW_DISABLE_FUNC(padapter, func) (ATOMIC_ADD(&adapter_to_dvobj(padapter)->disable_func, (func))) */
/* #define RTW_ENABLE_FUNC(padapter, func) (ATOMIC_SUB(&adapter_to_dvobj(padapter)->disable_func, (func))) */
__inline static void RTW_DISABLE_FUNC(_adapter *padapter, int func_bit)
{
   int    df = ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func);
   df |= func_bit;
   ATOMIC_SET(&adapter_to_dvobj(padapter)->disable_func, df);
}
 
__inline static void RTW_ENABLE_FUNC(_adapter *padapter, int func_bit)
{
   int    df = ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func);
   df &= ~(func_bit);
   ATOMIC_SET(&adapter_to_dvobj(padapter)->disable_func, df);
}
 
#define RTW_CANNOT_RUN(padapter) \
   (rtw_is_surprise_removed(padapter) || \
    rtw_is_drv_stopped(padapter))
 
#define RTW_IS_FUNC_DISABLED(padapter, func_bit) (ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func) & (func_bit))
 
#define RTW_CANNOT_IO(padapter) \
   (rtw_is_surprise_removed(padapter) || \
    RTW_IS_FUNC_DISABLED((padapter), DF_IO_BIT))
 
#define RTW_CANNOT_RX(padapter) \
   (RTW_CANNOT_RUN(padapter) || \
    RTW_IS_FUNC_DISABLED((padapter), DF_RX_BIT))
 
#define RTW_CANNOT_TX(padapter) \
   (RTW_CANNOT_RUN(padapter) || \
    RTW_IS_FUNC_DISABLED((padapter), DF_TX_BIT))
 
#ifdef CONFIG_PNO_SUPPORT
int rtw_parse_ssid_list_tlv(char **list_str, pno_ssid_t *ssid, int max, int *bytes_left);
int rtw_dev_pno_set(struct net_device *net, pno_ssid_t *ssid, int num,
           int pno_time, int pno_repeat, int pno_freq_expo_max);
#ifdef CONFIG_PNO_SET_DEBUG
   void rtw_dev_pno_debug(struct net_device *net);
#endif /* CONFIG_PNO_SET_DEBUG */
#endif /* CONFIG_PNO_SUPPORT */
 
int rtw_suspend_free_assoc_resource(_adapter *padapter);
#ifdef CONFIG_WOWLAN
   int rtw_suspend_wow(_adapter *padapter);
   int rtw_resume_process_wow(_adapter *padapter);
#endif
 
/* HCI Related header file */
#ifdef CONFIG_USB_HCI
   #include <usb_osintf.h>
   #include <usb_ops.h>
   #include <usb_hal.h>
#endif
 
#ifdef CONFIG_SDIO_HCI
   #include <sdio_osintf.h>
   #include <sdio_ops.h>
   #include <sdio_hal.h>
#endif
 
#ifdef CONFIG_GSPI_HCI
   #include <gspi_osintf.h>
   #include <gspi_ops.h>
   #include <gspi_hal.h>
#endif
 
#ifdef CONFIG_PCI_HCI
   #include <pci_osintf.h>
   #include <pci_ops.h>
   #include <pci_hal.h>
#endif
 
#endif /* __DRV_TYPES_H__ */