SAMA5D4 Xplained Ultra Board BSP
guowenxue
2019-08-19 2e7235d10c6dbff81960282e1a1e2e798f9b8db8
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
/******************************************************************************
 *
 * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
 *
 * 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.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
 *
 *
 ******************************************************************************/
/*-------------------------------------------------------------------------------
 
    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 <rtw_rf.h>
 
#ifdef CONFIG_80211N_HT
    #include <rtw_ht.h>
#endif
 
#ifdef CONFIG_80211AC_VHT
    #include <rtw_vht.h>
#endif
 
#ifdef CONFIG_INTEL_WIDI
    #include <rtw_intel_widi.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>
 
#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 <rtw_ioctl_rtl.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>
#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_DRVEXT_MODULE
    #include <drvext_api.h>
#endif /* CONFIG_DRVEXT_MODULE */
 
#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>
#ifdef CONFIG_BT_COEXIST
    #include <rtw_btcoex.h>
#endif /* CONFIG_BT_COEXIST */
 
#ifdef CONFIG_MCC_MODE
    #include <rtw_mcc.h>
#endif /*CONFIG_MCC_MODE */
 
#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    smart_ps;
    u8   usb_rxagg_mode;
    u8    long_retry_lmt;
    u8    short_retry_lmt;
    u16    busy_thresh;
    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
    u8    acm_method;
    /* UAPSD */
    u8    wmm_enable;
    u8    uapsd_enable;
    u8    uapsd_max_sp;
    u8    uapsd_acbk_en;
    u8    uapsd_acbe_en;
    u8    uapsd_acvi_en;
    u8    uapsd_acvo_en;
 
    WLAN_BSSID_EX    dev_network;
 
    u8 tx_bw_mode;
 
#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    ampdu_amsdu;/* A-MPDU Supports A-MSDU is permitted */
    /* 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;
    /*
     * 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    rf_config ;
    u8    low_power ;
 
    u8    wifi_spec;/* !turbo_mode */
    u8    special_rf_path; /* 0: 2T2R ,1: only turn on path A 1T1R */
    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;
#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;
 
#ifdef CONFIG_SPECIAL_SETTING_FOR_FUNAI_TV
    u8 force_ant;/* 0 normal,1 main,2 aux */
    u8 force_igi;/* 0 normal */
#endif
 
    u8 force_igi_lb;
 
    /* for pll reference clock selction */
    u8 pll_ref_clk_sel;
 
    /* define for tx power adjust */
    u8    RegEnableTxPowerLimit;
    u8    RegEnableTxPowerByRate;
    u8    RegPowerBase;
    u8    RegPwrTblSel;
 
    u8 target_tx_pwr_valid;
    s8 target_tx_pwr_2g[RF_PATH_MAX][RATE_SECTION_NUM];
#ifdef CONFIG_IEEE80211_BAND_5GHZ
    s8 target_tx_pwr_5g[RF_PATH_MAX][RATE_SECTION_NUM - 1];
#endif
 
    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;
#endif
    u8 qos_opt_enable;
 
    u8 hiq_filter;
    u8 adaptivity_en;
    u8 adaptivity_mode;
    u8 adaptivity_dml;
    u8 adaptivity_dc_backoff;
    s8 adaptivity_th_l2h_ini;
    s8 adaptivity_th_edcca_hl_diff;
 
    u8 boffefusemask;
    BOOLEAN bFileMaskEfuse;
#ifdef CONFIG_AUTO_CHNL_SEL_NHM
    u8 acs_mode;
    u8 acs_auto_scan;
#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_tsf_sync_offset;
    u8 rtw_mcc_start_time_offset;
    u8 rtw_mcc_interval;
    s8 rtw_mcc_guard_offset0;
    s8 rtw_mcc_guard_offset1;
#endif /* CONFIG_MCC_MODE */
 
#ifdef CONFIG_RTW_NAPI
    u8 en_napi;
