hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
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
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279
2280
2281
2282
2283
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416
2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472
2473
2474
2475
2476
2477
2478
2479
2480
2481
2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
2492
2493
2494
2495
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
2517
2518
2519
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548
2549
2550
2551
2552
2553
2554
2555
2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588
2589
2590
2591
2592
2593
2594
2595
2596
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619
2620
2621
2622
2623
2624
2625
2626
2627
2628
2629
2630
2631
2632
2633
2634
2635
2636
2637
2638
2639
2640
2641
2642
2643
2644
2645
2646
2647
2648
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666
2667
2668
2669
2670
2671
2672
2673
2674
2675
2676
2677
2678
2679
2680
2681
2682
2683
2684
2685
2686
2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
2731
2732
2733
2734
2735
2736
2737
2738
2739
2740
2741
2742
2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2760
2761
2762
2763
2764
2765
2766
2767
2768
2769
2770
2771
2772
2773
2774
2775
2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
2858
2859
2860
2861
2862
2863
2864
2865
2866
2867
2868
2869
2870
2871
2872
2873
2874
2875
2876
2877
2878
2879
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
2900
2901
2902
2903
2904
2905
2906
2907
2908
2909
2910
2911
2912
2913
2914
2915
2916
2917
2918
2919
2920
2921
2922
2923
2924
2925
2926
2927
2928
2929
2930
2931
2932
2933
2934
2935
2936
2937
2938
2939
2940
2941
2942
2943
2944
2945
2946
2947
2948
2949
2950
2951
2952
2953
2954
2955
2956
2957
2958
2959
2960
2961
2962
2963
2964
2965
2966
2967
2968
2969
2970
2971
2972
2973
2974
2975
2976
2977
2978
2979
2980
2981
2982
2983
2984
2985
2986
2987
2988
2989
2990
2991
2992
2993
2994
2995
2996
2997
2998
2999
3000
3001
3002
3003
3004
3005
3006
3007
3008
3009
3010
3011
3012
3013
3014
3015
3016
3017
3018
3019
3020
3021
3022
3023
3024
3025
3026
3027
3028
3029
3030
3031
3032
3033
3034
3035
3036
3037
3038
3039
3040
3041
3042
3043
3044
3045
3046
3047
3048
3049
3050
3051
3052
3053
3054
3055
3056
3057
3058
3059
3060
3061
3062
3063
3064
3065
3066
3067
3068
3069
3070
3071
3072
3073
3074
3075
3076
3077
3078
3079
3080
3081
3082
3083
3084
3085
3086
3087
3088
3089
3090
3091
3092
3093
3094
3095
3096
3097
3098
3099
3100
3101
3102
3103
3104
3105
3106
3107
3108
3109
3110
3111
3112
3113
3114
3115
3116
3117
3118
3119
3120
3121
3122
3123
3124
3125
3126
3127
3128
3129
3130
3131
3132
3133
3134
3135
3136
3137
3138
3139
3140
3141
3142
3143
3144
3145
3146
3147
3148
3149
3150
3151
3152
3153
3154
3155
3156
3157
3158
3159
3160
3161
3162
3163
3164
3165
3166
3167
3168
3169
3170
3171
3172
3173
3174
3175
3176
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
   Copyright (C) 2004 - 2010 Ivo van Doorn <IvDoorn@gmail.com>
   Copyright (C) 2010 Willow Garage <http://www.willowgarage.com>
   Copyright (C) 2009 Alban Browaeys <prahal@yahoo.com>
   Copyright (C) 2009 Felix Fietkau <nbd@openwrt.org>
   Copyright (C) 2009 Luis Correia <luis.f.correia@gmail.com>
   Copyright (C) 2009 Mattias Nissler <mattias.nissler@gmx.de>
   Copyright (C) 2009 Mark Asselstine <asselsm@gmail.com>
   Copyright (C) 2009 Xose Vazquez Perez <xose.vazquez@gmail.com>
   Copyright (C) 2009 Bart Zolnierkiewicz <bzolnier@gmail.com>
   <http://rt2x00.serialmonkey.com>
 
 */
 
/*
   Module: rt2800
   Abstract: Data structures and registers for the rt2800 modules.
   Supported chipsets: RT2800E, RT2800ED & RT2800U.
 */
 
#ifndef RT2800_H
#define RT2800_H
 
/*
 * RF chip defines.
 *
 * RF2820 2.4G 2T3R
 * RF2850 2.4G/5G 2T3R
 * RF2720 2.4G 1T2R
 * RF2750 2.4G/5G 1T2R
 * RF3020 2.4G 1T1R
 * RF2020 2.4G B/G
 * RF3021 2.4G 1T2R
 * RF3022 2.4G 2T2R
 * RF3052 2.4G/5G 2T2R
 * RF2853 2.4G/5G 3T3R
 * RF3320 2.4G 1T1R(RT3350/RT3370/RT3390)
 * RF3322 2.4G 2T2R(RT3352/RT3371/RT3372/RT3391/RT3392)
 * RF3053 2.4G/5G 3T3R(RT3563/RT3573/RT3593)
 * RF3853 2.4G/5G 3T3R(RT3883/RT3662)
 * RF5592 2.4G/5G 2T2R
 * RF3070 2.4G 1T1R
 * RF5360 2.4G 1T1R
 * RF5362 2.4G 1T1R
 * RF5370 2.4G 1T1R
 * RF5390 2.4G 1T1R
 */
#define RF2820                0x0001
#define RF2850                0x0002
#define RF2720                0x0003
#define RF2750                0x0004
#define RF3020                0x0005
#define RF2020                0x0006
#define RF3021                0x0007
#define RF3022                0x0008
#define RF3052                0x0009
#define RF2853                0x000a
#define RF3320                0x000b
#define RF3322                0x000c
#define RF3053                0x000d
#define RF5592                0x000f
#define RF3070                0x3070
#define RF3290                0x3290
#define RF3853                0x3853
#define RF5350                0x5350
#define RF5360                0x5360
#define RF5362                0x5362
#define RF5370                0x5370
#define RF5372                0x5372
#define RF5390                0x5390
#define RF5392                0x5392
#define RF7620                0x7620
 
/*
 * Chipset revisions.
 */
#define REV_RT2860C            0x0100
#define REV_RT2860D            0x0101
#define REV_RT2872E            0x0200
#define REV_RT3070E            0x0200
#define REV_RT3070F            0x0201
#define REV_RT3071E            0x0211
#define REV_RT3090E            0x0211
#define REV_RT3390E            0x0211
#define REV_RT3593E            0x0211
#define REV_RT5390F            0x0502
#define REV_RT5370G            0x0503
#define REV_RT5390R            0x1502
#define REV_RT5592C            0x0221
 
#define DEFAULT_RSSI_OFFSET        120
 
/*
 * Register layout information.
 */
#define CSR_REG_BASE            0x1000
#define CSR_REG_SIZE            0x0800
#define EEPROM_BASE            0x0000
#define EEPROM_SIZE            0x0200
#define BBP_BASE            0x0000
#define BBP_SIZE            0x00ff
#define RF_BASE                0x0004
#define RF_SIZE                0x0010
#define RFCSR_BASE            0x0000
#define RFCSR_SIZE            0x0040
 
/*
 * Number of TX queues.
 */
#define NUM_TX_QUEUES            4
 
/*
 * Registers.
 */
 
 
/*
 * MAC_CSR0_3290: MAC_CSR0 for RT3290 to identity MAC version number.
 */
#define MAC_CSR0_3290            0x0000
 
/*
 * E2PROM_CSR: PCI EEPROM control register.
 * RELOAD: Write 1 to reload eeprom content.
 * TYPE: 0: 93c46, 1:93c66.
 * LOAD_STATUS: 1:loading, 0:done.
 */
#define E2PROM_CSR            0x0004
#define E2PROM_CSR_DATA_CLOCK        FIELD32(0x00000001)
#define E2PROM_CSR_CHIP_SELECT        FIELD32(0x00000002)
#define E2PROM_CSR_DATA_IN        FIELD32(0x00000004)
#define E2PROM_CSR_DATA_OUT        FIELD32(0x00000008)
#define E2PROM_CSR_TYPE            FIELD32(0x00000030)
#define E2PROM_CSR_LOAD_STATUS        FIELD32(0x00000040)
#define E2PROM_CSR_RELOAD        FIELD32(0x00000080)
 
/*
 * CMB_CTRL_CFG
 */
#define CMB_CTRL        0x0020
#define AUX_OPT_BIT0        FIELD32(0x00000001)
#define AUX_OPT_BIT1        FIELD32(0x00000002)
#define AUX_OPT_BIT2        FIELD32(0x00000004)
#define AUX_OPT_BIT3        FIELD32(0x00000008)
#define AUX_OPT_BIT4        FIELD32(0x00000010)
#define AUX_OPT_BIT5        FIELD32(0x00000020)
#define AUX_OPT_BIT6        FIELD32(0x00000040)
#define AUX_OPT_BIT7        FIELD32(0x00000080)
#define AUX_OPT_BIT8        FIELD32(0x00000100)
#define AUX_OPT_BIT9        FIELD32(0x00000200)
#define AUX_OPT_BIT10        FIELD32(0x00000400)
#define AUX_OPT_BIT11        FIELD32(0x00000800)
#define AUX_OPT_BIT12        FIELD32(0x00001000)
#define AUX_OPT_BIT13        FIELD32(0x00002000)
#define AUX_OPT_BIT14        FIELD32(0x00004000)
#define AUX_OPT_BIT15        FIELD32(0x00008000)
#define LDO25_LEVEL        FIELD32(0x00030000)
#define LDO25_LARGEA        FIELD32(0x00040000)
#define LDO25_FRC_ON        FIELD32(0x00080000)
#define CMB_RSV            FIELD32(0x00300000)
#define XTAL_RDY        FIELD32(0x00400000)
#define PLL_LD            FIELD32(0x00800000)
#define LDO_CORE_LEVEL        FIELD32(0x0F000000)
#define LDO_BGSEL        FIELD32(0x30000000)
#define LDO3_EN            FIELD32(0x40000000)
#define LDO0_EN            FIELD32(0x80000000)
 
/*
 * EFUSE_CSR_3290: RT3290 EEPROM
 */
#define EFUSE_CTRL_3290            0x0024
 
/*
 * EFUSE_DATA3 of 3290
 */
#define EFUSE_DATA3_3290        0x0028
 
/*
 * EFUSE_DATA2 of 3290
 */
#define EFUSE_DATA2_3290        0x002c
 
/*
 * EFUSE_DATA1 of 3290
 */
#define EFUSE_DATA1_3290        0x0030
 
/*
 * EFUSE_DATA0 of 3290
 */
#define EFUSE_DATA0_3290        0x0034
 
/*
 * OSC_CTRL_CFG
 * Ring oscillator configuration
 */
#define OSC_CTRL        0x0038
#define OSC_REF_CYCLE        FIELD32(0x00001fff)
#define OSC_RSV            FIELD32(0x0000e000)
#define OSC_CAL_CNT        FIELD32(0x0fff0000)
#define OSC_CAL_ACK        FIELD32(0x10000000)
#define OSC_CLK_32K_VLD        FIELD32(0x20000000)
#define OSC_CAL_REQ        FIELD32(0x40000000)
#define OSC_ROSC_EN        FIELD32(0x80000000)
 
/*
 * COEX_CFG_0
 */
#define COEX_CFG0        0x0040
#define COEX_CFG_ANT        FIELD32(0xff000000)
/*
 * COEX_CFG_1
 */
#define COEX_CFG1        0x0044
 
/*
 * COEX_CFG_2
 */
#define COEX_CFG2        0x0048
#define BT_COEX_CFG1        FIELD32(0xff000000)
#define BT_COEX_CFG0        FIELD32(0x00ff0000)
#define WL_COEX_CFG1        FIELD32(0x0000ff00)
#define WL_COEX_CFG0        FIELD32(0x000000ff)
/*
 * PLL_CTRL_CFG
 * PLL configuration register
 */
#define PLL_CTRL        0x0050
#define PLL_RESERVED_INPUT1    FIELD32(0x000000ff)
#define PLL_RESERVED_INPUT2    FIELD32(0x0000ff00)
#define PLL_CONTROL        FIELD32(0x00070000)
#define PLL_LPF_R1        FIELD32(0x00080000)
#define PLL_LPF_C1_CTRL        FIELD32(0x00300000)
#define PLL_LPF_C2_CTRL        FIELD32(0x00c00000)
#define PLL_CP_CURRENT_CTRL    FIELD32(0x03000000)
#define PLL_PFD_DELAY_CTRL    FIELD32(0x0c000000)
#define PLL_LOCK_CTRL        FIELD32(0x70000000)
#define PLL_VBGBK_EN        FIELD32(0x80000000)
 
 
/*
 * WLAN_CTRL_CFG
 * RT3290 wlan configuration
 */
#define WLAN_FUN_CTRL            0x0080
#define WLAN_EN                FIELD32(0x00000001)
#define WLAN_CLK_EN            FIELD32(0x00000002)
#define WLAN_RSV1            FIELD32(0x00000004)
#define WLAN_RESET            FIELD32(0x00000008)
#define PCIE_APP0_CLK_REQ        FIELD32(0x00000010)
#define FRC_WL_ANT_SET            FIELD32(0x00000020)
#define INV_TR_SW0            FIELD32(0x00000040)
#define WLAN_GPIO_IN_BIT0        FIELD32(0x00000100)
#define WLAN_GPIO_IN_BIT1        FIELD32(0x00000200)
#define WLAN_GPIO_IN_BIT2        FIELD32(0x00000400)
#define WLAN_GPIO_IN_BIT3        FIELD32(0x00000800)
#define WLAN_GPIO_IN_BIT4        FIELD32(0x00001000)
#define WLAN_GPIO_IN_BIT5        FIELD32(0x00002000)
#define WLAN_GPIO_IN_BIT6        FIELD32(0x00004000)
#define WLAN_GPIO_IN_BIT7        FIELD32(0x00008000)
#define WLAN_GPIO_IN_BIT_ALL        FIELD32(0x0000ff00)
#define WLAN_GPIO_OUT_BIT0        FIELD32(0x00010000)
#define WLAN_GPIO_OUT_BIT1        FIELD32(0x00020000)
#define WLAN_GPIO_OUT_BIT2        FIELD32(0x00040000)
#define WLAN_GPIO_OUT_BIT3        FIELD32(0x00050000)
#define WLAN_GPIO_OUT_BIT4        FIELD32(0x00100000)
#define WLAN_GPIO_OUT_BIT5        FIELD32(0x00200000)
#define WLAN_GPIO_OUT_BIT6        FIELD32(0x00400000)
#define WLAN_GPIO_OUT_BIT7        FIELD32(0x00800000)
#define WLAN_GPIO_OUT_BIT_ALL        FIELD32(0x00ff0000)
#define WLAN_GPIO_OUT_OE_BIT0        FIELD32(0x01000000)
#define WLAN_GPIO_OUT_OE_BIT1        FIELD32(0x02000000)
#define WLAN_GPIO_OUT_OE_BIT2        FIELD32(0x04000000)
#define WLAN_GPIO_OUT_OE_BIT3        FIELD32(0x08000000)
#define WLAN_GPIO_OUT_OE_BIT4        FIELD32(0x10000000)
#define WLAN_GPIO_OUT_OE_BIT5        FIELD32(0x20000000)
#define WLAN_GPIO_OUT_OE_BIT6        FIELD32(0x40000000)
#define WLAN_GPIO_OUT_OE_BIT7        FIELD32(0x80000000)
#define WLAN_GPIO_OUT_OE_BIT_ALL    FIELD32(0xff000000)
 
/*
 * AUX_CTRL: Aux/PCI-E related configuration
 */
#define AUX_CTRL            0x10c
#define AUX_CTRL_WAKE_PCIE_EN        FIELD32(0x00000002)
#define AUX_CTRL_FORCE_PCIE_CLK        FIELD32(0x00000400)
 
/*
 * OPT_14: Unknown register used by rt3xxx devices.
 */
#define OPT_14_CSR            0x0114
#define OPT_14_CSR_BIT0            FIELD32(0x00000001)
 
/*
 * INT_SOURCE_CSR: Interrupt source register.
 * Write one to clear corresponding bit.
 * TX_FIFO_STATUS: FIFO Statistics is full, sw should read TX_STA_FIFO
 */
#define INT_SOURCE_CSR            0x0200
#define INT_SOURCE_CSR_RXDELAYINT    FIELD32(0x00000001)
#define INT_SOURCE_CSR_TXDELAYINT    FIELD32(0x00000002)
#define INT_SOURCE_CSR_RX_DONE        FIELD32(0x00000004)
#define INT_SOURCE_CSR_AC0_DMA_DONE    FIELD32(0x00000008)
#define INT_SOURCE_CSR_AC1_DMA_DONE    FIELD32(0x00000010)
#define INT_SOURCE_CSR_AC2_DMA_DONE    FIELD32(0x00000020)
#define INT_SOURCE_CSR_AC3_DMA_DONE    FIELD32(0x00000040)
#define INT_SOURCE_CSR_HCCA_DMA_DONE    FIELD32(0x00000080)
#define INT_SOURCE_CSR_MGMT_DMA_DONE    FIELD32(0x00000100)
#define INT_SOURCE_CSR_MCU_COMMAND    FIELD32(0x00000200)
#define INT_SOURCE_CSR_RXTX_COHERENT    FIELD32(0x00000400)
#define INT_SOURCE_CSR_TBTT        FIELD32(0x00000800)
#define INT_SOURCE_CSR_PRE_TBTT        FIELD32(0x00001000)
#define INT_SOURCE_CSR_TX_FIFO_STATUS    FIELD32(0x00002000)
#define INT_SOURCE_CSR_AUTO_WAKEUP    FIELD32(0x00004000)
#define INT_SOURCE_CSR_GPTIMER        FIELD32(0x00008000)
#define INT_SOURCE_CSR_RX_COHERENT    FIELD32(0x00010000)
#define INT_SOURCE_CSR_TX_COHERENT    FIELD32(0x00020000)
 
/*
 * INT_MASK_CSR: Interrupt MASK register. 1: the interrupt is mask OFF.
 */
#define INT_MASK_CSR            0x0204
#define INT_MASK_CSR_RXDELAYINT        FIELD32(0x00000001)
#define INT_MASK_CSR_TXDELAYINT        FIELD32(0x00000002)
#define INT_MASK_CSR_RX_DONE        FIELD32(0x00000004)
#define INT_MASK_CSR_AC0_DMA_DONE    FIELD32(0x00000008)
#define INT_MASK_CSR_AC1_DMA_DONE    FIELD32(0x00000010)
#define INT_MASK_CSR_AC2_DMA_DONE    FIELD32(0x00000020)
#define INT_MASK_CSR_AC3_DMA_DONE    FIELD32(0x00000040)
#define INT_MASK_CSR_HCCA_DMA_DONE    FIELD32(0x00000080)
#define INT_MASK_CSR_MGMT_DMA_DONE    FIELD32(0x00000100)
#define INT_MASK_CSR_MCU_COMMAND    FIELD32(0x00000200)
#define INT_MASK_CSR_RXTX_COHERENT    FIELD32(0x00000400)
#define INT_MASK_CSR_TBTT        FIELD32(0x00000800)
#define INT_MASK_CSR_PRE_TBTT        FIELD32(0x00001000)
#define INT_MASK_CSR_TX_FIFO_STATUS    FIELD32(0x00002000)
#define INT_MASK_CSR_AUTO_WAKEUP    FIELD32(0x00004000)
#define INT_MASK_CSR_GPTIMER        FIELD32(0x00008000)
#define INT_MASK_CSR_RX_COHERENT    FIELD32(0x00010000)
#define INT_MASK_CSR_TX_COHERENT    FIELD32(0x00020000)
 
/*
 * WPDMA_GLO_CFG
 */