#ifdef CONFIG_RTW_GRO
    u8 en_gro;
#endif /* CONFIG_RTW_GRO */
#endif /* CONFIG_RTW_NAPI */
 
    bool    default_patterns_en;
#ifdef CONFIG_SUPPORT_TRX_SHARED
    u8 trx_share_mode;
#endif
    u8 check_hw_status;
};
 
/* For registry parameters */
#define RGTRY_OFT(field) ((ULONG)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 BSSID_OFT(field) ((ULONG)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)
#define REGSTY_BW_2G(regsty) BW_MODE_2G((regsty)->bw_mode)
#define REGSTY_BW_5G(regsty) BW_MODE_5G((regsty)->bw_mode)
#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)
 
typedef struct rtw_if_operations {
    int __must_check(*read)(struct dvobj_priv *d, int addr, void *buf,
                size_t len, bool fixed);
    int __must_check(*write)(struct dvobj_priv *d, 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
 
#ifdef CONFIG_CONCURRENT_MODE
    #define is_primary_adapter(adapter) (adapter->adapter_type == PRIMARY_ADAPTER)
    #define is_vir_adapter(adapter) (adapter->adapter_type == VIRTUAL_ADAPTER)
    #define get_hw_port(adapter) (adapter->hw_port)
#else
    #define is_primary_adapter(adapter) (1)
    #define is_vir_adapter(adapter) (0)
    #define get_hw_port(adapter) (HW_PORT0)
#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;
    u64 dbg_rx_fifo_last_overflow;
    u64 dbg_rx_fifo_curr_overflow;
    u64 dbg_rx_fifo_diff_overflow;
    u64 dbg_rx_ampdu_drop_count;
    u64 dbg_rx_ampdu_forced_indicate_count;
    u64 dbg_rx_ampdu_loss_count;
    u64 dbg_rx_dup_mgt_frame_drop_count;
    u64 dbg_rx_ampdu_window_shift_cnt;
    u64 dbg_rx_conflic_mac_addr_cnt;
};
 
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]
 
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
};
 
struct macid_ctl_t {
    _lock lock;
    u8 num;
    struct macid_bmp used;
    struct macid_bmp bmc;
    struct macid_bmp if_g[CONFIG_IFACE_NUMBER];
    u8 iface_bmc[CONFIG_IFACE_NUMBER];/*for bc-sta of AP or Adhoc mode*/
    struct macid_bmp ch_g[2]; /* 2 ch concurrency */
    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];
    struct sta_info *sta[MACID_NUM_SW_LIMIT];
};
 
/* 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    0x000003FF
#define RATE_BMP_VHT_2SS    0x000FFC00
#define RATE_BMP_VHT_3SS    0x3FF00000
#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_GET_VHT_1SS(_bmp_vht)        (_bmp_vht & RATE_BMP_VHT_1SS)
#define RATE_BMP_GET_VHT_2SS(_bmp_vht)        ((_bmp_vht & RATE_BMP_VHT_2SS) >> 10)
#define RATE_BMP_GET_VHT_3SS(_bmp_vht)        ((_bmp_vht & RATE_BMP_VHT_3SS) >> 20)
 
struct rf_ctl_t {
    /* 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 */
    u32 rate_bmp_vht_by_bw[4];    /* 20MHz, 40MHz, 80MHz, 160MHz. up to 3SS supported */
 
    /* used by tx power limit */
    u8 highest_ht_rate_bw_bmp;
    u8 highest_vht_rate_bw_bmp;
 
#ifdef CONFIG_DFS_MASTER
    bool radar_detect_by_others;
    u8 dfs_master_enabled;
    bool radar_detected;
 
    u8 radar_detect_ch;
    u8 radar_detect_bw;
    u8 radar_detect_offset;
 
    u32 cac_start_time;
    u32 cac_end_time;
 
    u8 dfs_ch_sel_d_flags;
 
    u8 dbg_dfs_master_fake_radar_detect_cnt;
    u8 dbg_dfs_master_radar_detect_trigger_non;
    u8 dbg_dfs_master_choose_dfs_ch_first;