#define WPDMA_GLO_CFG             0x0208
#define WPDMA_GLO_CFG_ENABLE_TX_DMA    FIELD32(0x00000001)
#define WPDMA_GLO_CFG_TX_DMA_BUSY        FIELD32(0x00000002)
#define WPDMA_GLO_CFG_ENABLE_RX_DMA    FIELD32(0x00000004)
#define WPDMA_GLO_CFG_RX_DMA_BUSY    FIELD32(0x00000008)
#define WPDMA_GLO_CFG_WP_DMA_BURST_SIZE    FIELD32(0x00000030)
#define WPDMA_GLO_CFG_TX_WRITEBACK_DONE    FIELD32(0x00000040)
#define WPDMA_GLO_CFG_BIG_ENDIAN    FIELD32(0x00000080)
#define WPDMA_GLO_CFG_RX_HDR_SCATTER    FIELD32(0x0000ff00)
#define WPDMA_GLO_CFG_HDR_SEG_LEN    FIELD32(0xffff0000)
 
/*
 * WPDMA_RST_IDX
 */
#define WPDMA_RST_IDX             0x020c
#define WPDMA_RST_IDX_DTX_IDX0        FIELD32(0x00000001)
#define WPDMA_RST_IDX_DTX_IDX1        FIELD32(0x00000002)
#define WPDMA_RST_IDX_DTX_IDX2        FIELD32(0x00000004)
#define WPDMA_RST_IDX_DTX_IDX3        FIELD32(0x00000008)
#define WPDMA_RST_IDX_DTX_IDX4        FIELD32(0x00000010)
#define WPDMA_RST_IDX_DTX_IDX5        FIELD32(0x00000020)
#define WPDMA_RST_IDX_DRX_IDX0        FIELD32(0x00010000)
 
/*
 * DELAY_INT_CFG
 */
#define DELAY_INT_CFG            0x0210
#define DELAY_INT_CFG_RXMAX_PTIME    FIELD32(0x000000ff)
#define DELAY_INT_CFG_RXMAX_PINT    FIELD32(0x00007f00)
#define DELAY_INT_CFG_RXDLY_INT_EN    FIELD32(0x00008000)
#define DELAY_INT_CFG_TXMAX_PTIME    FIELD32(0x00ff0000)
#define DELAY_INT_CFG_TXMAX_PINT    FIELD32(0x7f000000)
#define DELAY_INT_CFG_TXDLY_INT_EN    FIELD32(0x80000000)
 
/*
 * WMM_AIFSN_CFG: Aifsn for each EDCA AC
 * AIFSN0: AC_VO
 * AIFSN1: AC_VI
 * AIFSN2: AC_BE
 * AIFSN3: AC_BK
 */
#define WMM_AIFSN_CFG            0x0214
#define WMM_AIFSN_CFG_AIFSN0        FIELD32(0x0000000f)
#define WMM_AIFSN_CFG_AIFSN1        FIELD32(0x000000f0)
#define WMM_AIFSN_CFG_AIFSN2        FIELD32(0x00000f00)
#define WMM_AIFSN_CFG_AIFSN3        FIELD32(0x0000f000)
 
/*
 * WMM_CWMIN_CSR: CWmin for each EDCA AC
 * CWMIN0: AC_VO
 * CWMIN1: AC_VI
 * CWMIN2: AC_BE
 * CWMIN3: AC_BK
 */
#define WMM_CWMIN_CFG            0x0218
#define WMM_CWMIN_CFG_CWMIN0        FIELD32(0x0000000f)
#define WMM_CWMIN_CFG_CWMIN1        FIELD32(0x000000f0)
#define WMM_CWMIN_CFG_CWMIN2        FIELD32(0x00000f00)
#define WMM_CWMIN_CFG_CWMIN3        FIELD32(0x0000f000)
 
/*
 * WMM_CWMAX_CSR: CWmax for each EDCA AC
 * CWMAX0: AC_VO
 * CWMAX1: AC_VI
 * CWMAX2: AC_BE
 * CWMAX3: AC_BK
 */
#define WMM_CWMAX_CFG            0x021c
#define WMM_CWMAX_CFG_CWMAX0        FIELD32(0x0000000f)
#define WMM_CWMAX_CFG_CWMAX1        FIELD32(0x000000f0)
#define WMM_CWMAX_CFG_CWMAX2        FIELD32(0x00000f00)
#define WMM_CWMAX_CFG_CWMAX3        FIELD32(0x0000f000)
 
/*
 * AC_TXOP0: AC_VO/AC_VI TXOP register
 * AC0TXOP: AC_VO in unit of 32us
 * AC1TXOP: AC_VI in unit of 32us
 */
#define WMM_TXOP0_CFG            0x0220
#define WMM_TXOP0_CFG_AC0TXOP        FIELD32(0x0000ffff)
#define WMM_TXOP0_CFG_AC1TXOP        FIELD32(0xffff0000)
 
/*
 * AC_TXOP1: AC_BE/AC_BK TXOP register
 * AC2TXOP: AC_BE in unit of 32us
 * AC3TXOP: AC_BK in unit of 32us
 */
#define WMM_TXOP1_CFG            0x0224
#define WMM_TXOP1_CFG_AC2TXOP        FIELD32(0x0000ffff)
#define WMM_TXOP1_CFG_AC3TXOP        FIELD32(0xffff0000)
 
/*
 * GPIO_CTRL:
 *    GPIO_CTRL_VALx: GPIO value
 *    GPIO_CTRL_DIRx: GPIO direction: 0 = output; 1 = input
 */
#define GPIO_CTRL            0x0228
#define GPIO_CTRL_VAL0            FIELD32(0x00000001)
#define GPIO_CTRL_VAL1            FIELD32(0x00000002)
#define GPIO_CTRL_VAL2            FIELD32(0x00000004)
#define GPIO_CTRL_VAL3            FIELD32(0x00000008)
#define GPIO_CTRL_VAL4            FIELD32(0x00000010)
#define GPIO_CTRL_VAL5            FIELD32(0x00000020)
#define GPIO_CTRL_VAL6            FIELD32(0x00000040)
#define GPIO_CTRL_VAL7            FIELD32(0x00000080)
#define GPIO_CTRL_DIR0            FIELD32(0x00000100)
#define GPIO_CTRL_DIR1            FIELD32(0x00000200)
#define GPIO_CTRL_DIR2            FIELD32(0x00000400)
#define GPIO_CTRL_DIR3            FIELD32(0x00000800)
#define GPIO_CTRL_DIR4            FIELD32(0x00001000)
#define GPIO_CTRL_DIR5            FIELD32(0x00002000)
#define GPIO_CTRL_DIR6            FIELD32(0x00004000)
#define GPIO_CTRL_DIR7            FIELD32(0x00008000)
#define GPIO_CTRL_VAL8            FIELD32(0x00010000)
#define GPIO_CTRL_VAL9            FIELD32(0x00020000)
#define GPIO_CTRL_VAL10            FIELD32(0x00040000)
#define GPIO_CTRL_DIR8            FIELD32(0x01000000)
#define GPIO_CTRL_DIR9            FIELD32(0x02000000)
#define GPIO_CTRL_DIR10            FIELD32(0x04000000)
 
/*
 * MCU_CMD_CFG
 */
#define MCU_CMD_CFG            0x022c
 
/*
 * AC_VO register offsets
 */
#define TX_BASE_PTR0            0x0230
#define TX_MAX_CNT0            0x0234
#define TX_CTX_IDX0            0x0238
#define TX_DTX_IDX0            0x023c
 
/*
 * AC_VI register offsets
 */
#define TX_BASE_PTR1            0x0240
#define TX_MAX_CNT1            0x0244
#define TX_CTX_IDX1            0x0248
#define TX_DTX_IDX1            0x024c
 
/*
 * AC_BE register offsets
 */
#define TX_BASE_PTR2            0x0250
#define TX_MAX_CNT2            0x0254
#define TX_CTX_IDX2            0x0258
#define TX_DTX_IDX2            0x025c
 
/*
 * AC_BK register offsets
 */
#define TX_BASE_PTR3            0x0260
#define TX_MAX_CNT3            0x0264
#define TX_CTX_IDX3            0x0268
#define TX_DTX_IDX3            0x026c
 
/*
 * HCCA register offsets
 */
#define TX_BASE_PTR4            0x0270
#define TX_MAX_CNT4            0x0274
#define TX_CTX_IDX4            0x0278
#define TX_DTX_IDX4            0x027c
 
/*
 * MGMT register offsets
 */
#define TX_BASE_PTR5            0x0280
#define TX_MAX_CNT5            0x0284
#define TX_CTX_IDX5            0x0288
#define TX_DTX_IDX5            0x028c
 
/*
 * RX register offsets
 */
#define RX_BASE_PTR            0x0290
#define RX_MAX_CNT            0x0294
#define RX_CRX_IDX            0x0298
#define RX_DRX_IDX            0x029c
 
/*
 * USB_DMA_CFG
 * RX_BULK_AGG_TIMEOUT: Rx Bulk Aggregation TimeOut in unit of 33ns.
 * RX_BULK_AGG_LIMIT: Rx Bulk Aggregation Limit in unit of 256 bytes.
 * PHY_CLEAR: phy watch dog enable.
 * TX_CLEAR: Clear USB DMA TX path.
 * TXOP_HALT: Halt TXOP count down when TX buffer is full.
 * RX_BULK_AGG_EN: Enable Rx Bulk Aggregation.
 * RX_BULK_EN: Enable USB DMA Rx.
 * TX_BULK_EN: Enable USB DMA Tx.
 * EP_OUT_VALID: OUT endpoint data valid.
 * RX_BUSY: USB DMA RX FSM busy.
 * TX_BUSY: USB DMA TX FSM busy.
 */
#define USB_DMA_CFG            0x02a0
#define USB_DMA_CFG_RX_BULK_AGG_TIMEOUT    FIELD32(0x000000ff)
#define USB_DMA_CFG_RX_BULK_AGG_LIMIT    FIELD32(0x0000ff00)
#define USB_DMA_CFG_PHY_CLEAR        FIELD32(0x00010000)
#define USB_DMA_CFG_TX_CLEAR        FIELD32(0x00080000)
#define USB_DMA_CFG_TXOP_HALT        FIELD32(0x00100000)
#define USB_DMA_CFG_RX_BULK_AGG_EN    FIELD32(0x00200000)
#define USB_DMA_CFG_RX_BULK_EN        FIELD32(0x00400000)
#define USB_DMA_CFG_TX_BULK_EN        FIELD32(0x00800000)
#define USB_DMA_CFG_EP_OUT_VALID    FIELD32(0x3f000000)
#define USB_DMA_CFG_RX_BUSY        FIELD32(0x40000000)
#define USB_DMA_CFG_TX_BUSY        FIELD32(0x80000000)
 
/*
 * US_CYC_CNT
 * BT_MODE_EN: Bluetooth mode enable
 * CLOCK CYCLE: Clock cycle count in 1us.
 * PCI:0x21, PCIE:0x7d, USB:0x1e
 */
#define US_CYC_CNT            0x02a4
#define US_CYC_CNT_BT_MODE_EN        FIELD32(0x00000100)
#define US_CYC_CNT_CLOCK_CYCLE        FIELD32(0x000000ff)
 
/*
 * PBF_SYS_CTRL
 * HOST_RAM_WRITE: enable Host program ram write selection
 */
#define PBF_SYS_CTRL            0x0400
#define PBF_SYS_CTRL_READY        FIELD32(0x00000080)
#define PBF_SYS_CTRL_HOST_RAM_WRITE    FIELD32(0x00010000)
 
/*
 * HOST-MCU shared memory
 */
#define HOST_CMD_CSR            0x0404
#define HOST_CMD_CSR_HOST_COMMAND    FIELD32(0x000000ff)
 
/*
 * PBF registers
 * Most are for debug. Driver doesn't touch PBF register.
 */
#define PBF_CFG                0x0408
#define PBF_MAX_PCNT            0x040c
#define PBF_CTRL            0x0410
#define PBF_INT_STA            0x0414
#define PBF_INT_ENA            0x0418
 
/*
 * BCN_OFFSET0:
 */
#define BCN_OFFSET0            0x042c
#define BCN_OFFSET0_BCN0        FIELD32(0x000000ff)
#define BCN_OFFSET0_BCN1        FIELD32(0x0000ff00)
#define BCN_OFFSET0_BCN2        FIELD32(0x00ff0000)
#define BCN_OFFSET0_BCN3        FIELD32(0xff000000)
 
/*
 * BCN_OFFSET1:
 */
#define BCN_OFFSET1            0x0430
#define BCN_OFFSET1_BCN4        FIELD32(0x000000ff)
#define BCN_OFFSET1_BCN5        FIELD32(0x0000ff00)
#define BCN_OFFSET1_BCN6        FIELD32(0x00ff0000)
#define BCN_OFFSET1_BCN7        FIELD32(0xff000000)
 
/*
 * TXRXQ_PCNT: PBF register
 * PCNT_TX0Q: Page count for TX hardware queue 0
 * PCNT_TX1Q: Page count for TX hardware queue 1
 * PCNT_TX2Q: Page count for TX hardware queue 2
 * PCNT_RX0Q: Page count for RX hardware queue
 */
#define TXRXQ_PCNT            0x0438
#define TXRXQ_PCNT_TX0Q            FIELD32(0x000000ff)
#define TXRXQ_PCNT_TX1Q            FIELD32(0x0000ff00)
#define TXRXQ_PCNT_TX2Q            FIELD32(0x00ff0000)
#define TXRXQ_PCNT_RX0Q            FIELD32(0xff000000)
 
/*
 * PBF register
 * Debug. Driver doesn't touch PBF register.
 */
#define PBF_DBG                0x043c
 
/*
 * RF registers
 */
#define    RF_CSR_CFG            0x0500
#define RF_CSR_CFG_DATA            FIELD32(0x000000ff)
#define RF_CSR_CFG_REGNUM        FIELD32(0x00003f00)
#define RF_CSR_CFG_WRITE        FIELD32(0x00010000)
#define RF_CSR_CFG_BUSY            FIELD32(0x00020000)
 
/*
 * MT7620 RF registers (reversed order)
 */
#define RF_CSR_CFG_DATA_MT7620        FIELD32(0x0000ff00)
#define RF_CSR_CFG_REGNUM_MT7620    FIELD32(0x03ff0000)
#define RF_CSR_CFG_WRITE_MT7620        FIELD32(0x00000010)
#define RF_CSR_CFG_BUSY_MT7620        FIELD32(0x00000001)
 
/* undocumented registers for calibration of new MAC */
#define RF_CONTROL0            0x0518
#define RF_BYPASS0            0x051c
#define RF_CONTROL1            0x0520
#define RF_BYPASS1            0x0524
#define RF_CONTROL2            0x0528
#define RF_BYPASS2            0x052c
#define RF_CONTROL3            0x0530
#define RF_BYPASS3            0x0534
 
/*
 * EFUSE_CSR: RT30x0 EEPROM
 */
#define EFUSE_CTRL            0x0580
#define EFUSE_CTRL_ADDRESS_IN        FIELD32(0x03fe0000)
#define EFUSE_CTRL_MODE            FIELD32(0x000000c0)
#define EFUSE_CTRL_KICK            FIELD32(0x40000000)
#define EFUSE_CTRL_PRESENT        FIELD32(0x80000000)
 
/*
 * EFUSE_DATA0
 */
#define EFUSE_DATA0            0x0590
 
/*
 * EFUSE_DATA1
 */
#define EFUSE_DATA1            0x0594
 
/*
 * EFUSE_DATA2
 */
#define EFUSE_DATA2            0x0598
 
/*
 * EFUSE_DATA3
 */
#define EFUSE_DATA3            0x059c
 
/*
 * LDO_CFG0
 */
#define LDO_CFG0            0x05d4
#define LDO_CFG0_DELAY3            FIELD32(0x000000ff)
#define LDO_CFG0_DELAY2            FIELD32(0x0000ff00)
#define LDO_CFG0_DELAY1            FIELD32(0x00ff0000)
#define LDO_CFG0_BGSEL            FIELD32(0x03000000)
#define LDO_CFG0_LDO_CORE_VLEVEL    FIELD32(0x1c000000)
#define LD0_CFG0_LDO25_LEVEL        FIELD32(0x60000000)
#define LDO_CFG0_LDO25_LARGEA        FIELD32(0x80000000)
 
/*
 * GPIO_SWITCH
 */
#define GPIO_SWITCH            0x05dc
#define GPIO_SWITCH_0            FIELD32(0x00000001)
#define GPIO_SWITCH_1            FIELD32(0x00000002)
#define GPIO_SWITCH_2            FIELD32(0x00000004)
#define GPIO_SWITCH_3            FIELD32(0x00000008)
#define GPIO_SWITCH_4            FIELD32(0x00000010)
#define GPIO_SWITCH_5            FIELD32(0x00000020)
#define GPIO_SWITCH_6            FIELD32(0x00000040)
#define GPIO_SWITCH_7            FIELD32(0x00000080)
 
/*
 * FIXME: where the DEBUG_INDEX name come from?
 */
#define MAC_DEBUG_INDEX            0x05e8
#define MAC_DEBUG_INDEX_XTAL        FIELD32(0x80000000)
 
/*
 * MAC Control/Status Registers(CSR).
 * Some values are set in TU, whereas 1 TU == 1024 us.
 */
 
/*
 * MAC_CSR0: ASIC revision number.
 * ASIC_REV: 0
 * ASIC_VER: 2860 or 2870
 */
#define MAC_CSR0            0x1000
#define MAC_CSR0_REVISION        FIELD32(0x0000ffff)
#define MAC_CSR0_CHIPSET        FIELD32(0xffff0000)
 
/*
 * MAC_SYS_CTRL:
 */
#define MAC_SYS_CTRL            0x1004
#define MAC_SYS_CTRL_RESET_CSR        FIELD32(0x00000001)
#define MAC_SYS_CTRL_RESET_BBP        FIELD32(0x00000002)
#define MAC_SYS_CTRL_ENABLE_TX        FIELD32(0x00000004)
#define MAC_SYS_CTRL_ENABLE_RX        FIELD32(0x00000008)
#define MAC_SYS_CTRL_CONTINUOUS_TX    FIELD32(0x00000010)
#define MAC_SYS_CTRL_LOOPBACK        FIELD32(0x00000020)
#define MAC_SYS_CTRL_WLAN_HALT        FIELD32(0x00000040)
#define MAC_SYS_CTRL_RX_TIMESTAMP    FIELD32(0x00000080)
 
/*
 * MAC_ADDR_DW0: STA MAC register 0
 */
#define MAC_ADDR_DW0            0x1008
#define MAC_ADDR_DW0_BYTE0        FIELD32(0x000000ff)
#define MAC_ADDR_DW0_BYTE1        FIELD32(0x0000ff00)
#define MAC_ADDR_DW0_BYTE2        FIELD32(0x00ff0000)
#define MAC_ADDR_DW0_BYTE3        FIELD32(0xff000000)
 
/*
 * MAC_ADDR_DW1: STA MAC register 1
 * UNICAST_TO_ME_MASK:
 * Used to mask off bits from byte 5 of the MAC address
 * to determine the UNICAST_TO_ME bit for RX frames.
 * The full mask is complemented by BSS_ID_MASK:
 *    MASK = BSS_ID_MASK & UNICAST_TO_ME_MASK
 */
#define MAC_ADDR_DW1            0x100c
#define MAC_ADDR_DW1_BYTE4        FIELD32(0x000000ff)
#define MAC_ADDR_DW1_BYTE5        FIELD32(0x0000ff00)
#define MAC_ADDR_DW1_UNICAST_TO_ME_MASK    FIELD32(0x00ff0000)
 
/*
 * MAC_BSSID_DW0: BSSID register 0
 */
#define MAC_BSSID_DW0            0x1010
#define MAC_BSSID_DW0_BYTE0        FIELD32(0x000000ff)
#define MAC_BSSID_DW0_BYTE1        FIELD32(0x0000ff00)
#define MAC_BSSID_DW0_BYTE2        FIELD32(0x00ff0000)
#define MAC_BSSID_DW0_BYTE3        FIELD32(0xff000000)
 
/*
 * MAC_BSSID_DW1: BSSID register 1
 * BSS_ID_MASK:
 *     0: 1-BSSID mode (BSS index = 0)
 *     1: 2-BSSID mode (BSS index: Byte5, bit 0)
 *     2: 4-BSSID mode (BSS index: byte5, bit 0 - 1)
 *     3: 8-BSSID mode (BSS index: byte5, bit 0 - 2)
 * This mask is used to mask off bits 0, 1 and 2 of byte 5 of the
 * BSSID. This will make sure that those bits will be ignored
 * when determining the MY_BSS of RX frames.
 */
#define MAC_BSSID_DW1            0x1014
#define MAC_BSSID_DW1_BYTE4        FIELD32(0x000000ff)
#define MAC_BSSID_DW1_BYTE5        FIELD32(0x0000ff00)
#define MAC_BSSID_DW1_BSS_ID_MASK    FIELD32(0x00030000)
#define MAC_BSSID_DW1_BSS_BCN_NUM    FIELD32(0x001c0000)
 
/*
 * MAX_LEN_CFG: Maximum frame length register.
 * MAX_MPDU: rt2860b max 16k bytes
 * MAX_PSDU: Maximum PSDU length
 *    (power factor) 0:2^13, 1:2^14, 2:2^15, 3:2^16
 */
#define MAX_LEN_CFG            0x1018
#define MAX_LEN_CFG_MAX_MPDU        FIELD32(0x00000fff)
#define MAX_LEN_CFG_MAX_PSDU        FIELD32(0x00003000)
#define MAX_LEN_CFG_MIN_PSDU        FIELD32(0x0000c000)
#define MAX_LEN_CFG_MIN_MPDU        FIELD32(0x000f0000)
 
/*
 * BBP_CSR_CFG: BBP serial control register
 * VALUE: Register value to program into BBP
 * REG_NUM: Selected BBP register
 * READ_CONTROL: 0 write BBP, 1 read BBP
 * BUSY: ASIC is busy executing BBP commands
 * BBP_PAR_DUR: 0 4 MAC clocks, 1 8 MAC clocks
 * BBP_RW_MODE: 0 serial, 1 parallel
 */
#define BBP_CSR_CFG            0x101c
#define BBP_CSR_CFG_VALUE        FIELD32(0x000000ff)
#define BBP_CSR_CFG_REGNUM        FIELD32(0x0000ff00)
#define BBP_CSR_CFG_READ_CONTROL    FIELD32(0x00010000)
#define BBP_CSR_CFG_BUSY        FIELD32(0x00020000)
#define BBP_CSR_CFG_BBP_PAR_DUR        FIELD32(0x00040000)
#define BBP_CSR_CFG_BBP_RW_MODE        FIELD32(0x00080000)
 
/*
 * RF_CSR_CFG0: RF control register
 * REGID_AND_VALUE: Register value to program into RF
 * BITWIDTH: Selected RF register
 * STANDBYMODE: 0 high when standby, 1 low when standby
 * SEL: 0 RF_LE0 activate, 1 RF_LE1 activate
 * BUSY: ASIC is busy executing RF commands
 */
#define RF_CSR_CFG0            0x1020
#define RF_CSR_CFG0_REGID_AND_VALUE    FIELD32(0x00ffffff)
#define RF_CSR_CFG0_BITWIDTH        FIELD32(0x1f000000)
#define RF_CSR_CFG0_REG_VALUE_BW    FIELD32(0x1fffffff)
#define RF_CSR_CFG0_STANDBYMODE        FIELD32(0x20000000)
#define RF_CSR_CFG0_SEL            FIELD32(0x40000000)
#define RF_CSR_CFG0_BUSY        FIELD32(0x80000000)
 
/*
 * RF_CSR_CFG1: RF control register
 * REGID_AND_VALUE: Register value to program into RF
 * RFGAP: Gap between BB_CONTROL_RF and RF_LE
 *        0: 3 system clock cycle (37.5usec)
 *        1: 5 system clock cycle (62.5usec)
 */
#define RF_CSR_CFG1            0x1024
#define RF_CSR_CFG1_REGID_AND_VALUE    FIELD32(0x00ffffff)
#define RF_CSR_CFG1_RFGAP        FIELD32(0x1f000000)
 
/*
 * RF_CSR_CFG2: RF control register
 * VALUE: Register value to program into RF
 */
#define RF_CSR_CFG2            0x1028
#define RF_CSR_CFG2_VALUE        FIELD32(0x00ffffff)
 
/*
 * LED_CFG: LED control
 * ON_PERIOD: LED active time (ms) during TX (only used for LED mode 1)
 * OFF_PERIOD: LED inactive time (ms) during TX (only used for LED mode 1)
 * SLOW_BLINK_PERIOD: LED blink interval in seconds (only used for LED mode 2)
 * color LED's:
 *   0: off
 *   1: blinking upon TX2
 *   2: periodic slow blinking
 *   3: always on
 * LED polarity:
 *   0: active low
 *   1: active high
 */
#define LED_CFG                0x102c
#define LED_CFG_ON_PERIOD        FIELD32(0x000000ff)
#define LED_CFG_OFF_PERIOD        FIELD32(0x0000ff00)
#define LED_CFG_SLOW_BLINK_PERIOD    FIELD32(0x003f0000)
#define LED_CFG_R_LED_MODE        FIELD32(0x03000000)
#define LED_CFG_G_LED_MODE        FIELD32(0x0c000000)
#define LED_CFG_Y_LED_MODE        FIELD32(0x30000000)
#define LED_CFG_LED_POLAR        FIELD32(0x40000000)
 
/*
 * AMPDU_BA_WINSIZE: Force BlockAck window size
 * FORCE_WINSIZE_ENABLE:
 *   0: Disable forcing of BlockAck window size
 *   1: Enable forcing of BlockAck window size, overwrites values BlockAck
 *      window size values in the TXWI
 * FORCE_WINSIZE: BlockAck window size
 */
#define AMPDU_BA_WINSIZE        0x1040
#define AMPDU_BA_WINSIZE_FORCE_WINSIZE_ENABLE FIELD32(0x00000020)
#define AMPDU_BA_WINSIZE_FORCE_WINSIZE    FIELD32(0x0000001f)
 
/*
 * XIFS_TIME_CFG: MAC timing
 * CCKM_SIFS_TIME: unit 1us. Applied after CCK RX/TX
 * OFDM_SIFS_TIME: unit 1us. Applied after OFDM RX/TX
 * OFDM_XIFS_TIME: unit 1us. Applied after OFDM RX
 *    when MAC doesn't reference BBP signal BBRXEND
 * EIFS: unit 1us
 * BB_RXEND_ENABLE: reference RXEND signal to begin XIFS defer
 *
 */
#define XIFS_TIME_CFG            0x1100
#define XIFS_TIME_CFG_CCKM_SIFS_TIME    FIELD32(0x000000ff)
#define XIFS_TIME_CFG_OFDM_SIFS_TIME    FIELD32(0x0000ff00)
#define XIFS_TIME_CFG_OFDM_XIFS_TIME    FIELD32(0x000f0000)
#define XIFS_TIME_CFG_EIFS        FIELD32(0x1ff00000)
#define XIFS_TIME_CFG_BB_RXEND_ENABLE    FIELD32(0x20000000)
 
/*
 * BKOFF_SLOT_CFG:
 */
#define BKOFF_SLOT_CFG            0x1104
#define BKOFF_SLOT_CFG_SLOT_TIME    FIELD32(0x000000ff)
#define BKOFF_SLOT_CFG_CC_DELAY_TIME    FIELD32(0x0000ff00)
 
/*
 * NAV_TIME_CFG:
 */
#define NAV_TIME_CFG            0x1108
#define NAV_TIME_CFG_SIFS        FIELD32(0x000000ff)
#define NAV_TIME_CFG_SLOT_TIME        FIELD32(0x0000ff00)
#define NAV_TIME_CFG_EIFS        FIELD32(0x01ff0000)
#define NAV_TIME_ZERO_SIFS        FIELD32(0x02000000)
 
/*
 * CH_TIME_CFG: count as channel busy
 * EIFS_BUSY: Count EIFS as channel busy
 * NAV_BUSY: Count NAS as channel busy
 * RX_BUSY: Count RX as channel busy
 * TX_BUSY: Count TX as channel busy
 * TMR_EN: Enable channel statistics timer
 */
#define CH_TIME_CFG                 0x110c
#define CH_TIME_CFG_EIFS_BUSY        FIELD32(0x00000010)
#define CH_TIME_CFG_NAV_BUSY        FIELD32(0x00000008)
#define CH_TIME_CFG_RX_BUSY        FIELD32(0x00000004)
#define CH_TIME_CFG_TX_BUSY        FIELD32(0x00000002)
#define CH_TIME_CFG_TMR_EN        FIELD32(0x00000001)
 
/*
 * PBF_LIFE_TIMER: TX/RX MPDU timestamp timer (free run) Unit: 1us
 */
#define PBF_LIFE_TIMER                 0x1110
 
/*
 * BCN_TIME_CFG:
 * BEACON_INTERVAL: in unit of 1/16 TU
 * TSF_TICKING: Enable TSF auto counting
 * TSF_SYNC: Enable TSF sync, 00: disable, 01: infra mode, 10: ad-hoc mode
 * BEACON_GEN: Enable beacon generator
 */
#define BCN_TIME_CFG            0x1114
#define BCN_TIME_CFG_BEACON_INTERVAL    FIELD32(0x0000ffff)
#define BCN_TIME_CFG_TSF_TICKING    FIELD32(0x00010000)
#define BCN_TIME_CFG_TSF_SYNC        FIELD32(0x00060000)
#define BCN_TIME_CFG_TBTT_ENABLE    FIELD32(0x00080000)
#define BCN_TIME_CFG_BEACON_GEN        FIELD32(0x00100000)
#define BCN_TIME_CFG_TX_TIME_COMPENSATE    FIELD32(0xf0000000)
 
/*
 * TBTT_SYNC_CFG:
 * BCN_AIFSN: Beacon AIFSN after TBTT interrupt in slots
 * BCN_CWMIN: Beacon CWMin after TBTT interrupt in slots
 */
#define TBTT_SYNC_CFG            0x1118
#define TBTT_SYNC_CFG_TBTT_ADJUST    FIELD32(0x000000ff)
#define TBTT_SYNC_CFG_BCN_EXP_WIN    FIELD32(0x0000ff00)
#define TBTT_SYNC_CFG_BCN_AIFSN        FIELD32(0x000f0000)
#define TBTT_SYNC_CFG_BCN_CWMIN        FIELD32(0x00f00000)
 
/*
 * TSF_TIMER_DW0: Local lsb TSF timer, read-only
 */
#define TSF_TIMER_DW0            0x111c
#define TSF_TIMER_DW0_LOW_WORD        FIELD32(0xffffffff)
 
/*
 * TSF_TIMER_DW1: Local msb TSF timer, read-only
 */
#define TSF_TIMER_DW1            0x1120
#define TSF_TIMER_DW1_HIGH_WORD        FIELD32(0xffffffff)
 
/*
 * TBTT_TIMER: TImer remains till next TBTT, read-only
 */
#define TBTT_TIMER            0x1124
 
/*
 * INT_TIMER_CFG: timer configuration
 * PRE_TBTT_TIMER: leadtime to tbtt for pretbtt interrupt in units of 1/16 TU
 * GP_TIMER: period of general purpose timer in units of 1/16 TU
 */
#define INT_TIMER_CFG            0x1128
#define INT_TIMER_CFG_PRE_TBTT_TIMER    FIELD32(0x0000ffff)
#define INT_TIMER_CFG_GP_TIMER        FIELD32(0xffff0000)
 
/*
 * INT_TIMER_EN: GP-timer and pre-tbtt Int enable
 */
#define INT_TIMER_EN            0x112c
#define INT_TIMER_EN_PRE_TBTT_TIMER    FIELD32(0x00000001)
#define INT_TIMER_EN_GP_TIMER        FIELD32(0x00000002)
 
/*
 * CH_IDLE_STA: channel idle time (in us)
 */
#define CH_IDLE_STA            0x1130
 
/*
 * CH_BUSY_STA: channel busy time on primary channel (in us)
 */
#define CH_BUSY_STA            0x1134
 
/*
 * CH_BUSY_STA_SEC: channel busy time on secondary channel in HT40 mode (in us)
 */
#define CH_BUSY_STA_SEC            0x1138
 
/*
 * MAC_STATUS_CFG:
 * BBP_RF_BUSY: When set to 0, BBP and RF are stable.
 *    if 1 or higher one of the 2 registers is busy.
 */
#define MAC_STATUS_CFG            0x1200
#define MAC_STATUS_CFG_BBP_RF_BUSY    FIELD32(0x00000003)
 
/*
 * PWR_PIN_CFG:
 */
#define PWR_PIN_CFG            0x1204
 
/*
 * AUTOWAKEUP_CFG: Manual power control / status register
 * TBCN_BEFORE_WAKE: ForceWake has high privilege than PutToSleep when both set
 * AUTOWAKE: 0:sleep, 1:awake
 */
#define AUTOWAKEUP_CFG            0x1208
#define AUTOWAKEUP_CFG_AUTO_LEAD_TIME    FIELD32(0x000000ff)
#define AUTOWAKEUP_CFG_TBCN_BEFORE_WAKE    FIELD32(0x00007f00)
#define AUTOWAKEUP_CFG_AUTOWAKE        FIELD32(0x00008000)
 
/*
 * MIMO_PS_CFG: MIMO Power-save Configuration
 */
#define MIMO_PS_CFG            0x1210
#define MIMO_PS_CFG_MMPS_BB_EN        FIELD32(0x00000001)
#define MIMO_PS_CFG_MMPS_RX_ANT_NUM    FIELD32(0x00000006)
#define MIMO_PS_CFG_MMPS_RF_EN        FIELD32(0x00000008)
#define MIMO_PS_CFG_RX_STBY_POL        FIELD32(0x00000010)
#define MIMO_PS_CFG_RX_RX_STBY0        FIELD32(0x00000020)
 
/*
 * EDCA_AC0_CFG:
 */
#define EDCA_AC0_CFG            0x1300
#define EDCA_AC0_CFG_TX_OP        FIELD32(0x000000ff)
#define EDCA_AC0_CFG_AIFSN        FIELD32(0x00000f00)
#define EDCA_AC0_CFG_CWMIN        FIELD32(0x0000f000)
#define EDCA_AC0_CFG_CWMAX        FIELD32(0x000f0000)
 
/*
 * EDCA_AC1_CFG:
 */
#define EDCA_AC1_CFG            0x1304
#define EDCA_AC1_CFG_TX_OP        FIELD32(0x000000ff)
#define EDCA_AC1_CFG_AIFSN        FIELD32(0x00000f00)
#define EDCA_AC1_CFG_CWMIN        FIELD32(0x0000f000)
#define EDCA_AC1_CFG_CWMAX        FIELD32(0x000f0000)
 
/*
 * EDCA_AC2_CFG:
 */
#define EDCA_AC2_CFG            0x1308
#define EDCA_AC2_CFG_TX_OP        FIELD32(0x000000ff)
#define EDCA_AC2_CFG_AIFSN        FIELD32(0x00000f00)
#define EDCA_AC2_CFG_CWMIN        FIELD32(0x0000f000)
#define EDCA_AC2_CFG_CWMAX        FIELD32(0x000f0000)
 
/*
 * EDCA_AC3_CFG:
 */
#define EDCA_AC3_CFG            0x130c
#define EDCA_AC3_CFG_TX_OP        FIELD32(0x000000ff)
#define EDCA_AC3_CFG_AIFSN        FIELD32(0x00000f00)
#define EDCA_AC3_CFG_CWMIN        FIELD32(0x0000f000)
#define EDCA_AC3_CFG_CWMAX        FIELD32(0x000f0000)
 
/*
 * EDCA_TID_AC_MAP:
 */
#define EDCA_TID_AC_MAP            0x1310
 
/*
 * TX_PWR_CFG:
 */
#define TX_PWR_CFG_RATE0        FIELD32(0x0000000f)
#define TX_PWR_CFG_RATE1        FIELD32(0x000000f0)
#define TX_PWR_CFG_RATE2        FIELD32(0x00000f00)
#define TX_PWR_CFG_RATE3        FIELD32(0x0000f000)
#define TX_PWR_CFG_RATE4        FIELD32(0x000f0000)
#define TX_PWR_CFG_RATE5        FIELD32(0x00f00000)
#define TX_PWR_CFG_RATE6        FIELD32(0x0f000000)
#define TX_PWR_CFG_RATE7        FIELD32(0xf0000000)
 
/*
 * TX_PWR_CFG_0:
 */
#define TX_PWR_CFG_0            0x1314
#define TX_PWR_CFG_0_1MBS        FIELD32(0x0000000f)
#define TX_PWR_CFG_0_2MBS        FIELD32(0x000000f0)
#define TX_PWR_CFG_0_55MBS        FIELD32(0x00000f00)
#define TX_PWR_CFG_0_11MBS        FIELD32(0x0000f000)
#define TX_PWR_CFG_0_6MBS        FIELD32(0x000f0000)
#define TX_PWR_CFG_0_9MBS        FIELD32(0x00f00000)
#define TX_PWR_CFG_0_12MBS        FIELD32(0x0f000000)
#define TX_PWR_CFG_0_18MBS        FIELD32(0xf0000000)
/* bits for 3T devices */
#define TX_PWR_CFG_0_CCK1_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_0_CCK1_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_0_CCK5_CH0        FIELD32(0x00000f00)
#define TX_PWR_CFG_0_CCK5_CH1        FIELD32(0x0000f000)
#define TX_PWR_CFG_0_OFDM6_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_0_OFDM6_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_0_OFDM12_CH0        FIELD32(0x0f000000)
#define TX_PWR_CFG_0_OFDM12_CH1        FIELD32(0xf0000000)
/* bits for new 2T devices */
#define TX_PWR_CFG_0B_1MBS_2MBS        FIELD32(0x000000ff)
#define TX_PWR_CFG_0B_5MBS_11MBS        FIELD32(0x0000ff00)
#define TX_PWR_CFG_0B_6MBS_9MBS        FIELD32(0x00ff0000)
#define TX_PWR_CFG_0B_12MBS_18MBS    FIELD32(0xff000000)
 
 
/*
 * TX_PWR_CFG_1:
 */
#define TX_PWR_CFG_1            0x1318
#define TX_PWR_CFG_1_24MBS        FIELD32(0x0000000f)
#define TX_PWR_CFG_1_36MBS        FIELD32(0x000000f0)
#define TX_PWR_CFG_1_48MBS        FIELD32(0x00000f00)
#define TX_PWR_CFG_1_54MBS        FIELD32(0x0000f000)
#define TX_PWR_CFG_1_MCS0        FIELD32(0x000f0000)
#define TX_PWR_CFG_1_MCS1        FIELD32(0x00f00000)
#define TX_PWR_CFG_1_MCS2        FIELD32(0x0f000000)
#define TX_PWR_CFG_1_MCS3        FIELD32(0xf0000000)
/* bits for 3T devices */
#define TX_PWR_CFG_1_OFDM24_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_1_OFDM24_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_1_OFDM48_CH0        FIELD32(0x00000f00)
#define TX_PWR_CFG_1_OFDM48_CH1        FIELD32(0x0000f000)
#define TX_PWR_CFG_1_MCS0_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_1_MCS0_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_1_MCS2_CH0        FIELD32(0x0f000000)
#define TX_PWR_CFG_1_MCS2_CH1        FIELD32(0xf0000000)
/* bits for new 2T devices */
#define TX_PWR_CFG_1B_24MBS_36MBS    FIELD32(0x000000ff)
#define TX_PWR_CFG_1B_48MBS        FIELD32(0x0000ff00)
#define TX_PWR_CFG_1B_MCS0_MCS1        FIELD32(0x00ff0000)
#define TX_PWR_CFG_1B_MCS2_MCS3        FIELD32(0xff000000)
 
/*
 * TX_PWR_CFG_2:
 */