#endif
};
 
#define RTW_CAC_STOPPED 0
#define IS_CAC_STOPPED(rfctl) ((rfctl)->cac_end_time == RTW_CAC_STOPPED)
#define IS_CH_WAITING(rfctl) (!IS_CAC_STOPPED(rfctl) && time_after((unsigned long)(rfctl)->cac_end_time, (unsigned long)rtw_get_current_time()))
#define IS_UNDER_CAC(rfctl) (IS_CH_WAITING(rfctl) && time_after((unsigned long)rtw_get_current_time(), (unsigned long)(rfctl)->cac_start_time))
 
#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;
 
#ifdef CONFIG_SDIO_HCI
    /* Store hardware tx queue page number setting */
    u16 txpage[HW_QUEUE_ENTRY];
#endif /* CONFIG_SDIO_HCI */
};
#endif /* RTW_HALMAC */
 
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;
 
#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
 
    unsigned char    oper_channel; /* saved channel info when call set_channel_bw */
    unsigned char    oper_bwmode;
    unsigned char    oper_ch_offset;/* PRIME_CHNL_OFFSET */
    u32 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
    u8 nr_ap_if; /* total interface s number of ap/go mode. */
    u32 inter_bcn_space; /* unit:ms */
    _queue    ap_if_q;
#endif
 
    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;
 
    /* For 92D, DMDP have 2 interface. */
    u8    InterfaceNumber;
    u8    NumInterfaces;
 
    /* In /Out Pipe information */
    int    RtInPipe[2];
    int    RtOutPipe[4];
    u8    Queue2Pipe[HW_QUEUE_ENTRY];/* for out pipe mapping */
 
    u8    irq_alloc;
    ATOMIC_T continual_io_error;
 
    ATOMIC_T disable_func;
 
    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 RTW_HALMAC
    void *halmac;
    struct halmacpriv hmpriv;
#endif /* RTW_HALMAC */
 
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
    u8 default_port_id;
#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[6]; /* 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_WINDOWS
    /* related device objects */
    PDEVICE_OBJECT    pphysdevobj;/* pPhysDevObj; */
    PDEVICE_OBJECT    pfuncdevobj;/* pFuncDevObj; */
    PDEVICE_OBJECT    pnextdevobj;/* pNextDevObj; */
 
    u8    nextdevstacksz;/* unsigned char NextDeviceStackSize;     */ /* = (CHAR)CEdevice->pUsbDevObj->StackSize + 1; */
 
    /* urb for control diescriptor request */
 
#ifdef PLATFORM_OS_XP
    struct _URB_CONTROL_DESCRIPTOR_REQUEST descriptor_urb;
    PUSB_CONFIGURATION_DESCRIPTOR    pconfig_descriptor;/* UsbConfigurationDescriptor; */
#endif
 
#ifdef PLATFORM_OS_CE
    WCHAR            active_path[MAX_ACTIVE_REG_PATH];    /* adapter regpath */
    USB_EXTENSION    usb_extension;
 
    _nic_hdl        pipehdls_r8192c[0x10];
#endif
 
    u32    config_descriptor_len;/* ULONG UsbConfigurationDescriptorLength; */
#endif/* PLATFORM_WINDOWS */
 
#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;
 
    /* ASPM */
    u8    const_pci_aspm;
    u8    const_amdpci_aspm;
    u8    const_hwsw_rfoff_d3;
    u8    const_support_pciaspm;
    /* pci-e bridge */
    u8    const_hostpci_aspm_setting;
    /* pci-e device */
    u8    const_devicepci_aspm_setting;
    u8    b_support_aspm; /* If it supports ASPM, Offset[560h] = 0x40, otherwise Offset[560h] = 0x00. */
    u8    b_support_backdoor;
    u8    bdma64;