#define TX_PWR_CFG_2            0x131c
#define TX_PWR_CFG_2_MCS4        FIELD32(0x0000000f)
#define TX_PWR_CFG_2_MCS5        FIELD32(0x000000f0)
#define TX_PWR_CFG_2_MCS6        FIELD32(0x00000f00)
#define TX_PWR_CFG_2_MCS7        FIELD32(0x0000f000)
#define TX_PWR_CFG_2_MCS8        FIELD32(0x000f0000)
#define TX_PWR_CFG_2_MCS9        FIELD32(0x00f00000)
#define TX_PWR_CFG_2_MCS10        FIELD32(0x0f000000)
#define TX_PWR_CFG_2_MCS11        FIELD32(0xf0000000)
/* bits for 3T devices */
#define TX_PWR_CFG_2_MCS4_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_2_MCS4_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_2_MCS6_CH0        FIELD32(0x00000f00)
#define TX_PWR_CFG_2_MCS6_CH1        FIELD32(0x0000f000)
#define TX_PWR_CFG_2_MCS8_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_2_MCS8_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_2_MCS10_CH0        FIELD32(0x0f000000)
#define TX_PWR_CFG_2_MCS10_CH1        FIELD32(0xf0000000)
/* bits for new 2T devices */
#define TX_PWR_CFG_2B_MCS4_MCS5        FIELD32(0x000000ff)
#define TX_PWR_CFG_2B_MCS6_MCS7        FIELD32(0x0000ff00)
#define TX_PWR_CFG_2B_MCS8_MCS9        FIELD32(0x00ff0000)
#define TX_PWR_CFG_2B_MCS10_MCS11    FIELD32(0xff000000)
 
/*
 * TX_PWR_CFG_3:
 */
#define TX_PWR_CFG_3            0x1320
#define TX_PWR_CFG_3_MCS12        FIELD32(0x0000000f)
#define TX_PWR_CFG_3_MCS13        FIELD32(0x000000f0)
#define TX_PWR_CFG_3_MCS14        FIELD32(0x00000f00)
#define TX_PWR_CFG_3_MCS15        FIELD32(0x0000f000)
#define TX_PWR_CFG_3_UNKNOWN1        FIELD32(0x000f0000)
#define TX_PWR_CFG_3_UNKNOWN2        FIELD32(0x00f00000)
#define TX_PWR_CFG_3_UNKNOWN3        FIELD32(0x0f000000)
#define TX_PWR_CFG_3_UNKNOWN4        FIELD32(0xf0000000)
/* bits for 3T devices */
#define TX_PWR_CFG_3_MCS12_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_3_MCS12_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_3_MCS14_CH0        FIELD32(0x00000f00)
#define TX_PWR_CFG_3_MCS14_CH1        FIELD32(0x0000f000)
#define TX_PWR_CFG_3_STBC0_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_3_STBC0_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_3_STBC2_CH0        FIELD32(0x0f000000)
#define TX_PWR_CFG_3_STBC2_CH1        FIELD32(0xf0000000)
/* bits for new 2T devices */
#define TX_PWR_CFG_3B_MCS12_MCS13    FIELD32(0x000000ff)
#define TX_PWR_CFG_3B_MCS14        FIELD32(0x0000ff00)
#define TX_PWR_CFG_3B_STBC_MCS0_MCS1    FIELD32(0x00ff0000)
#define TX_PWR_CFG_3B_STBC_MCS2_MSC3    FIELD32(0xff000000)
 
/*
 * TX_PWR_CFG_4:
 */
#define TX_PWR_CFG_4            0x1324
#define TX_PWR_CFG_4_UNKNOWN5        FIELD32(0x0000000f)
#define TX_PWR_CFG_4_UNKNOWN6        FIELD32(0x000000f0)
#define TX_PWR_CFG_4_UNKNOWN7        FIELD32(0x00000f00)
#define TX_PWR_CFG_4_UNKNOWN8        FIELD32(0x0000f000)
/* bits for 3T devices */
#define TX_PWR_CFG_4_STBC4_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_4_STBC4_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_4_STBC6_CH0        FIELD32(0x00000f00)
#define TX_PWR_CFG_4_STBC6_CH1        FIELD32(0x0000f000)
/* bits for new 2T devices */
#define TX_PWR_CFG_4B_STBC_MCS4_MCS5    FIELD32(0x000000ff)
#define TX_PWR_CFG_4B_STBC_MCS6        FIELD32(0x0000ff00)
 
/*
 * TX_PIN_CFG:
 */
#define TX_PIN_CFG            0x1328
#define TX_PIN_CFG_PA_PE_DISABLE    0xfcfffff0
#define TX_PIN_CFG_PA_PE_A0_EN        FIELD32(0x00000001)
#define TX_PIN_CFG_PA_PE_G0_EN        FIELD32(0x00000002)
#define TX_PIN_CFG_PA_PE_A1_EN        FIELD32(0x00000004)
#define TX_PIN_CFG_PA_PE_G1_EN        FIELD32(0x00000008)
#define TX_PIN_CFG_PA_PE_A0_POL        FIELD32(0x00000010)
#define TX_PIN_CFG_PA_PE_G0_POL        FIELD32(0x00000020)
#define TX_PIN_CFG_PA_PE_A1_POL        FIELD32(0x00000040)
#define TX_PIN_CFG_PA_PE_G1_POL        FIELD32(0x00000080)
#define TX_PIN_CFG_LNA_PE_A0_EN        FIELD32(0x00000100)
#define TX_PIN_CFG_LNA_PE_G0_EN        FIELD32(0x00000200)
#define TX_PIN_CFG_LNA_PE_A1_EN        FIELD32(0x00000400)
#define TX_PIN_CFG_LNA_PE_G1_EN        FIELD32(0x00000800)
#define TX_PIN_CFG_LNA_PE_A0_POL    FIELD32(0x00001000)
#define TX_PIN_CFG_LNA_PE_G0_POL    FIELD32(0x00002000)
#define TX_PIN_CFG_LNA_PE_A1_POL    FIELD32(0x00004000)
#define TX_PIN_CFG_LNA_PE_G1_POL    FIELD32(0x00008000)
#define TX_PIN_CFG_RFTR_EN        FIELD32(0x00010000)
#define TX_PIN_CFG_RFTR_POL        FIELD32(0x00020000)
#define TX_PIN_CFG_TRSW_EN        FIELD32(0x00040000)
#define TX_PIN_CFG_TRSW_POL        FIELD32(0x00080000)
#define TX_PIN_CFG_RFRX_EN        FIELD32(0x00100000)
#define TX_PIN_CFG_RFRX_POL        FIELD32(0x00200000)
#define TX_PIN_CFG_PA_PE_A2_EN        FIELD32(0x01000000)
#define TX_PIN_CFG_PA_PE_G2_EN        FIELD32(0x02000000)
#define TX_PIN_CFG_PA_PE_A2_POL        FIELD32(0x04000000)
#define TX_PIN_CFG_PA_PE_G2_POL        FIELD32(0x08000000)
#define TX_PIN_CFG_LNA_PE_A2_EN        FIELD32(0x10000000)
#define TX_PIN_CFG_LNA_PE_G2_EN        FIELD32(0x20000000)
#define TX_PIN_CFG_LNA_PE_A2_POL    FIELD32(0x40000000)
#define TX_PIN_CFG_LNA_PE_G2_POL    FIELD32(0x80000000)
 
/*
 * TX_BAND_CFG: 0x1 use upper 20MHz, 0x0 use lower 20MHz
 */
#define TX_BAND_CFG            0x132c
#define TX_BAND_CFG_HT40_MINUS        FIELD32(0x00000001)
#define TX_BAND_CFG_A            FIELD32(0x00000002)
#define TX_BAND_CFG_BG            FIELD32(0x00000004)
 
/*
 * TX_SW_CFG0:
 */
#define TX_SW_CFG0            0x1330
 
/*
 * TX_SW_CFG1:
 */
#define TX_SW_CFG1            0x1334
 
/*
 * TX_SW_CFG2:
 */
#define TX_SW_CFG2            0x1338
 
/*
 * TXOP_THRES_CFG:
 */
#define TXOP_THRES_CFG            0x133c
 
/*
 * TXOP_CTRL_CFG:
 * TIMEOUT_TRUN_EN: Enable/Disable TXOP timeout truncation
 * AC_TRUN_EN: Enable/Disable truncation for AC change
 * TXRATEGRP_TRUN_EN: Enable/Disable truncation for TX rate group change
 * USER_MODE_TRUN_EN: Enable/Disable truncation for user TXOP mode
 * MIMO_PS_TRUN_EN: Enable/Disable truncation for MIMO PS RTS/CTS
 * RESERVED_TRUN_EN: Reserved
 * LSIG_TXOP_EN: Enable/Disable L-SIG TXOP protection
 * EXT_CCA_EN: Enable/Disable extension channel CCA reference (Defer 40Mhz
 *           transmissions if extension CCA is clear).
 * EXT_CCA_DLY: Extension CCA signal delay time (unit: us)
 * EXT_CWMIN: CwMin for extension channel backoff
 *          0: Disabled
 *
 */
#define TXOP_CTRL_CFG            0x1340
#define TXOP_CTRL_CFG_TIMEOUT_TRUN_EN    FIELD32(0x00000001)
#define TXOP_CTRL_CFG_AC_TRUN_EN    FIELD32(0x00000002)
#define TXOP_CTRL_CFG_TXRATEGRP_TRUN_EN    FIELD32(0x00000004)
#define TXOP_CTRL_CFG_USER_MODE_TRUN_EN    FIELD32(0x00000008)
#define TXOP_CTRL_CFG_MIMO_PS_TRUN_EN    FIELD32(0x00000010)
#define TXOP_CTRL_CFG_RESERVED_TRUN_EN    FIELD32(0x00000020)
#define TXOP_CTRL_CFG_LSIG_TXOP_EN    FIELD32(0x00000040)
#define TXOP_CTRL_CFG_EXT_CCA_EN    FIELD32(0x00000080)
#define TXOP_CTRL_CFG_EXT_CCA_DLY    FIELD32(0x0000ff00)
#define TXOP_CTRL_CFG_EXT_CWMIN        FIELD32(0x000f0000)
 
/*
 * TX_RTS_CFG:
 * RTS_THRES: unit:byte
 * RTS_FBK_EN: enable rts rate fallback
 */
#define TX_RTS_CFG            0x1344
#define TX_RTS_CFG_AUTO_RTS_RETRY_LIMIT    FIELD32(0x000000ff)
#define TX_RTS_CFG_RTS_THRES        FIELD32(0x00ffff00)
#define TX_RTS_CFG_RTS_FBK_EN        FIELD32(0x01000000)
 
/*
 * TX_TIMEOUT_CFG:
 * MPDU_LIFETIME: expiration time = 2^(9+MPDU LIFE TIME) us
 * RX_ACK_TIMEOUT: unit:slot. Used for TX procedure
 * TX_OP_TIMEOUT: TXOP timeout value for TXOP truncation.
 *                it is recommended that:
 *                (SLOT_TIME) > (TX_OP_TIMEOUT) > (RX_ACK_TIMEOUT)
 */
#define TX_TIMEOUT_CFG            0x1348
#define TX_TIMEOUT_CFG_MPDU_LIFETIME    FIELD32(0x000000f0)
#define TX_TIMEOUT_CFG_RX_ACK_TIMEOUT    FIELD32(0x0000ff00)
#define TX_TIMEOUT_CFG_TX_OP_TIMEOUT    FIELD32(0x00ff0000)
 
/*
 * TX_RTY_CFG:
 * SHORT_RTY_LIMIT: short retry limit
 * LONG_RTY_LIMIT: long retry limit
 * LONG_RTY_THRE: Long retry threshoold
 * NON_AGG_RTY_MODE: Non-Aggregate MPDU retry mode
 *                   0:expired by retry limit, 1: expired by mpdu life timer
 * AGG_RTY_MODE: Aggregate MPDU retry mode
 *               0:expired by retry limit, 1: expired by mpdu life timer
 * TX_AUTO_FB_ENABLE: Tx retry PHY rate auto fallback enable
 */
#define TX_RTY_CFG            0x134c
#define TX_RTY_CFG_SHORT_RTY_LIMIT    FIELD32(0x000000ff)
#define TX_RTY_CFG_LONG_RTY_LIMIT    FIELD32(0x0000ff00)
#define TX_RTY_CFG_LONG_RTY_THRE    FIELD32(0x0fff0000)
#define TX_RTY_CFG_NON_AGG_RTY_MODE    FIELD32(0x10000000)
#define TX_RTY_CFG_AGG_RTY_MODE        FIELD32(0x20000000)
#define TX_RTY_CFG_TX_AUTO_FB_ENABLE    FIELD32(0x40000000)
 
/*
 * TX_LINK_CFG:
 * REMOTE_MFB_LIFETIME: remote MFB life time. unit: 32us
 * MFB_ENABLE: TX apply remote MFB 1:enable
 * REMOTE_UMFS_ENABLE: remote unsolicit  MFB enable
 *                     0: not apply remote remote unsolicit (MFS=7)
 * TX_MRQ_EN: MCS request TX enable
 * TX_RDG_EN: RDG TX enable
 * TX_CF_ACK_EN: Piggyback CF-ACK enable
 * REMOTE_MFB: remote MCS feedback
 * REMOTE_MFS: remote MCS feedback sequence number
 */
#define TX_LINK_CFG            0x1350
#define TX_LINK_CFG_REMOTE_MFB_LIFETIME    FIELD32(0x000000ff)
#define TX_LINK_CFG_MFB_ENABLE        FIELD32(0x00000100)
#define TX_LINK_CFG_REMOTE_UMFS_ENABLE    FIELD32(0x00000200)
#define TX_LINK_CFG_TX_MRQ_EN        FIELD32(0x00000400)
#define TX_LINK_CFG_TX_RDG_EN        FIELD32(0x00000800)
#define TX_LINK_CFG_TX_CF_ACK_EN    FIELD32(0x00001000)
#define TX_LINK_CFG_REMOTE_MFB        FIELD32(0x00ff0000)
#define TX_LINK_CFG_REMOTE_MFS        FIELD32(0xff000000)
 
/*
 * HT_FBK_CFG0:
 */
#define HT_FBK_CFG0            0x1354
#define HT_FBK_CFG0_HTMCS0FBK        FIELD32(0x0000000f)
#define HT_FBK_CFG0_HTMCS1FBK        FIELD32(0x000000f0)
#define HT_FBK_CFG0_HTMCS2FBK        FIELD32(0x00000f00)
#define HT_FBK_CFG0_HTMCS3FBK        FIELD32(0x0000f000)
#define HT_FBK_CFG0_HTMCS4FBK        FIELD32(0x000f0000)
#define HT_FBK_CFG0_HTMCS5FBK        FIELD32(0x00f00000)
#define HT_FBK_CFG0_HTMCS6FBK        FIELD32(0x0f000000)
#define HT_FBK_CFG0_HTMCS7FBK        FIELD32(0xf0000000)
 
/*
 * HT_FBK_CFG1:
 */
#define HT_FBK_CFG1            0x1358
#define HT_FBK_CFG1_HTMCS8FBK        FIELD32(0x0000000f)
#define HT_FBK_CFG1_HTMCS9FBK        FIELD32(0x000000f0)
#define HT_FBK_CFG1_HTMCS10FBK        FIELD32(0x00000f00)
#define HT_FBK_CFG1_HTMCS11FBK        FIELD32(0x0000f000)
#define HT_FBK_CFG1_HTMCS12FBK        FIELD32(0x000f0000)
#define HT_FBK_CFG1_HTMCS13FBK        FIELD32(0x00f00000)
#define HT_FBK_CFG1_HTMCS14FBK        FIELD32(0x0f000000)
#define HT_FBK_CFG1_HTMCS15FBK        FIELD32(0xf0000000)
 
/*
 * LG_FBK_CFG0:
 */
#define LG_FBK_CFG0            0x135c
#define LG_FBK_CFG0_OFDMMCS0FBK        FIELD32(0x0000000f)
#define LG_FBK_CFG0_OFDMMCS1FBK        FIELD32(0x000000f0)
#define LG_FBK_CFG0_OFDMMCS2FBK        FIELD32(0x00000f00)
#define LG_FBK_CFG0_OFDMMCS3FBK        FIELD32(0x0000f000)
#define LG_FBK_CFG0_OFDMMCS4FBK        FIELD32(0x000f0000)
#define LG_FBK_CFG0_OFDMMCS5FBK        FIELD32(0x00f00000)
#define LG_FBK_CFG0_OFDMMCS6FBK        FIELD32(0x0f000000)
#define LG_FBK_CFG0_OFDMMCS7FBK        FIELD32(0xf0000000)
 
/*
 * LG_FBK_CFG1:
 */
#define LG_FBK_CFG1            0x1360
#define LG_FBK_CFG0_CCKMCS0FBK        FIELD32(0x0000000f)
#define LG_FBK_CFG0_CCKMCS1FBK        FIELD32(0x000000f0)
#define LG_FBK_CFG0_CCKMCS2FBK        FIELD32(0x00000f00)
#define LG_FBK_CFG0_CCKMCS3FBK        FIELD32(0x0000f000)
 
/*
 * CCK_PROT_CFG: CCK Protection
 * PROTECT_RATE: Protection control frame rate for CCK TX(RTS/CTS/CFEnd)
 * PROTECT_CTRL: Protection control frame type for CCK TX
 *               0:none, 1:RTS/CTS, 2:CTS-to-self
 * PROTECT_NAV_SHORT: TXOP protection type for CCK TX with short NAV
 * PROTECT_NAV_LONG: TXOP protection type for CCK TX with long NAV
 * TX_OP_ALLOW_CCK: CCK TXOP allowance, 0:disallow
 * TX_OP_ALLOW_OFDM: CCK TXOP allowance, 0:disallow
 * TX_OP_ALLOW_MM20: CCK TXOP allowance, 0:disallow
 * TX_OP_ALLOW_MM40: CCK TXOP allowance, 0:disallow
 * TX_OP_ALLOW_GF20: CCK TXOP allowance, 0:disallow
 * TX_OP_ALLOW_GF40: CCK TXOP allowance, 0:disallow
 * RTS_TH_EN: RTS threshold enable on CCK TX
 */
#define CCK_PROT_CFG            0x1364
#define CCK_PROT_CFG_PROTECT_RATE    FIELD32(0x0000ffff)
#define CCK_PROT_CFG_PROTECT_CTRL    FIELD32(0x00030000)
#define CCK_PROT_CFG_PROTECT_NAV_SHORT    FIELD32(0x00040000)
#define CCK_PROT_CFG_PROTECT_NAV_LONG    FIELD32(0x00080000)
#define CCK_PROT_CFG_TX_OP_ALLOW_CCK    FIELD32(0x00100000)
#define CCK_PROT_CFG_TX_OP_ALLOW_OFDM    FIELD32(0x00200000)
#define CCK_PROT_CFG_TX_OP_ALLOW_MM20    FIELD32(0x00400000)
#define CCK_PROT_CFG_TX_OP_ALLOW_MM40    FIELD32(0x00800000)
#define CCK_PROT_CFG_TX_OP_ALLOW_GF20    FIELD32(0x01000000)
#define CCK_PROT_CFG_TX_OP_ALLOW_GF40    FIELD32(0x02000000)
#define CCK_PROT_CFG_RTS_TH_EN        FIELD32(0x04000000)
 
/*
 * OFDM_PROT_CFG: OFDM Protection
 */
#define OFDM_PROT_CFG            0x1368
#define OFDM_PROT_CFG_PROTECT_RATE    FIELD32(0x0000ffff)
#define OFDM_PROT_CFG_PROTECT_CTRL    FIELD32(0x00030000)
#define OFDM_PROT_CFG_PROTECT_NAV_SHORT    FIELD32(0x00040000)
#define OFDM_PROT_CFG_PROTECT_NAV_LONG    FIELD32(0x00080000)
#define OFDM_PROT_CFG_TX_OP_ALLOW_CCK    FIELD32(0x00100000)
#define OFDM_PROT_CFG_TX_OP_ALLOW_OFDM    FIELD32(0x00200000)
#define OFDM_PROT_CFG_TX_OP_ALLOW_MM20    FIELD32(0x00400000)
#define OFDM_PROT_CFG_TX_OP_ALLOW_MM40    FIELD32(0x00800000)
#define OFDM_PROT_CFG_TX_OP_ALLOW_GF20    FIELD32(0x01000000)
#define OFDM_PROT_CFG_TX_OP_ALLOW_GF40    FIELD32(0x02000000)
#define OFDM_PROT_CFG_RTS_TH_EN        FIELD32(0x04000000)
 
/*
 * MM20_PROT_CFG: MM20 Protection
 */
#define MM20_PROT_CFG            0x136c
#define MM20_PROT_CFG_PROTECT_RATE    FIELD32(0x0000ffff)
#define MM20_PROT_CFG_PROTECT_CTRL    FIELD32(0x00030000)
#define MM20_PROT_CFG_PROTECT_NAV_SHORT    FIELD32(0x00040000)
#define MM20_PROT_CFG_PROTECT_NAV_LONG    FIELD32(0x00080000)
#define MM20_PROT_CFG_TX_OP_ALLOW_CCK    FIELD32(0x00100000)
#define MM20_PROT_CFG_TX_OP_ALLOW_OFDM    FIELD32(0x00200000)
#define MM20_PROT_CFG_TX_OP_ALLOW_MM20    FIELD32(0x00400000)
#define MM20_PROT_CFG_TX_OP_ALLOW_MM40    FIELD32(0x00800000)
#define MM20_PROT_CFG_TX_OP_ALLOW_GF20    FIELD32(0x01000000)
#define MM20_PROT_CFG_TX_OP_ALLOW_GF40    FIELD32(0x02000000)
#define MM20_PROT_CFG_RTS_TH_EN        FIELD32(0x04000000)
 
/*
 * MM40_PROT_CFG: MM40 Protection
 */
#define MM40_PROT_CFG            0x1370
#define MM40_PROT_CFG_PROTECT_RATE    FIELD32(0x0000ffff)
#define MM40_PROT_CFG_PROTECT_CTRL    FIELD32(0x00030000)
#define MM40_PROT_CFG_PROTECT_NAV_SHORT    FIELD32(0x00040000)
#define MM40_PROT_CFG_PROTECT_NAV_LONG    FIELD32(0x00080000)
#define MM40_PROT_CFG_TX_OP_ALLOW_CCK    FIELD32(0x00100000)
#define MM40_PROT_CFG_TX_OP_ALLOW_OFDM    FIELD32(0x00200000)
#define MM40_PROT_CFG_TX_OP_ALLOW_MM20    FIELD32(0x00400000)
#define MM40_PROT_CFG_TX_OP_ALLOW_MM40    FIELD32(0x00800000)
#define MM40_PROT_CFG_TX_OP_ALLOW_GF20    FIELD32(0x01000000)
#define MM40_PROT_CFG_TX_OP_ALLOW_GF40    FIELD32(0x02000000)
#define MM40_PROT_CFG_RTS_TH_EN        FIELD32(0x04000000)
 
/*
 * GF20_PROT_CFG: GF20 Protection
 */
#define GF20_PROT_CFG            0x1374
#define GF20_PROT_CFG_PROTECT_RATE    FIELD32(0x0000ffff)
#define GF20_PROT_CFG_PROTECT_CTRL    FIELD32(0x00030000)
#define GF20_PROT_CFG_PROTECT_NAV_SHORT    FIELD32(0x00040000)
#define GF20_PROT_CFG_PROTECT_NAV_LONG    FIELD32(0x00080000)
#define GF20_PROT_CFG_TX_OP_ALLOW_CCK    FIELD32(0x00100000)
#define GF20_PROT_CFG_TX_OP_ALLOW_OFDM    FIELD32(0x00200000)
#define GF20_PROT_CFG_TX_OP_ALLOW_MM20    FIELD32(0x00400000)
#define GF20_PROT_CFG_TX_OP_ALLOW_MM40    FIELD32(0x00800000)
#define GF20_PROT_CFG_TX_OP_ALLOW_GF20    FIELD32(0x01000000)
#define GF20_PROT_CFG_TX_OP_ALLOW_GF40    FIELD32(0x02000000)
#define GF20_PROT_CFG_RTS_TH_EN        FIELD32(0x04000000)
 
/*
 * GF40_PROT_CFG: GF40 Protection
 */
#define GF40_PROT_CFG            0x1378
#define GF40_PROT_CFG_PROTECT_RATE    FIELD32(0x0000ffff)
#define GF40_PROT_CFG_PROTECT_CTRL    FIELD32(0x00030000)
#define GF40_PROT_CFG_PROTECT_NAV_SHORT    FIELD32(0x00040000)
#define GF40_PROT_CFG_PROTECT_NAV_LONG    FIELD32(0x00080000)
#define GF40_PROT_CFG_TX_OP_ALLOW_CCK    FIELD32(0x00100000)
#define GF40_PROT_CFG_TX_OP_ALLOW_OFDM    FIELD32(0x00200000)
#define GF40_PROT_CFG_TX_OP_ALLOW_MM20    FIELD32(0x00400000)
#define GF40_PROT_CFG_TX_OP_ALLOW_MM40    FIELD32(0x00800000)
#define GF40_PROT_CFG_TX_OP_ALLOW_GF20    FIELD32(0x01000000)
#define GF40_PROT_CFG_TX_OP_ALLOW_GF40    FIELD32(0x02000000)
#define GF40_PROT_CFG_RTS_TH_EN        FIELD32(0x04000000)
 
/*
 * EXP_CTS_TIME:
 */
#define EXP_CTS_TIME            0x137c
 
/*
 * EXP_ACK_TIME:
 */
#define EXP_ACK_TIME            0x1380
 
/* TX_PWR_CFG_5 */
#define TX_PWR_CFG_5            0x1384
#define TX_PWR_CFG_5_MCS16_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_5_MCS16_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_5_MCS16_CH2        FIELD32(0x00000f00)
#define TX_PWR_CFG_5_MCS18_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_5_MCS18_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_5_MCS18_CH2        FIELD32(0x0f000000)
 
/* TX_PWR_CFG_6 */
#define TX_PWR_CFG_6            0x1388
#define TX_PWR_CFG_6_MCS20_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_6_MCS20_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_6_MCS20_CH2        FIELD32(0x00000f00)
#define TX_PWR_CFG_6_MCS22_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_6_MCS22_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_6_MCS22_CH2        FIELD32(0x0f000000)
 
/* TX_PWR_CFG_0_EXT */
#define TX_PWR_CFG_0_EXT        0x1390
#define TX_PWR_CFG_0_EXT_CCK1_CH2    FIELD32(0x0000000f)
#define TX_PWR_CFG_0_EXT_CCK5_CH2    FIELD32(0x00000f00)
#define TX_PWR_CFG_0_EXT_OFDM6_CH2    FIELD32(0x000f0000)
#define TX_PWR_CFG_0_EXT_OFDM12_CH2    FIELD32(0x0f000000)
 
/* TX_PWR_CFG_1_EXT */
#define TX_PWR_CFG_1_EXT        0x1394
#define TX_PWR_CFG_1_EXT_OFDM24_CH2    FIELD32(0x0000000f)
#define TX_PWR_CFG_1_EXT_OFDM48_CH2    FIELD32(0x00000f00)
#define TX_PWR_CFG_1_EXT_MCS0_CH2    FIELD32(0x000f0000)
#define TX_PWR_CFG_1_EXT_MCS2_CH2    FIELD32(0x0f000000)
 
/* TX_PWR_CFG_2_EXT */
#define TX_PWR_CFG_2_EXT        0x1398
#define TX_PWR_CFG_2_EXT_MCS4_CH2    FIELD32(0x0000000f)
#define TX_PWR_CFG_2_EXT_MCS6_CH2    FIELD32(0x00000f00)
#define TX_PWR_CFG_2_EXT_MCS8_CH2    FIELD32(0x000f0000)
#define TX_PWR_CFG_2_EXT_MCS10_CH2    FIELD32(0x0f000000)
 
/* TX_PWR_CFG_3_EXT */
#define TX_PWR_CFG_3_EXT        0x139c
#define TX_PWR_CFG_3_EXT_MCS12_CH2    FIELD32(0x0000000f)
#define TX_PWR_CFG_3_EXT_MCS14_CH2    FIELD32(0x00000f00)
#define TX_PWR_CFG_3_EXT_STBC0_CH2    FIELD32(0x000f0000)
#define TX_PWR_CFG_3_EXT_STBC2_CH2    FIELD32(0x0f000000)
 
/* TX_PWR_CFG_4_EXT */
#define TX_PWR_CFG_4_EXT        0x13a0
#define TX_PWR_CFG_4_EXT_STBC4_CH2    FIELD32(0x0000000f)
#define TX_PWR_CFG_4_EXT_STBC6_CH2    FIELD32(0x00000f00)
 
/* TXn_RF_GAIN_CORRECT: RF Gain Correction for each RF_ALC[3:2]
 * Unit: 0.1 dB, Range: -3.2 dB to 3.1 dB
 */
#define TX0_RF_GAIN_CORRECT        0x13a0
#define TX0_RF_GAIN_CORRECT_GAIN_CORR_0    FIELD32(0x0000003f)
#define TX0_RF_GAIN_CORRECT_GAIN_CORR_1    FIELD32(0x00003f00)
#define TX0_RF_GAIN_CORRECT_GAIN_CORR_2    FIELD32(0x003f0000)
#define TX0_RF_GAIN_CORRECT_GAIN_CORR_3    FIELD32(0x3f000000)
 
#define TX1_RF_GAIN_CORRECT        0x13a4
#define TX1_RF_GAIN_CORRECT_GAIN_CORR_0    FIELD32(0x0000003f)
#define TX1_RF_GAIN_CORRECT_GAIN_CORR_1    FIELD32(0x00003f00)
#define TX1_RF_GAIN_CORRECT_GAIN_CORR_2    FIELD32(0x003f0000)
#define TX1_RF_GAIN_CORRECT_GAIN_CORR_3    FIELD32(0x3f000000)
 
/* TXn_RF_GAIN_ATTEN: TXn RF Gain Attenuation Level
 * Format: 7-bit, signed value
 * Unit: 0.5 dB, Range: -20 dB to -5 dB
 */
#define TX0_RF_GAIN_ATTEN        0x13a8
#define TX0_RF_GAIN_ATTEN_LEVEL_0    FIELD32(0x0000007f)
#define TX0_RF_GAIN_ATTEN_LEVEL_1    FIELD32(0x00007f00)
#define TX0_RF_GAIN_ATTEN_LEVEL_2    FIELD32(0x007f0000)
#define TX0_RF_GAIN_ATTEN_LEVEL_3    FIELD32(0x7f000000)
#define TX1_RF_GAIN_ATTEN        0x13ac
#define TX1_RF_GAIN_ATTEN_LEVEL_0    FIELD32(0x0000007f)
#define TX1_RF_GAIN_ATTEN_LEVEL_1    FIELD32(0x00007f00)
#define TX1_RF_GAIN_ATTEN_LEVEL_2    FIELD32(0x007f0000)
#define TX1_RF_GAIN_ATTEN_LEVEL_3    FIELD32(0x7f000000)
 
/* TX_ALC_CFG_0: TX Automatic Level Control Configuration 0
 * TX_ALC_LIMIT_n: TXn upper limit
 * TX_ALC_CH_INIT_n: TXn channel initial transmission gain
 * Unit: 0.5 dB, Range: 0 to 23.5 dB
 */
#define TX_ALC_CFG_0            0x13b0
#define TX_ALC_CFG_0_CH_INIT_0        FIELD32(0x0000003f)
#define TX_ALC_CFG_0_CH_INIT_1        FIELD32(0x00003f00)
#define TX_ALC_CFG_0_LIMIT_0        FIELD32(0x003f0000)
#define TX_ALC_CFG_0_LIMIT_1        FIELD32(0x3f000000)
 
/* TX_ALC_CFG_1: TX Automatic Level Control Configuration 1
 * TX_TEMP_COMP:      TX Power Temperature Compensation
 *                    Unit: 0.5 dB, Range: -10 dB to 10 dB
 * TXn_GAIN_FINE:     TXn Gain Fine Adjustment
 *                    Unit: 0.1 dB, Range: -0.8 dB to 0.7 dB
 * RF_TOS_DLY:        Sets the RF_TOS_EN assertion delay after
 *                    deassertion of PA_PE.
 *                    Unit: 0.25 usec
 * TXn_RF_GAIN_ATTEN: TXn RF gain attentuation selector
 * RF_TOS_TIMEOUT:    time-out value for RF_TOS_ENABLE
 *                    deassertion if RF_TOS_DONE is missing.
 *                    Unit: 0.25 usec
 * RF_TOS_ENABLE:     TX offset calibration enable
 * ROS_BUSY_EN:       RX offset calibration busy enable
 */
#define TX_ALC_CFG_1            0x13b4
#define TX_ALC_CFG_1_TX_TEMP_COMP    FIELD32(0x0000003f)
#define TX_ALC_CFG_1_TX0_GAIN_FINE    FIELD32(0x00000f00)
#define TX_ALC_CFG_1_TX1_GAIN_FINE    FIELD32(0x0000f000)
#define TX_ALC_CFG_1_RF_TOS_DLY        FIELD32(0x00070000)
#define TX_ALC_CFG_1_TX0_RF_GAIN_ATTEN    FIELD32(0x00300000)
#define TX_ALC_CFG_1_TX1_RF_GAIN_ATTEN    FIELD32(0x00c00000)
#define TX_ALC_CFG_1_RF_TOS_TIMEOUT    FIELD32(0x3f000000)
#define TX_ALC_CFG_1_RF_TOS_ENABLE    FIELD32(0x40000000)
#define TX_ALC_CFG_1_ROS_BUSY_EN    FIELD32(0x80000000)
 
/* TXn_BB_GAIN_ATTEN: TXn RF Gain Attenuation Level
 * Format: 5-bit signed values
 * Unit: 0.5 dB, Range: -8 dB to 7 dB
 */
#define TX0_BB_GAIN_ATTEN        0x13c0
#define TX0_BB_GAIN_ATTEN_LEVEL_0    FIELD32(0x0000001f)
#define TX0_BB_GAIN_ATTEN_LEVEL_1    FIELD32(0x00001f00)
#define TX0_BB_GAIN_ATTEN_LEVEL_2    FIELD32(0x001f0000)
#define TX0_BB_GAIN_ATTEN_LEVEL_3    FIELD32(0x1f000000)
#define TX1_BB_GAIN_ATTEN        0x13c4
#define TX1_BB_GAIN_ATTEN_LEVEL_0    FIELD32(0x0000001f)
#define TX1_BB_GAIN_ATTEN_LEVEL_1    FIELD32(0x00001f00)
#define TX1_BB_GAIN_ATTEN_LEVEL_2    FIELD32(0x001f0000)
#define TX1_BB_GAIN_ATTEN_LEVEL_3    FIELD32(0x1f000000)
 
/* TX_ALC_VGA3: TX Automatic Level Correction Variable Gain Amplifier 3 */
#define TX_ALC_VGA3            0x13c8
#define TX_ALC_VGA3_TX0_ALC_VGA3    FIELD32(0x0000001f)
#define TX_ALC_VGA3_TX1_ALC_VGA3    FIELD32(0x00001f00)
#define TX_ALC_VGA3_TX0_ALC_VGA2    FIELD32(0x001f0000)
#define TX_ALC_VGA3_TX1_ALC_VGA2    FIELD32(0x1f000000)
 
/* TX_PWR_CFG_7 */
#define TX_PWR_CFG_7            0x13d4
#define TX_PWR_CFG_7_OFDM54_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_7_OFDM54_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_7_OFDM54_CH2        FIELD32(0x00000f00)
#define TX_PWR_CFG_7_MCS7_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_7_MCS7_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_7_MCS7_CH2        FIELD32(0x0f000000)
/* bits for new 2T devices */
#define TX_PWR_CFG_7B_54MBS        FIELD32(0x000000ff)
#define TX_PWR_CFG_7B_MCS7        FIELD32(0x00ff0000)
 
 
/* TX_PWR_CFG_8 */
#define TX_PWR_CFG_8            0x13d8
#define TX_PWR_CFG_8_MCS15_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_8_MCS15_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_8_MCS15_CH2        FIELD32(0x00000f00)
#define TX_PWR_CFG_8_MCS23_CH0        FIELD32(0x000f0000)
#define TX_PWR_CFG_8_MCS23_CH1        FIELD32(0x00f00000)
#define TX_PWR_CFG_8_MCS23_CH2        FIELD32(0x0f000000)
/* bits for new 2T devices */
#define TX_PWR_CFG_8B_MCS15        FIELD32(0x000000ff)
 
 
/* TX_PWR_CFG_9 */
#define TX_PWR_CFG_9            0x13dc
#define TX_PWR_CFG_9_STBC7_CH0        FIELD32(0x0000000f)
#define TX_PWR_CFG_9_STBC7_CH1        FIELD32(0x000000f0)
#define TX_PWR_CFG_9_STBC7_CH2        FIELD32(0x00000f00)
/* bits for new 2T devices */
#define TX_PWR_CFG_9B_STBC_MCS7        FIELD32(0x000000ff)
 
/*
 * TX_TXBF_CFG:
 */
#define TX_TXBF_CFG_0            0x138c
#define TX_TXBF_CFG_1            0x13a4
#define TX_TXBF_CFG_2            0x13a8
#define TX_TXBF_CFG_3            0x13ac
 
/*
 * TX_FBK_CFG_3S:
 */
#define TX_FBK_CFG_3S_0            0x13c4
#define TX_FBK_CFG_3S_1            0x13c8
 
/*
 * RX_FILTER_CFG: RX configuration register.
 */
#define RX_FILTER_CFG            0x1400
#define RX_FILTER_CFG_DROP_CRC_ERROR    FIELD32(0x00000001)
#define RX_FILTER_CFG_DROP_PHY_ERROR    FIELD32(0x00000002)
#define RX_FILTER_CFG_DROP_NOT_TO_ME    FIELD32(0x00000004)
#define RX_FILTER_CFG_DROP_NOT_MY_BSSD    FIELD32(0x00000008)
#define RX_FILTER_CFG_DROP_VER_ERROR    FIELD32(0x00000010)
#define RX_FILTER_CFG_DROP_MULTICAST    FIELD32(0x00000020)
#define RX_FILTER_CFG_DROP_BROADCAST    FIELD32(0x00000040)
#define RX_FILTER_CFG_DROP_DUPLICATE    FIELD32(0x00000080)
#define RX_FILTER_CFG_DROP_CF_END_ACK    FIELD32(0x00000100)
#define RX_FILTER_CFG_DROP_CF_END    FIELD32(0x00000200)
#define RX_FILTER_CFG_DROP_ACK        FIELD32(0x00000400)
#define RX_FILTER_CFG_DROP_CTS        FIELD32(0x00000800)
#define RX_FILTER_CFG_DROP_RTS        FIELD32(0x00001000)
#define RX_FILTER_CFG_DROP_PSPOLL    FIELD32(0x00002000)
#define RX_FILTER_CFG_DROP_BA        FIELD32(0x00004000)
#define RX_FILTER_CFG_DROP_BAR        FIELD32(0x00008000)
#define RX_FILTER_CFG_DROP_CNTL        FIELD32(0x00010000)
 
/*
 * AUTO_RSP_CFG:
 * AUTORESPONDER: 0: disable, 1: enable
 * BAC_ACK_POLICY: 0:long, 1:short preamble
 * CTS_40_MMODE: Response CTS 40MHz duplicate mode
 * CTS_40_MREF: Response CTS 40MHz duplicate mode
 * AR_PREAMBLE: Auto responder preamble 0:long, 1:short preamble
 * DUAL_CTS_EN: Power bit value in control frame
 * ACK_CTS_PSM_BIT:Power bit value in control frame
 */
#define AUTO_RSP_CFG            0x1404
#define AUTO_RSP_CFG_AUTORESPONDER    FIELD32(0x00000001)
#define AUTO_RSP_CFG_BAC_ACK_POLICY    FIELD32(0x00000002)
#define AUTO_RSP_CFG_CTS_40_MMODE    FIELD32(0x00000004)
#define AUTO_RSP_CFG_CTS_40_MREF    FIELD32(0x00000008)
#define AUTO_RSP_CFG_AR_PREAMBLE    FIELD32(0x00000010)
#define AUTO_RSP_CFG_DUAL_CTS_EN    FIELD32(0x00000040)
#define AUTO_RSP_CFG_ACK_CTS_PSM_BIT    FIELD32(0x00000080)
 