#endif/* PLATFORM_LINUX */
 
#endif/* CONFIG_PCI_HCI */
 
#ifdef CONFIG_MCC_MODE
    struct mcc_obj_priv mcc_objpriv;
#endif /*CONFIG_MCC_MODE */
};
 
#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_AP_NUM(_dvobj)            MSTATE_AP_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_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 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,
};
 
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_INTEL_PROXIM
struct proxim {
    bool proxim_support;
    bool proxim_on;
 
    void *proximity_priv;
    int (*proxim_rx)(_adapter *padapter,
             union recv_frame *precv_frame);
    u8(*proxim_get_var)(_adapter *padapter, u8 type);
};
#endif /* CONFIG_INTEL_PROXIM */
 
#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
 
struct tsf_info {
    u8 sync_port;/*tsf sync from portx*/
    u8 offset; /*tsf timer offset*/
};
 
#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 */
 
    _list    list;
 
    struct dvobj_priv *dvobj;
    struct    mlme_priv mlmepriv;
    struct    mlme_ext_priv mlmeextpriv;
    struct    cmd_priv    cmdpriv;
    struct    evt_priv    evtpriv;
    /* 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;
 
    struct    led_priv    ledpriv;
 
#ifdef CONFIG_RTW_NAPI
    struct    napi_struct napi;
    u8    napi_state;
#endif
 
#ifdef CONFIG_MP_INCLUDED
    struct    mp_priv    mppriv;
#endif
 
#ifdef CONFIG_DRVEXT_MODULE
    struct    drvext_priv    drvextpriv;
#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_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. */
 
    PVOID            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;
    _thread_hdl_ evtThread;
    _thread_hdl_ xmitThread;
    _thread_hdl_ recvThread;
 
    u8 registered;
#ifndef PLATFORM_LINUX
    NDIS_STATUS(*dvobj_init)(struct dvobj_priv *dvobj);
    void (*dvobj_deinit)(struct dvobj_priv *dvobj);
#endif
 
    u32(*intf_init)(struct dvobj_priv *dvobj);
    void (*intf_deinit)(struct dvobj_priv *dvobj);
    int (*intf_alloc_irq)(struct dvobj_priv *dvobj);
    void (*intf_free_irq)(struct dvobj_priv *dvobj);
 
 
    void (*intf_start)(_adapter *adapter);
    void (*intf_stop)(_adapter *adapter);
 
#ifdef PLATFORM_WINDOWS
    _nic_hdl        hndis_adapter;/* hNdisAdapter(NDISMiniportAdapterHandle); */
    _nic_hdl        hndis_config;/* hNdisConfiguration; */
    NDIS_STRING fw_img;
 
    u32    NdisPacketFilter;
    u8    MCList[MAX_MCAST_LIST_NUM][6];
    u32    MCAddrCount;
#endif /* end of PLATFORM_WINDOWS */
 
 
#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 bFWReady;
    u8 bBTFWReady;
    u8 bLinkInfoDump;
    u8 bRxRSSIDisplay;
    /*    Added by Albert 2012/10/26 */
    /*    The driver will show up the desired channel number when this flag is 1. */
    u8 bNotifyChannelChange;
#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 */
    struct tsf_info tsf;
 
 
    /*extend to support multi interface*/
    /*IFACE_ID0 is equals to PRIMARY_ADAPTER
    IFACE_ID1 is equals to VIRTUAL_ADAPTER*/
    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_INTEL_PROXIM
    /* intel Proximity, should be alloc mem
     * in intel Proximity module and can only
     * be used in intel Proximity mode */
    struct proxim proximity;
#endif /* CONFIG_INTEL_PROXIM */
 
#ifdef CONFIG_MAC_LOOPBACK_DRIVER
    PLOOPBACKDATA ploopback;
#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;
 
    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
    unsigned char     in_cta_test;
#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 */
};
 
#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_mac_addr(adapter) (adapter->mac_addr)
 
#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__ */