/*
 * LEGACY_BASIC_RATE:
 */
#define LEGACY_BASIC_RATE        0x1408
 
/*
 * HT_BASIC_RATE:
 */
#define HT_BASIC_RATE            0x140c
 
/*
 * HT_CTRL_CFG:
 */
#define HT_CTRL_CFG            0x1410
 
/*
 * SIFS_COST_CFG:
 */
#define SIFS_COST_CFG            0x1414
 
/*
 * RX_PARSER_CFG:
 * Set NAV for all received frames
 */
#define RX_PARSER_CFG            0x1418
 
/*
 * TX_SEC_CNT0:
 */
#define TX_SEC_CNT0            0x1500
 
/*
 * RX_SEC_CNT0:
 */
#define RX_SEC_CNT0            0x1504
 
/*
 * CCMP_FC_MUTE:
 */
#define CCMP_FC_MUTE            0x1508
 
/*
 * TXOP_HLDR_ADDR0:
 */
#define TXOP_HLDR_ADDR0            0x1600
 
/*
 * TXOP_HLDR_ADDR1:
 */
#define TXOP_HLDR_ADDR1            0x1604
 
/*
 * TXOP_HLDR_ET:
 */
#define TXOP_HLDR_ET            0x1608
 
/*
 * QOS_CFPOLL_RA_DW0:
 */
#define QOS_CFPOLL_RA_DW0        0x160c
 
/*
 * QOS_CFPOLL_RA_DW1:
 */
#define QOS_CFPOLL_RA_DW1        0x1610
 
/*
 * QOS_CFPOLL_QC:
 */
#define QOS_CFPOLL_QC            0x1614
 
/*
 * RX_STA_CNT0: RX PLCP error count & RX CRC error count
 */
#define RX_STA_CNT0            0x1700
#define RX_STA_CNT0_CRC_ERR        FIELD32(0x0000ffff)
#define RX_STA_CNT0_PHY_ERR        FIELD32(0xffff0000)
 
/*
 * RX_STA_CNT1: RX False CCA count & RX LONG frame count
 */
#define RX_STA_CNT1            0x1704
#define RX_STA_CNT1_FALSE_CCA        FIELD32(0x0000ffff)
#define RX_STA_CNT1_PLCP_ERR        FIELD32(0xffff0000)
 
/*
 * RX_STA_CNT2:
 */
#define RX_STA_CNT2            0x1708
#define RX_STA_CNT2_RX_DUPLI_COUNT    FIELD32(0x0000ffff)
#define RX_STA_CNT2_RX_FIFO_OVERFLOW    FIELD32(0xffff0000)
 
/*
 * TX_STA_CNT0: TX Beacon count
 */
#define TX_STA_CNT0            0x170c
#define TX_STA_CNT0_TX_FAIL_COUNT    FIELD32(0x0000ffff)
#define TX_STA_CNT0_TX_BEACON_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_STA_CNT1: TX tx count
 */
#define TX_STA_CNT1            0x1710
#define TX_STA_CNT1_TX_SUCCESS        FIELD32(0x0000ffff)
#define TX_STA_CNT1_TX_RETRANSMIT    FIELD32(0xffff0000)
 
/*
 * TX_STA_CNT2: TX tx count
 */
#define TX_STA_CNT2            0x1714
#define TX_STA_CNT2_TX_ZERO_LEN_COUNT    FIELD32(0x0000ffff)
#define TX_STA_CNT2_TX_UNDER_FLOW_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_STA_FIFO: TX Result for specific PID status fifo register.
 *
 * This register is implemented as FIFO with 16 entries in the HW. Each
 * register read fetches the next tx result. If the FIFO is full because
 * it wasn't read fast enough after the according interrupt (TX_FIFO_STATUS)
 * triggered, the hw seems to simply drop further tx results.
 *
 * VALID: 1: this tx result is valid
 *        0: no valid tx result -> driver should stop reading
 * PID_TYPE: The PID latched from the PID field in the TXWI, can be used
 *           to match a frame with its tx result (even though the PID is
 *           only 4 bits wide).
 * PID_QUEUE: Part of PID_TYPE, this is the queue index number (0-3)
 * PID_ENTRY: Part of PID_TYPE, this is the queue entry index number (1-3)
 *            This identification number is calculated by ((idx % 3) + 1).
 * TX_SUCCESS: Indicates tx success (1) or failure (0)
 * TX_AGGRE: Indicates if the frame was part of an aggregate (1) or not (0)
 * TX_ACK_REQUIRED: Indicates if the frame needed to get ack'ed (1) or not (0)
 * WCID: The wireless client ID.
 * MCS: The tx rate used during the last transmission of this frame, be it
 *      successful or not.
 * PHYMODE: The phymode used for the transmission.
 */
#define TX_STA_FIFO            0x1718
#define TX_STA_FIFO_VALID        FIELD32(0x00000001)
#define TX_STA_FIFO_PID_TYPE        FIELD32(0x0000001e)
#define TX_STA_FIFO_PID_QUEUE        FIELD32(0x00000006)
#define TX_STA_FIFO_PID_ENTRY        FIELD32(0x00000018)
#define TX_STA_FIFO_TX_SUCCESS        FIELD32(0x00000020)
#define TX_STA_FIFO_TX_AGGRE        FIELD32(0x00000040)
#define TX_STA_FIFO_TX_ACK_REQUIRED    FIELD32(0x00000080)
#define TX_STA_FIFO_WCID        FIELD32(0x0000ff00)
#define TX_STA_FIFO_SUCCESS_RATE    FIELD32(0xffff0000)
#define TX_STA_FIFO_MCS            FIELD32(0x007f0000)
#define TX_STA_FIFO_BW            FIELD32(0x00800000)
#define TX_STA_FIFO_SGI            FIELD32(0x01000000)
#define TX_STA_FIFO_PHYMODE        FIELD32(0xc0000000)
 
/*
 * TX_AGG_CNT: Debug counter
 */
#define TX_AGG_CNT            0x171c
#define TX_AGG_CNT_NON_AGG_TX_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT_AGG_TX_COUNT        FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT0:
 */
#define TX_AGG_CNT0            0x1720
#define TX_AGG_CNT0_AGG_SIZE_1_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT0_AGG_SIZE_2_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT1:
 */
#define TX_AGG_CNT1            0x1724
#define TX_AGG_CNT1_AGG_SIZE_3_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT1_AGG_SIZE_4_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT2:
 */
#define TX_AGG_CNT2            0x1728
#define TX_AGG_CNT2_AGG_SIZE_5_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT2_AGG_SIZE_6_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT3:
 */
#define TX_AGG_CNT3            0x172c
#define TX_AGG_CNT3_AGG_SIZE_7_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT3_AGG_SIZE_8_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT4:
 */
#define TX_AGG_CNT4            0x1730
#define TX_AGG_CNT4_AGG_SIZE_9_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT4_AGG_SIZE_10_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT5:
 */
#define TX_AGG_CNT5            0x1734
#define TX_AGG_CNT5_AGG_SIZE_11_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT5_AGG_SIZE_12_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT6:
 */
#define TX_AGG_CNT6            0x1738
#define TX_AGG_CNT6_AGG_SIZE_13_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT6_AGG_SIZE_14_COUNT    FIELD32(0xffff0000)
 
/*
 * TX_AGG_CNT7:
 */
#define TX_AGG_CNT7            0x173c
#define TX_AGG_CNT7_AGG_SIZE_15_COUNT    FIELD32(0x0000ffff)
#define TX_AGG_CNT7_AGG_SIZE_16_COUNT    FIELD32(0xffff0000)
 
/*
 * MPDU_DENSITY_CNT:
 * TX_ZERO_DEL: TX zero length delimiter count
 * RX_ZERO_DEL: RX zero length delimiter count
 */
#define MPDU_DENSITY_CNT        0x1740
#define MPDU_DENSITY_CNT_TX_ZERO_DEL    FIELD32(0x0000ffff)
#define MPDU_DENSITY_CNT_RX_ZERO_DEL    FIELD32(0xffff0000)
 
/*
 * Security key table memory.
 *
 * The pairwise key table shares some memory with the beacon frame
 * buffers 6 and 7. That basically means that when beacon 6 & 7
 * are used we should only use the reduced pairwise key table which
 * has a maximum of 222 entries.
 *
 * ---------------------------------------------
 * |0x4000 | Pairwise Key   | Reduced Pairwise |
 * |       | Table          | Key Table        |
 * |       | Size: 256 * 32 | Size: 222 * 32   |
 * |0x5BC0 |                |-------------------
 * |       |                | Beacon 6         |
 * |0x5DC0 |                |-------------------
 * |       |                | Beacon 7         |
 * |0x5FC0 |                |-------------------
 * |0x5FFF |                |
 * --------------------------
 *
 * MAC_WCID_BASE: 8-bytes (use only 6 bytes) * 256 entry
 * PAIRWISE_KEY_TABLE_BASE: 32-byte * 256 entry
 * MAC_IVEIV_TABLE_BASE: 8-byte * 256-entry
 * MAC_WCID_ATTRIBUTE_BASE: 4-byte * 256-entry
 * SHARED_KEY_TABLE_BASE: 32-byte * 16-entry
 * SHARED_KEY_MODE_BASE: 4-byte * 16-entry
 */
#define MAC_WCID_BASE            0x1800
#define PAIRWISE_KEY_TABLE_BASE        0x4000
#define MAC_IVEIV_TABLE_BASE        0x6000
#define MAC_WCID_ATTRIBUTE_BASE        0x6800
#define SHARED_KEY_TABLE_BASE        0x6c00
#define SHARED_KEY_MODE_BASE        0x7000
 
#define MAC_WCID_ENTRY(__idx) \
   (MAC_WCID_BASE + ((__idx) * sizeof(struct mac_wcid_entry)))
#define PAIRWISE_KEY_ENTRY(__idx) \
   (PAIRWISE_KEY_TABLE_BASE + ((__idx) * sizeof(struct hw_key_entry)))
#define MAC_IVEIV_ENTRY(__idx) \
   (MAC_IVEIV_TABLE_BASE + ((__idx) * sizeof(struct mac_iveiv_entry)))
#define MAC_WCID_ATTR_ENTRY(__idx) \
   (MAC_WCID_ATTRIBUTE_BASE + ((__idx) * sizeof(u32)))
#define SHARED_KEY_ENTRY(__idx) \
   (SHARED_KEY_TABLE_BASE + ((__idx) * sizeof(struct hw_key_entry)))
#define SHARED_KEY_MODE_ENTRY(__idx) \
   (SHARED_KEY_MODE_BASE + ((__idx) * sizeof(u32)))
 
struct mac_wcid_entry {
   u8 mac[6];
   u8 reserved[2];
} __packed;
 
struct hw_key_entry {
   u8 key[16];
   u8 tx_mic[8];
   u8 rx_mic[8];
} __packed;
 
struct mac_iveiv_entry {
   u8 iv[8];
} __packed;
 
/*
 * MAC_WCID_ATTRIBUTE:
 */
#define MAC_WCID_ATTRIBUTE_KEYTAB    FIELD32(0x00000001)
#define MAC_WCID_ATTRIBUTE_CIPHER    FIELD32(0x0000000e)
#define MAC_WCID_ATTRIBUTE_BSS_IDX    FIELD32(0x00000070)
#define MAC_WCID_ATTRIBUTE_RX_WIUDF    FIELD32(0x00000380)
#define MAC_WCID_ATTRIBUTE_CIPHER_EXT    FIELD32(0x00000400)
#define MAC_WCID_ATTRIBUTE_BSS_IDX_EXT    FIELD32(0x00000800)
#define MAC_WCID_ATTRIBUTE_WAPI_MCBC    FIELD32(0x00008000)
#define MAC_WCID_ATTRIBUTE_WAPI_KEY_IDX    FIELD32(0xff000000)
 
/*
 * SHARED_KEY_MODE:
 */
#define SHARED_KEY_MODE_BSS0_KEY0    FIELD32(0x00000007)
#define SHARED_KEY_MODE_BSS0_KEY1    FIELD32(0x00000070)
#define SHARED_KEY_MODE_BSS0_KEY2    FIELD32(0x00000700)
#define SHARED_KEY_MODE_BSS0_KEY3    FIELD32(0x00007000)
#define SHARED_KEY_MODE_BSS1_KEY0    FIELD32(0x00070000)
#define SHARED_KEY_MODE_BSS1_KEY1    FIELD32(0x00700000)
#define SHARED_KEY_MODE_BSS1_KEY2    FIELD32(0x07000000)
#define SHARED_KEY_MODE_BSS1_KEY3    FIELD32(0x70000000)
 
/*
 * HOST-MCU communication
 */
 
/*
 * H2M_MAILBOX_CSR: Host-to-MCU Mailbox.
 * CMD_TOKEN: Command id, 0xff disable status reporting.
 */
#define H2M_MAILBOX_CSR            0x7010
#define H2M_MAILBOX_CSR_ARG0        FIELD32(0x000000ff)
#define H2M_MAILBOX_CSR_ARG1        FIELD32(0x0000ff00)
#define H2M_MAILBOX_CSR_CMD_TOKEN    FIELD32(0x00ff0000)
#define H2M_MAILBOX_CSR_OWNER        FIELD32(0xff000000)
 
/*
 * H2M_MAILBOX_CID:
 * Free slots contain 0xff. MCU will store command's token to lowest free slot.
 * If all slots are occupied status will be dropped.
 */
#define H2M_MAILBOX_CID            0x7014
#define H2M_MAILBOX_CID_CMD0        FIELD32(0x000000ff)
#define H2M_MAILBOX_CID_CMD1        FIELD32(0x0000ff00)
#define H2M_MAILBOX_CID_CMD2        FIELD32(0x00ff0000)
#define H2M_MAILBOX_CID_CMD3        FIELD32(0xff000000)
 
/*
 * H2M_MAILBOX_STATUS:
 * Command status will be saved to same slot as command id.
 */
#define H2M_MAILBOX_STATUS        0x701c
 
/*
 * H2M_INT_SRC:
 */
#define H2M_INT_SRC            0x7024
 
/*
 * H2M_BBP_AGENT:
 */
#define H2M_BBP_AGENT            0x7028
 
/*
 * MCU_LEDCS: LED control for MCU Mailbox.
 */
#define MCU_LEDCS_LED_MODE        FIELD8(0x1f)
#define MCU_LEDCS_POLARITY        FIELD8(0x01)
 
/*
 * HW_CS_CTS_BASE:
 * Carrier-sense CTS frame base address.
 * It's where mac stores carrier-sense frame for carrier-sense function.
 */
#define HW_CS_CTS_BASE            0x7700
 
/*
 * HW_DFS_CTS_BASE:
 * DFS CTS frame base address. It's where mac stores CTS frame for DFS.
 */
#define HW_DFS_CTS_BASE            0x7780
 
/*
 * TXRX control registers - base address 0x3000
 */
 
/*
 * TXRX_CSR1:
 * rt2860b  UNKNOWN reg use R/O Reg Addr 0x77d0 first..
 */
#define TXRX_CSR1            0x77d0
 
/*
 * HW_DEBUG_SETTING_BASE:
 * since NULL frame won't be that long (256 byte)
 * We steal 16 tail bytes to save debugging settings
 */
#define HW_DEBUG_SETTING_BASE        0x77f0
#define HW_DEBUG_SETTING_BASE2        0x7770
 
/*
 * HW_BEACON_BASE
 * In order to support maximum 8 MBSS and its maximum length
 * is 512 bytes for each beacon
 * Three section discontinue memory segments will be used.
 * 1. The original region for BCN 0~3
 * 2. Extract memory from FCE table for BCN 4~5
 * 3. Extract memory from Pair-wise key table for BCN 6~7
 *    It occupied those memory of wcid 238~253 for BCN 6
 *    and wcid 222~237 for BCN 7 (see Security key table memory
 *    for more info).
 *
 * IMPORTANT NOTE: Not sure why legacy driver does this,
 * but HW_BEACON_BASE7 is 0x0200 bytes below HW_BEACON_BASE6.
 */
#define HW_BEACON_BASE0            0x7800
#define HW_BEACON_BASE1            0x7a00
#define HW_BEACON_BASE2            0x7c00
#define HW_BEACON_BASE3            0x7e00
#define HW_BEACON_BASE4            0x7200
#define HW_BEACON_BASE5            0x7400
#define HW_BEACON_BASE6            0x5dc0
#define HW_BEACON_BASE7            0x5bc0
 
#define HW_BEACON_BASE(__index) \
   (((__index) < 4) ? (HW_BEACON_BASE0 + (__index * 0x0200)) : \
     (((__index) < 6) ? (HW_BEACON_BASE4 + ((__index - 4) * 0x0200)) : \
     (HW_BEACON_BASE6 - ((__index - 6) * 0x0200))))
 
#define BEACON_BASE_TO_OFFSET(_base)    (((_base) - 0x4000) / 64)
 
/*
 * BBP registers.
 * The wordsize of the BBP is 8 bits.
 */
 
/*
 * BBP 1: TX Antenna & Power Control
 * POWER_CTRL:
 * 0 - normal,
 * 1 - drop tx power by 6dBm,
 * 2 - drop tx power by 12dBm,
 * 3 - increase tx power by 6dBm
 */
#define BBP1_TX_POWER_CTRL        FIELD8(0x03)
#define BBP1_TX_ANTENNA            FIELD8(0x18)
 
/*
 * BBP 3: RX Antenna
 */
#define BBP3_RX_ADC            FIELD8(0x03)
#define BBP3_RX_ANTENNA            FIELD8(0x18)
#define BBP3_HT40_MINUS            FIELD8(0x20)
#define BBP3_ADC_MODE_SWITCH        FIELD8(0x40)
#define BBP3_ADC_INIT_MODE        FIELD8(0x80)
 
/*
 * BBP 4: Bandwidth
 */
#define BBP4_TX_BF            FIELD8(0x01)
#define BBP4_BANDWIDTH            FIELD8(0x18)
#define BBP4_MAC_IF_CTRL        FIELD8(0x40)
 
/* BBP27 */
#define BBP27_RX_CHAIN_SEL        FIELD8(0x60)
 
/*
 * BBP 47: Bandwidth
 */
#define BBP47_TSSI_REPORT_SEL        FIELD8(0x03)
#define BBP47_TSSI_UPDATE_REQ        FIELD8(0x04)
#define BBP47_TSSI_TSSI_MODE        FIELD8(0x18)
#define BBP47_TSSI_ADC6            FIELD8(0x80)
 
/*
 * BBP 49
 */
#define BBP49_UPDATE_FLAG        FIELD8(0x01)
 
/*
 * BBP 105:
 * - bit0: detect SIG on primary channel only (on 40MHz bandwidth)
 * - bit1: FEQ (Feed Forward Compensation) for independend streams
 * - bit2: MLD (Maximum Likehood Detection) for 2 streams (reserved on single
 *       stream)
 * - bit4: channel estimation updates based on remodulation of
 *       L-SIG and HT-SIG symbols
 */
#define BBP105_DETECT_SIG_ON_PRIMARY    FIELD8(0x01)
#define BBP105_FEQ            FIELD8(0x02)
#define BBP105_MLD            FIELD8(0x04)
#define BBP105_SIG_REMODULATION        FIELD8(0x08)
 
/*
 * BBP 109
 */
#define BBP109_TX0_POWER        FIELD8(0x0f)
#define BBP109_TX1_POWER        FIELD8(0xf0)
 
/* BBP 110 */
#define BBP110_TX2_POWER        FIELD8(0x0f)
 
 
/*
 * BBP 138: Unknown
 */
#define BBP138_RX_ADC1            FIELD8(0x02)
#define BBP138_RX_ADC2            FIELD8(0x04)
#define BBP138_TX_DAC1            FIELD8(0x20)
#define BBP138_TX_DAC2            FIELD8(0x40)
 
/*
 * BBP 152: Rx Ant
 */
#define BBP152_RX_DEFAULT_ANT        FIELD8(0x80)
 
/*
 * BBP 254: unknown
 */
#define BBP254_BIT7            FIELD8(0x80)
 
/*
 * RFCSR registers
 * The wordsize of the RFCSR is 8 bits.
 */
 
/*
 * RFCSR 1:
 */
#define RFCSR1_RF_BLOCK_EN        FIELD8(0x01)
#define RFCSR1_PLL_PD            FIELD8(0x02)
#define RFCSR1_RX0_PD            FIELD8(0x04)
#define RFCSR1_TX0_PD            FIELD8(0x08)
#define RFCSR1_RX1_PD            FIELD8(0x10)
#define RFCSR1_TX1_PD            FIELD8(0x20)
#define RFCSR1_RX2_PD            FIELD8(0x40)
#define RFCSR1_TX2_PD            FIELD8(0x80)
#define RFCSR1_TX2_EN_MT7620        FIELD8(0x02)
 
/*
 * RFCSR 2:
 */
#define RFCSR2_RESCAL_BP        FIELD8(0x40)
#define RFCSR2_RESCAL_EN        FIELD8(0x80)
#define RFCSR2_RX2_EN_MT7620        FIELD8(0x02)
#define RFCSR2_TX2_EN_MT7620        FIELD8(0x20)
 
/*
 * RFCSR 3:
 */
#define RFCSR3_K            FIELD8(0x0f)
/* Bits [7-4] for RF3320 (RT3370/RT3390), on other chipsets reserved */
#define RFCSR3_PA1_BIAS_CCK        FIELD8(0x70)
#define RFCSR3_PA2_CASCODE_BIAS_CCKK    FIELD8(0x80)
/* Bits for RF3290/RF5360/RF5362/RF5370/RF5372/RF5390/RF5392 */
#define RFCSR3_VCOCAL_EN        FIELD8(0x80)
/* Bits for RF3050 */
#define RFCSR3_BIT1            FIELD8(0x02)
#define RFCSR3_BIT2            FIELD8(0x04)
#define RFCSR3_BIT3            FIELD8(0x08)
#define RFCSR3_BIT4            FIELD8(0x10)
#define RFCSR3_BIT5            FIELD8(0x20)
 
/*
 * RFCSR 4:
 * VCOCAL_EN used by MT7620
 */
#define RFCSR4_VCOCAL_EN        FIELD8(0x80)
 
/*
 * FRCSR 5:
 */
#define RFCSR5_R1            FIELD8(0x0c)
 
/*
 * RFCSR 6:
 */
#define RFCSR6_R1            FIELD8(0x03)
#define RFCSR6_R2            FIELD8(0x40)
#define RFCSR6_TXDIV            FIELD8(0x0c)
/* bits for RF3053 */
#define RFCSR6_VCO_IC            FIELD8(0xc0)
 
/*
 * RFCSR 7:
 */
#define RFCSR7_RF_TUNING        FIELD8(0x01)
#define RFCSR7_BIT1            FIELD8(0x02)
#define RFCSR7_BIT2            FIELD8(0x04)
#define RFCSR7_BIT3            FIELD8(0x08)
#define RFCSR7_BIT4            FIELD8(0x10)
#define RFCSR7_BIT5            FIELD8(0x20)
#define RFCSR7_BITS67            FIELD8(0xc0)
 
/*
 * RFCSR 9:
 */
#define RFCSR9_K            FIELD8(0x0f)
#define RFCSR9_N            FIELD8(0x10)
#define RFCSR9_UNKNOWN            FIELD8(0x60)
#define RFCSR9_MOD            FIELD8(0x80)
 
/*
 * RFCSR 11:
 */
#define RFCSR11_R            FIELD8(0x03)
#define RFCSR11_PLL_MOD            FIELD8(0x0c)
#define RFCSR11_MOD            FIELD8(0xc0)
/* bits for RF3053 */
/* TODO: verify RFCSR11_MOD usage on other chips */
#define RFCSR11_PLL_IDOH        FIELD8(0x40)
 
 
/*
 * RFCSR 12:
 */
#define RFCSR12_TX_POWER        FIELD8(0x1f)
#define RFCSR12_DR0            FIELD8(0xe0)
 
/*
 * RFCSR 13:
 */
#define RFCSR13_TX_POWER        FIELD8(0x1f)
#define RFCSR13_DR0            FIELD8(0xe0)
#define RFCSR13_RDIV_MT7620        FIELD8(0x03)
 
/*
 * RFCSR 15:
 */
#define RFCSR15_TX_LO2_EN        FIELD8(0x08)
 
/*
 * RFCSR 16:
 */
#define RFCSR16_TXMIXER_GAIN        FIELD8(0x07)
#define RFCSR16_RF_PLL_FREQ_SEL_MT7620    FIELD8(0x0F)
#define RFCSR16_SDM_MODE_MT7620        FIELD8(0xE0)
 
/*
 * RFCSR 17:
 */
#define RFCSR17_TXMIXER_GAIN        FIELD8(0x07)
#define RFCSR17_TX_LO1_EN        FIELD8(0x08)
#define RFCSR17_R            FIELD8(0x20)
#define RFCSR17_CODE            FIELD8(0x7f)
 
/* RFCSR 18 */
#define RFCSR18_XO_TUNE_BYPASS        FIELD8(0x40)
 
/* RFCSR 19 */
#define RFCSR19_K            FIELD8(0x03)
 
/*
 * RFCSR 20:
 */
#define RFCSR20_RX_LO1_EN        FIELD8(0x08)
 
/*
 * RFCSR 21:
 */
#define RFCSR21_RX_LO2_EN        FIELD8(0x08)
#define RFCSR21_BIT1            FIELD8(0x01)
#define RFCSR21_BIT8            FIELD8(0x80)
 
/*
 * RFCSR 22:
 */
#define RFCSR22_BASEBAND_LOOPBACK    FIELD8(0x01)
#define RFCSR22_FREQPLAN_D_MT7620    FIELD8(0x07)
 
/*
 * RFCSR 23:
 */
#define RFCSR23_FREQ_OFFSET        FIELD8(0x7f)
 
/*
 * RFCSR 24:
 */
#define RFCSR24_TX_AGC_FC        FIELD8(0x1f)
#define RFCSR24_TX_H20M            FIELD8(0x20)
#define RFCSR24_TX_CALIB        FIELD8(0x7f)
 
/*
 * RFCSR 27:
 */
#define RFCSR27_R1            FIELD8(0x03)
#define RFCSR27_R2            FIELD8(0x04)
#define RFCSR27_R3            FIELD8(0x30)
#define RFCSR27_R4            FIELD8(0x40)
 
/*
 * RFCSR 28:
 */
#define RFCSR28_CH11_HT40        FIELD8(0x04)
 
/*
 * RFCSR 29:
 */
#define RFCSR29_ADC6_TEST        FIELD8(0x01)
#define RFCSR29_ADC6_INT_TEST        FIELD8(0x02)
#define RFCSR29_RSSI_RESET        FIELD8(0x04)
#define RFCSR29_RSSI_ON            FIELD8(0x08)
#define RFCSR29_RSSI_RIP_CTRL        FIELD8(0x30)
#define RFCSR29_RSSI_GAIN        FIELD8(0xc0)
 
/*
 * RFCSR 30:
 */
#define RFCSR30_TX_H20M            FIELD8(0x02)
#define RFCSR30_RX_H20M            FIELD8(0x04)
#define RFCSR30_RX_VCM            FIELD8(0x18)
#define RFCSR30_RF_CALIBRATION        FIELD8(0x80)
#define RF3322_RFCSR30_TX_H20M        FIELD8(0x01)
#define RF3322_RFCSR30_RX_H20M        FIELD8(0x02)
 
/*
 * RFCSR 31:
 */
#define RFCSR31_RX_AGC_FC        FIELD8(0x1f)
#define RFCSR31_RX_H20M            FIELD8(0x20)
#define RFCSR31_RX_CALIB        FIELD8(0x7f)
 
/* RFCSR 32 bits for RF3053 */
#define RFCSR32_TX_AGC_FC        FIELD8(0xf8)
 
/* RFCSR 36 bits for RF3053 */
#define RFCSR36_RF_BS            FIELD8(0x80)
 
/*
 * RFCSR 34:
 */
#define RFCSR34_TX0_EXT_PA        FIELD8(0x04)
#define RFCSR34_TX1_EXT_PA        FIELD8(0x08)
 
/*
 * RFCSR 38:
 */
#define RFCSR38_RX_LO1_EN        FIELD8(0x20)
 
/*
 * RFCSR 39:
 */
#define RFCSR39_RX_DIV            FIELD8(0x40)
#define RFCSR39_RX_LO2_EN        FIELD8(0x80)
 
/*
 * RFCSR 41:
 */
#define RFCSR41_BIT1            FIELD8(0x01)
#define RFCSR41_BIT4            FIELD8(0x08)
 
/*
 * RFCSR 42:
 */
#define RFCSR42_BIT1            FIELD8(0x01)
#define RFCSR42_BIT4            FIELD8(0x08)
#define RFCSR42_TX2_EN_MT7620        FIELD8(0x40)
 
/*
 * RFCSR 49:
 */
#define RFCSR49_TX            FIELD8(0x3f)
#define RFCSR49_EP            FIELD8(0xc0)
/* bits for RT3593 */
#define RFCSR49_TX_LO1_IC        FIELD8(0x1c)
#define RFCSR49_TX_DIV            FIELD8(0x20)
 
/*
 * RFCSR 50:
 */
#define RFCSR50_TX            FIELD8(0x3f)
#define RFCSR50_TX0_EXT_PA        FIELD8(0x02)
#define RFCSR50_TX1_EXT_PA        FIELD8(0x10)
#define RFCSR50_EP            FIELD8(0xc0)
/* bits for RT3593 */
#define RFCSR50_TX_LO1_EN        FIELD8(0x20)
#define RFCSR50_TX_LO2_EN        FIELD8(0x10)
 
/* RFCSR 51 */
/* bits for RT3593 */
#define RFCSR51_BITS01            FIELD8(0x03)
#define RFCSR51_BITS24            FIELD8(0x1c)
#define RFCSR51_BITS57            FIELD8(0xe0)
 
#define RFCSR53_TX_POWER        FIELD8(0x3f)
#define RFCSR53_UNKNOWN            FIELD8(0xc0)
 
#define RFCSR54_TX_POWER        FIELD8(0x3f)
#define RFCSR54_UNKNOWN            FIELD8(0xc0)
 
#define RFCSR55_TX_POWER        FIELD8(0x3f)
#define RFCSR55_UNKNOWN            FIELD8(0xc0)
 
#define RFCSR57_DRV_CC            FIELD8(0xfc)
 
 
/*
 * RF registers
 */
 
/*
 * RF 2
 */
#define RF2_ANTENNA_RX2            FIELD32(0x00000040)
#define RF2_ANTENNA_TX1            FIELD32(0x00004000)
#define RF2_ANTENNA_RX1            FIELD32(0x00020000)
 
/*
 * RF 3
 */
#define RF3_TXPOWER_G            FIELD32(0x00003e00)
#define RF3_TXPOWER_A_7DBM_BOOST    FIELD32(0x00000200)
#define RF3_TXPOWER_A            FIELD32(0x00003c00)
 
/*
 * RF 4
 */
#define RF4_TXPOWER_G            FIELD32(0x000007c0)
#define RF4_TXPOWER_A_7DBM_BOOST    FIELD32(0x00000040)
#define RF4_TXPOWER_A            FIELD32(0x00000780)
#define RF4_FREQ_OFFSET            FIELD32(0x001f8000)
#define RF4_HT40            FIELD32(0x00200000)
 
/*
 * EEPROM content.
 * The wordsize of the EEPROM is 16 bits.
 */
 
enum rt2800_eeprom_word {
   EEPROM_CHIP_ID = 0,
   EEPROM_VERSION,
   EEPROM_MAC_ADDR_0,
   EEPROM_MAC_ADDR_1,
   EEPROM_MAC_ADDR_2,
   EEPROM_NIC_CONF0,
   EEPROM_NIC_CONF1,
   EEPROM_FREQ,
   EEPROM_LED_AG_CONF,
   EEPROM_LED_ACT_CONF,
   EEPROM_LED_POLARITY,
   EEPROM_NIC_CONF2,
   EEPROM_LNA,
   EEPROM_RSSI_BG,
   EEPROM_RSSI_BG2,
   EEPROM_TXMIXER_GAIN_BG,
   EEPROM_RSSI_A,
   EEPROM_RSSI_A2,
   EEPROM_TXMIXER_GAIN_A,
   EEPROM_EIRP_MAX_TX_POWER,
   EEPROM_TXPOWER_DELTA,
   EEPROM_TXPOWER_BG1,
   EEPROM_TXPOWER_BG2,
   EEPROM_TSSI_BOUND_BG1,
   EEPROM_TSSI_BOUND_BG2,
   EEPROM_TSSI_BOUND_BG3,
   EEPROM_TSSI_BOUND_BG4,
   EEPROM_TSSI_BOUND_BG5,
   EEPROM_TXPOWER_A1,
   EEPROM_TXPOWER_A2,
   EEPROM_TXPOWER_INIT,
   EEPROM_TSSI_BOUND_A1,
   EEPROM_TSSI_BOUND_A2,
   EEPROM_TSSI_BOUND_A3,
   EEPROM_TSSI_BOUND_A4,
   EEPROM_TSSI_BOUND_A5,
   EEPROM_TXPOWER_BYRATE,
   EEPROM_BBP_START,
 
   /* IDs for extended EEPROM format used by three-chain devices */
   EEPROM_EXT_LNA2,
   EEPROM_EXT_TXPOWER_BG3,
   EEPROM_EXT_TXPOWER_A3,
 
   /* New values must be added before this */
   EEPROM_WORD_COUNT
};
 
/*
 * EEPROM Version
 */
#define EEPROM_VERSION_FAE        FIELD16(0x00ff)
#define EEPROM_VERSION_VERSION        FIELD16(0xff00)
 
/*
 * HW MAC address.
 */
#define EEPROM_MAC_ADDR_BYTE0        FIELD16(0x00ff)
#define EEPROM_MAC_ADDR_BYTE1        FIELD16(0xff00)
#define EEPROM_MAC_ADDR_BYTE2        FIELD16(0x00ff)
#define EEPROM_MAC_ADDR_BYTE3        FIELD16(0xff00)
#define EEPROM_MAC_ADDR_BYTE4        FIELD16(0x00ff)
#define EEPROM_MAC_ADDR_BYTE5        FIELD16(0xff00)
 
/*
 * EEPROM NIC Configuration 0
 * RXPATH: 1: 1R, 2: 2R, 3: 3R
 * TXPATH: 1: 1T, 2: 2T, 3: 3T
 * RF_TYPE: RFIC type
 */
#define EEPROM_NIC_CONF0_RXPATH        FIELD16(0x000f)
#define EEPROM_NIC_CONF0_TXPATH        FIELD16(0x00f0)
#define EEPROM_NIC_CONF0_RF_TYPE    FIELD16(0x0f00)
 
/*
 * EEPROM NIC Configuration 1
 * HW_RADIO: 0: disable, 1: enable
 * EXTERNAL_TX_ALC: 0: disable, 1: enable
 * EXTERNAL_LNA_2G: 0: disable, 1: enable
 * EXTERNAL_LNA_5G: 0: disable, 1: enable
 * CARDBUS_ACCEL: 0: enable, 1: disable
 * BW40M_SB_2G: 0: disable, 1: enable
 * BW40M_SB_5G: 0: disable, 1: enable
 * WPS_PBC: 0: disable, 1: enable
 * BW40M_2G: 0: enable, 1: disable
 * BW40M_5G: 0: enable, 1: disable
 * BROADBAND_EXT_LNA: 0: disable, 1: enable
 * ANT_DIVERSITY: 00: Disable, 01: Diversity,
 *                   10: Main antenna, 11: Aux antenna
 * INTERNAL_TX_ALC: 0: disable, 1: enable
 * BT_COEXIST: 0: disable, 1: enable
 * DAC_TEST: 0: disable, 1: enable
 * EXTERNAL_TX0_PA: 0: disable, 1: enable (only on RT3352)
 * EXTERNAL_TX1_PA: 0: disable, 1: enable (only on RT3352)
 */
#define EEPROM_NIC_CONF1_HW_RADIO        FIELD16(0x0001)
#define EEPROM_NIC_CONF1_EXTERNAL_TX_ALC    FIELD16(0x0002)
#define EEPROM_NIC_CONF1_EXTERNAL_LNA_2G    FIELD16(0x0004)
#define EEPROM_NIC_CONF1_EXTERNAL_LNA_5G    FIELD16(0x0008)
#define EEPROM_NIC_CONF1_CARDBUS_ACCEL        FIELD16(0x0010)
#define EEPROM_NIC_CONF1_BW40M_SB_2G        FIELD16(0x0020)
#define EEPROM_NIC_CONF1_BW40M_SB_5G        FIELD16(0x0040)
#define EEPROM_NIC_CONF1_WPS_PBC        FIELD16(0x0080)
#define EEPROM_NIC_CONF1_BW40M_2G        FIELD16(0x0100)
#define EEPROM_NIC_CONF1_BW40M_5G        FIELD16(0x0200)
#define EEPROM_NIC_CONF1_BROADBAND_EXT_LNA    FIELD16(0x400)
#define EEPROM_NIC_CONF1_ANT_DIVERSITY        FIELD16(0x1800)
#define EEPROM_NIC_CONF1_INTERNAL_TX_ALC    FIELD16(0x2000)
#define EEPROM_NIC_CONF1_BT_COEXIST        FIELD16(0x4000)
#define EEPROM_NIC_CONF1_DAC_TEST        FIELD16(0x8000)
#define EEPROM_NIC_CONF1_EXTERNAL_TX0_PA_3352    FIELD16(0x4000)
#define EEPROM_NIC_CONF1_EXTERNAL_TX1_PA_3352    FIELD16(0x8000)
 
/*
 * EEPROM frequency
 */
#define EEPROM_FREQ_OFFSET        FIELD16(0x00ff)
#define EEPROM_FREQ_LED_MODE        FIELD16(0x7f00)
#define EEPROM_FREQ_LED_POLARITY    FIELD16(0x1000)
 
/*
 * EEPROM LED
 * POLARITY_RDY_G: Polarity RDY_G setting.
 * POLARITY_RDY_A: Polarity RDY_A setting.
 * POLARITY_ACT: Polarity ACT setting.
 * POLARITY_GPIO_0: Polarity GPIO0 setting.
 * POLARITY_GPIO_1: Polarity GPIO1 setting.
 * POLARITY_GPIO_2: Polarity GPIO2 setting.
 * POLARITY_GPIO_3: Polarity GPIO3 setting.
 * POLARITY_GPIO_4: Polarity GPIO4 setting.
 * LED_MODE: Led mode.
 */
#define EEPROM_LED_POLARITY_RDY_BG    FIELD16(0x0001)
#define EEPROM_LED_POLARITY_RDY_A    FIELD16(0x0002)
#define EEPROM_LED_POLARITY_ACT        FIELD16(0x0004)
#define EEPROM_LED_POLARITY_GPIO_0    FIELD16(0x0008)
#define EEPROM_LED_POLARITY_GPIO_1    FIELD16(0x0010)
#define EEPROM_LED_POLARITY_GPIO_2    FIELD16(0x0020)
#define EEPROM_LED_POLARITY_GPIO_3    FIELD16(0x0040)
#define EEPROM_LED_POLARITY_GPIO_4    FIELD16(0x0080)
#define EEPROM_LED_LED_MODE        FIELD16(0x1f00)
 
/*
 * EEPROM NIC Configuration 2
 * RX_STREAM: 0: Reserved, 1: 1 Stream, 2: 2 Stream
 * TX_STREAM: 0: Reserved, 1: 1 Stream, 2: 2 Stream
 * CRYSTAL: 00: Reserved, 01: One crystal, 10: Two crystal, 11: Reserved
 */
#define EEPROM_NIC_CONF2_RX_STREAM    FIELD16(0x000f)
#define EEPROM_NIC_CONF2_TX_STREAM    FIELD16(0x00f0)
#define EEPROM_NIC_CONF2_CRYSTAL    FIELD16(0x0600)
 
/*
 * EEPROM LNA
 */
#define EEPROM_LNA_BG            FIELD16(0x00ff)
#define EEPROM_LNA_A0            FIELD16(0xff00)
 
/*
 * EEPROM RSSI BG offset
 */
#define EEPROM_RSSI_BG_OFFSET0        FIELD16(0x00ff)
#define EEPROM_RSSI_BG_OFFSET1        FIELD16(0xff00)
 
/*
 * EEPROM RSSI BG2 offset
 */
#define EEPROM_RSSI_BG2_OFFSET2        FIELD16(0x00ff)
#define EEPROM_RSSI_BG2_LNA_A1        FIELD16(0xff00)
 
/*
 * EEPROM TXMIXER GAIN BG offset (note overlaps with EEPROM RSSI BG2).
 */
#define EEPROM_TXMIXER_GAIN_BG_VAL    FIELD16(0x0007)
 
/*
 * EEPROM RSSI A offset
 */
#define EEPROM_RSSI_A_OFFSET0        FIELD16(0x00ff)
#define EEPROM_RSSI_A_OFFSET1        FIELD16(0xff00)
 
/*
 * EEPROM RSSI A2 offset
 */
#define EEPROM_RSSI_A2_OFFSET2        FIELD16(0x00ff)
#define EEPROM_RSSI_A2_LNA_A2        FIELD16(0xff00)
 
/*
 * EEPROM TXMIXER GAIN A offset (note overlaps with EEPROM RSSI A2).
 */
#define EEPROM_TXMIXER_GAIN_A_VAL    FIELD16(0x0007)
 
/*
 * EEPROM EIRP Maximum TX power values(unit: dbm)
 */
#define EEPROM_EIRP_MAX_TX_POWER_2GHZ    FIELD16(0x00ff)
#define EEPROM_EIRP_MAX_TX_POWER_5GHZ    FIELD16(0xff00)
 
/*
 * EEPROM TXpower delta: 20MHZ AND 40 MHZ use different power.
 * This is delta in 40MHZ.
 * VALUE: Tx Power dalta value, MAX=4(unit: dbm)
 * TYPE: 1: Plus the delta value, 0: minus the delta value
 * ENABLE: enable tx power compensation for 40BW
 */
#define EEPROM_TXPOWER_DELTA_VALUE_2G    FIELD16(0x003f)
#define EEPROM_TXPOWER_DELTA_TYPE_2G    FIELD16(0x0040)
#define EEPROM_TXPOWER_DELTA_ENABLE_2G    FIELD16(0x0080)
#define EEPROM_TXPOWER_DELTA_VALUE_5G    FIELD16(0x3f00)
#define EEPROM_TXPOWER_DELTA_TYPE_5G    FIELD16(0x4000)
#define EEPROM_TXPOWER_DELTA_ENABLE_5G    FIELD16(0x8000)
 
/*
 * EEPROM TXPOWER 802.11BG
 */
#define EEPROM_TXPOWER_BG_SIZE        7
#define EEPROM_TXPOWER_BG_1        FIELD16(0x00ff)
#define EEPROM_TXPOWER_BG_2        FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11BG
 * MINUS4: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -4)
 * MINUS3: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -3)
 */
#define EEPROM_TSSI_BOUND_BG1_MINUS4    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_BG1_MINUS3    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11BG
 * MINUS2: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -2)
 * MINUS1: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -1)
 */
#define EEPROM_TSSI_BOUND_BG2_MINUS2    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_BG2_MINUS1    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11BG
 * REF: Reference TSSI value, no tx power changes needed
 * PLUS1: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 1)
 */
#define EEPROM_TSSI_BOUND_BG3_REF    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_BG3_PLUS1    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11BG
 * PLUS2: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 2)
 * PLUS3: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 3)
 */
#define EEPROM_TSSI_BOUND_BG4_PLUS2    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_BG4_PLUS3    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11BG
 * PLUS4: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 4)
 * AGC_STEP: Temperature compensation step.
 */
#define EEPROM_TSSI_BOUND_BG5_PLUS4    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_BG5_AGC_STEP    FIELD16(0xff00)
 
/*
 * EEPROM TXPOWER 802.11A
 */
#define EEPROM_TXPOWER_A_SIZE        6
#define EEPROM_TXPOWER_A_1        FIELD16(0x00ff)
#define EEPROM_TXPOWER_A_2        FIELD16(0xff00)
 
/* EEPROM_TXPOWER_{A,G} fields for RT3593 */
#define EEPROM_TXPOWER_ALC        FIELD8(0x1f)
#define EEPROM_TXPOWER_FINE_CTRL    FIELD8(0xe0)
 
/*
 * EEPROM temperature compensation boundaries 802.11A
 * MINUS4: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -4)
 * MINUS3: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -3)
 */
#define EEPROM_TSSI_BOUND_A1_MINUS4    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_A1_MINUS3    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11A
 * MINUS2: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -2)
 * MINUS1: If the actual TSSI is below this boundary, tx power needs to be
 *         reduced by (agc_step * -1)
 */
#define EEPROM_TSSI_BOUND_A2_MINUS2    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_A2_MINUS1    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11A
 * REF: Reference TSSI value, no tx power changes needed
 * PLUS1: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 1)
 */
#define EEPROM_TSSI_BOUND_A3_REF    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_A3_PLUS1    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11A
 * PLUS2: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 2)
 * PLUS3: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 3)
 */
#define EEPROM_TSSI_BOUND_A4_PLUS2    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_A4_PLUS3    FIELD16(0xff00)
 
/*
 * EEPROM temperature compensation boundaries 802.11A
 * PLUS4: If the actual TSSI is above this boundary, tx power needs to be
 *        increased by (agc_step * 4)
 * AGC_STEP: Temperature compensation step.
 */
#define EEPROM_TSSI_BOUND_A5_PLUS4    FIELD16(0x00ff)
#define EEPROM_TSSI_BOUND_A5_AGC_STEP    FIELD16(0xff00)
 
/*
 * EEPROM TXPOWER by rate: tx power per tx rate for HT20 mode
 */
#define EEPROM_TXPOWER_BYRATE_SIZE    9
 
#define EEPROM_TXPOWER_BYRATE_RATE0    FIELD16(0x000f)
#define EEPROM_TXPOWER_BYRATE_RATE1    FIELD16(0x00f0)
#define EEPROM_TXPOWER_BYRATE_RATE2    FIELD16(0x0f00)
#define EEPROM_TXPOWER_BYRATE_RATE3    FIELD16(0xf000)
 
/*
 * EEPROM BBP.
 */
#define EEPROM_BBP_SIZE            16
#define EEPROM_BBP_VALUE        FIELD16(0x00ff)
#define EEPROM_BBP_REG_ID        FIELD16(0xff00)
 
/* EEPROM_EXT_LNA2 */
#define EEPROM_EXT_LNA2_A1        FIELD16(0x00ff)
#define EEPROM_EXT_LNA2_A2        FIELD16(0xff00)
 
/*
 * EEPROM IQ Calibration, unlike other entries those are byte addresses.
 */
 
#define EEPROM_IQ_GAIN_CAL_TX0_2G            0x130
#define EEPROM_IQ_PHASE_CAL_TX0_2G            0x131
#define EEPROM_IQ_GROUPDELAY_CAL_TX0_2G            0x132
#define EEPROM_IQ_GAIN_CAL_TX1_2G            0x133
#define EEPROM_IQ_PHASE_CAL_TX1_2G            0x134
#define EEPROM_IQ_GROUPDELAY_CAL_TX1_2G            0x135
#define EEPROM_IQ_GAIN_CAL_RX0_2G            0x136
#define EEPROM_IQ_PHASE_CAL_RX0_2G            0x137
#define EEPROM_IQ_GROUPDELAY_CAL_RX0_2G            0x138
#define EEPROM_IQ_GAIN_CAL_RX1_2G            0x139
#define EEPROM_IQ_PHASE_CAL_RX1_2G            0x13A
#define EEPROM_IQ_GROUPDELAY_CAL_RX1_2G            0x13B
#define EEPROM_RF_IQ_COMPENSATION_CONTROL        0x13C
#define EEPROM_RF_IQ_IMBALANCE_COMPENSATION_CONTROL    0x13D
#define EEPROM_IQ_GAIN_CAL_TX0_CH36_TO_CH64_5G        0x144
#define EEPROM_IQ_PHASE_CAL_TX0_CH36_TO_CH64_5G        0x145
#define EEPROM_IQ_GAIN_CAL_TX0_CH100_TO_CH138_5G    0X146
#define EEPROM_IQ_PHASE_CAL_TX0_CH100_TO_CH138_5G    0x147
#define EEPROM_IQ_GAIN_CAL_TX0_CH140_TO_CH165_5G    0x148
#define EEPROM_IQ_PHASE_CAL_TX0_CH140_TO_CH165_5G    0x149
#define EEPROM_IQ_GAIN_CAL_TX1_CH36_TO_CH64_5G        0x14A
#define EEPROM_IQ_PHASE_CAL_TX1_CH36_TO_CH64_5G        0x14B
#define EEPROM_IQ_GAIN_CAL_TX1_CH100_TO_CH138_5G    0X14C
#define EEPROM_IQ_PHASE_CAL_TX1_CH100_TO_CH138_5G    0x14D
#define EEPROM_IQ_GAIN_CAL_TX1_CH140_TO_CH165_5G    0x14E
#define EEPROM_IQ_PHASE_CAL_TX1_CH140_TO_CH165_5G    0x14F
#define EEPROM_IQ_GROUPDELAY_CAL_TX0_CH36_TO_CH64_5G    0x150
#define EEPROM_IQ_GROUPDELAY_CAL_TX1_CH36_TO_CH64_5G    0x151
#define EEPROM_IQ_GROUPDELAY_CAL_TX0_CH100_TO_CH138_5G    0x152
#define EEPROM_IQ_GROUPDELAY_CAL_TX1_CH100_TO_CH138_5G    0x153
#define EEPROM_IQ_GROUPDELAY_CAL_TX0_CH140_TO_CH165_5G    0x154
#define EEPROM_IQ_GROUPDELAY_CAL_TX1_CH140_TO_CH165_5G    0x155
#define EEPROM_IQ_GAIN_CAL_RX0_CH36_TO_CH64_5G        0x156
#define EEPROM_IQ_PHASE_CAL_RX0_CH36_TO_CH64_5G        0x157
#define EEPROM_IQ_GAIN_CAL_RX0_CH100_TO_CH138_5G    0X158
#define EEPROM_IQ_PHASE_CAL_RX0_CH100_TO_CH138_5G    0x159
#define EEPROM_IQ_GAIN_CAL_RX0_CH140_TO_CH165_5G    0x15A
#define EEPROM_IQ_PHASE_CAL_RX0_CH140_TO_CH165_5G    0x15B
#define EEPROM_IQ_GAIN_CAL_RX1_CH36_TO_CH64_5G        0x15C
#define EEPROM_IQ_PHASE_CAL_RX1_CH36_TO_CH64_5G        0x15D
#define EEPROM_IQ_GAIN_CAL_RX1_CH100_TO_CH138_5G    0X15E
#define EEPROM_IQ_PHASE_CAL_RX1_CH100_TO_CH138_5G    0x15F
#define EEPROM_IQ_GAIN_CAL_RX1_CH140_TO_CH165_5G    0x160
#define EEPROM_IQ_PHASE_CAL_RX1_CH140_TO_CH165_5G    0x161
#define EEPROM_IQ_GROUPDELAY_CAL_RX0_CH36_TO_CH64_5G    0x162
#define EEPROM_IQ_GROUPDELAY_CAL_RX1_CH36_TO_CH64_5G    0x163
#define EEPROM_IQ_GROUPDELAY_CAL_RX0_CH100_TO_CH138_5G    0x164
#define EEPROM_IQ_GROUPDELAY_CAL_RX1_CH100_TO_CH138_5G    0x165
#define EEPROM_IQ_GROUPDELAY_CAL_RX0_CH140_TO_CH165_5G    0x166
#define EEPROM_IQ_GROUPDELAY_CAL_RX1_CH140_TO_CH165_5G    0x167
 
/*
 * MCU mailbox commands.
 * MCU_SLEEP - go to power-save mode.
 *             arg1: 1: save as much power as possible, 0: save less power.
 *             status: 1: success, 2: already asleep,
 *                     3: maybe MAC is busy so can't finish this task.
 * MCU_RADIO_OFF
 *             arg0: 0: do power-saving, NOT turn off radio.
 */
#define MCU_SLEEP            0x30
#define MCU_WAKEUP            0x31
#define MCU_RADIO_OFF            0x35
#define MCU_CURRENT            0x36
#define MCU_LED                0x50
#define MCU_LED_STRENGTH        0x51
#define MCU_LED_AG_CONF            0x52
#define MCU_LED_ACT_CONF        0x53
#define MCU_LED_LED_POLARITY        0x54
#define MCU_RADAR            0x60
#define MCU_BOOT_SIGNAL            0x72
#define MCU_ANT_SELECT            0X73
#define MCU_FREQ_OFFSET            0x74
#define MCU_BBP_SIGNAL            0x80
#define MCU_POWER_SAVE            0x83
#define MCU_BAND_SELECT            0x91
 
/*
 * MCU mailbox tokens
 */
#define TOKEN_SLEEP            1
#define TOKEN_RADIO_OFF            2
#define TOKEN_WAKEUP            3
 
 
/*
 * DMA descriptor defines.
 */
 
#define TXWI_DESC_SIZE_4WORDS        (4 * sizeof(__le32))
#define TXWI_DESC_SIZE_5WORDS        (5 * sizeof(__le32))
 
#define RXWI_DESC_SIZE_4WORDS        (4 * sizeof(__le32))
#define RXWI_DESC_SIZE_5WORDS        (5 * sizeof(__le32))
#define RXWI_DESC_SIZE_6WORDS        (6 * sizeof(__le32))
 
/*
 * TX WI structure
 */
 
/*
 * Word0
 * FRAG: 1 To inform TKIP engine this is a fragment.
 * MIMO_PS: The remote peer is in dynamic MIMO-PS mode
 * TX_OP: 0:HT TXOP rule , 1:PIFS TX ,2:Backoff, 3:sifs
 * BW: Channel bandwidth 0:20MHz, 1:40 MHz (for legacy rates this will
 *     duplicate the frame to both channels).
 * STBC: 1: STBC support MCS =0-7, 2,3 : RESERVED
 * AMPDU: 1: this frame is eligible for AMPDU aggregation, the hw will
 *        aggregate consecutive frames with the same RA and QoS TID. If
 *        a frame A with the same RA and QoS TID but AMPDU=0 is queued
 *        directly after a frame B with AMPDU=1, frame A might still
 *        get aggregated into the AMPDU started by frame B. So, setting
 *        AMPDU to 0 does _not_ necessarily mean the frame is sent as
 *        MPDU, it can still end up in an AMPDU if the previous frame
 *        was tagged as AMPDU.
 */
#define TXWI_W0_FRAG            FIELD32(0x00000001)
#define TXWI_W0_MIMO_PS            FIELD32(0x00000002)
#define TXWI_W0_CF_ACK            FIELD32(0x00000004)
#define TXWI_W0_TS            FIELD32(0x00000008)
#define TXWI_W0_AMPDU            FIELD32(0x00000010)
#define TXWI_W0_MPDU_DENSITY        FIELD32(0x000000e0)
#define TXWI_W0_TX_OP            FIELD32(0x00000300)
#define TXWI_W0_MCS            FIELD32(0x007f0000)
#define TXWI_W0_BW            FIELD32(0x00800000)
#define TXWI_W0_SHORT_GI        FIELD32(0x01000000)
#define TXWI_W0_STBC            FIELD32(0x06000000)
#define TXWI_W0_IFS            FIELD32(0x08000000)
#define TXWI_W0_PHYMODE            FIELD32(0xc0000000)
 
/*
 * Word1
 * ACK: 0: No Ack needed, 1: Ack needed
 * NSEQ: 0: Don't assign hw sequence number, 1: Assign hw sequence number
 * BW_WIN_SIZE: BA windows size of the recipient
 * WIRELESS_CLI_ID: Client ID for WCID table access
 * MPDU_TOTAL_BYTE_COUNT: Length of 802.11 frame
 * PACKETID: Will be latched into the TX_STA_FIFO register once the according
 *           frame was processed. If multiple frames are aggregated together
 *           (AMPDU==1) the reported tx status will always contain the packet
 *           id of the first frame. 0: Don't report tx status for this frame.
 * PACKETID_QUEUE: Part of PACKETID, This is the queue index (0-3)
 * PACKETID_ENTRY: Part of PACKETID, THis is the queue entry index (1-3)
 *                 This identification number is calculated by ((idx % 3) + 1).
 *           The (+1) is required to prevent PACKETID to become 0.
 */
#define TXWI_W1_ACK            FIELD32(0x00000001)
#define TXWI_W1_NSEQ            FIELD32(0x00000002)
#define TXWI_W1_BW_WIN_SIZE        FIELD32(0x000000fc)
#define TXWI_W1_WIRELESS_CLI_ID        FIELD32(0x0000ff00)
#define TXWI_W1_MPDU_TOTAL_BYTE_COUNT    FIELD32(0x0fff0000)
#define TXWI_W1_PACKETID        FIELD32(0xf0000000)
#define TXWI_W1_PACKETID_QUEUE        FIELD32(0x30000000)
#define TXWI_W1_PACKETID_ENTRY        FIELD32(0xc0000000)
 
/*
 * Word2
 */
#define TXWI_W2_IV            FIELD32(0xffffffff)
 
/*
 * Word3
 */
#define TXWI_W3_EIV            FIELD32(0xffffffff)
 
/*
 * RX WI structure
 */
 
/*
 * Word0
 */
#define RXWI_W0_WIRELESS_CLI_ID        FIELD32(0x000000ff)
#define RXWI_W0_KEY_INDEX        FIELD32(0x00000300)
#define RXWI_W0_BSSID            FIELD32(0x00001c00)
#define RXWI_W0_UDF            FIELD32(0x0000e000)
#define RXWI_W0_MPDU_TOTAL_BYTE_COUNT    FIELD32(0x0fff0000)
#define RXWI_W0_TID            FIELD32(0xf0000000)
 
/*
 * Word1
 */
#define RXWI_W1_FRAG            FIELD32(0x0000000f)
#define RXWI_W1_SEQUENCE        FIELD32(0x0000fff0)
#define RXWI_W1_MCS            FIELD32(0x007f0000)
#define RXWI_W1_BW            FIELD32(0x00800000)
#define RXWI_W1_SHORT_GI        FIELD32(0x01000000)
#define RXWI_W1_STBC            FIELD32(0x06000000)
#define RXWI_W1_PHYMODE            FIELD32(0xc0000000)
 
/*
 * Word2
 */
#define RXWI_W2_RSSI0            FIELD32(0x000000ff)
#define RXWI_W2_RSSI1            FIELD32(0x0000ff00)
#define RXWI_W2_RSSI2            FIELD32(0x00ff0000)
 
/*
 * Word3
 */
#define RXWI_W3_SNR0            FIELD32(0x000000ff)
#define RXWI_W3_SNR1            FIELD32(0x0000ff00)
 
/*
 * Macros for converting txpower from EEPROM to mac80211 value
 * and from mac80211 value to register value.
 */
#define MIN_G_TXPOWER    0
#define MIN_A_TXPOWER    -7
#define MAX_G_TXPOWER    31
#define MAX_A_TXPOWER    15
#define DEFAULT_TXPOWER    5
 
#define MIN_A_TXPOWER_3593    0
#define MAX_A_TXPOWER_3593    31
 
#define TXPOWER_G_FROM_DEV(__txpower) \
   ((__txpower) > MAX_G_TXPOWER) ? DEFAULT_TXPOWER : (__txpower)
 
#define TXPOWER_A_FROM_DEV(__txpower) \
   ((__txpower) > MAX_A_TXPOWER) ? DEFAULT_TXPOWER : (__txpower)
 
/*
 *  Board's maximun TX power limitation
 */
#define EIRP_MAX_TX_POWER_LIMIT    0x50
 
/*
 * Number of TBTT intervals after which we have to adjust
 * the hw beacon timer.
 */
#define BCN_TBTT_OFFSET 64
 
#endif /* RT2800_H */