1 /* SPDX-License-Identifier: GPL-2.0 */
2 /******************************************************************************
4 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
6 ******************************************************************************/
17 /* slot time for 11g */
18 #define SHORT_SLOT_TIME 9
19 #define NON_SHORT_SLOT_TIME 20
21 #define RTL8711_RF_MAX_SENS 6
22 #define RTL8711_RF_DEF_SENS 4
25 /* We now define the following channels as the max channels in each channel plan. */
26 /* 2G, total 14 chnls */
27 /* {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14} */
28 /* 5G, total 24 chnls */
29 /* {36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120,
30 * 124, 128, 132, 136, 140, 149, 153, 157, 161, 165} */
31 #define MAX_CHANNEL_NUM_2G 14
32 #define MAX_CHANNEL_NUM_5G 24
33 #define MAX_CHANNEL_NUM 38/* 14+24 */
35 #define NUM_REGULATORYS 1
39 #define EUROPE 0x1 /* temp, should be provided later */
40 #define JAPAN 0x2 /* temp, should be provided later */
42 struct regulatory_class {
43 u32 starting_freq; /* MHz, */
44 u8 channel_set[MAX_CHANNEL_NUM];
45 u8 channel_cck_power[MAX_CHANNEL_NUM];/* dbm */
46 u8 channel_ofdm_power[MAX_CHANNEL_NUM];/* dbm */
47 u8 txpower_limit; /* dbm */
48 u8 channel_spacing; /* MHz */
58 cShortPreamble = 0x0020,
60 cChannelAgility = 0x0080,
61 cSpectrumMgnt = 0x0100,
62 cQos = 0x0200, /* For HCCA, use with CF-Pollable and CF-PollReq */
63 cShortSlotTime = 0x0400,
65 cRM = 0x1000, /* RRM (Radio Request Measurement) */
68 cImmediateBA = 0x8000,
71 enum _REG_PREAMBLE_MODE {
77 enum _RTL8712_RF_MIMO_CONFIG_ {
78 RTL8712_RFCONFIG_1T = 0x10,
79 RTL8712_RFCONFIG_2T = 0x20,
80 RTL8712_RFCONFIG_1R = 0x01,
81 RTL8712_RFCONFIG_2R = 0x02,
82 RTL8712_RFCONFIG_1T1R = 0x11,
83 RTL8712_RFCONFIG_1T2R = 0x12,
84 RTL8712_RFCONFIG_TURBO = 0x92,
85 RTL8712_RFCONFIG_2T2R = 0x22
88 enum RF90_RADIO_PATH {
89 RF90_PATH_A = 0, /* Radio Path A */
90 RF90_PATH_B = 1, /* Radio Path B */
91 RF90_PATH_C = 2, /* Radio Path C */
92 RF90_PATH_D = 3 /* Radio Path D */
95 /* Bandwidth Offset */
96 #define HAL_PRIME_CHNL_OFFSET_DONT_CARE 0
97 #define HAL_PRIME_CHNL_OFFSET_LOWER 1
98 #define HAL_PRIME_CHNL_OFFSET_UPPER 2
100 /* Represent Channel Width in HT Capabilities */
102 CHANNEL_WIDTH_20 = 0,
103 CHANNEL_WIDTH_40 = 1,
104 CHANNEL_WIDTH_80 = 2,
105 CHANNEL_WIDTH_160 = 3,
106 CHANNEL_WIDTH_80_80 = 4,
107 CHANNEL_WIDTH_MAX = 5,
110 /* Represent Extension Channel Offset in HT Capabilities */
111 /* This is available only in 40Mhz mode. */
112 enum EXTCHNL_OFFSET {
113 EXTCHNL_OFFSET_NO_EXT = 0,
114 EXTCHNL_OFFSET_UPPER = 1,
115 EXTCHNL_OFFSET_NO_DEF = 2,
116 EXTCHNL_OFFSET_LOWER = 3,
120 VHT_DATA_SC_DONOT_CARE = 0,
121 VHT_DATA_SC_20_UPPER_OF_80MHZ = 1,
122 VHT_DATA_SC_20_LOWER_OF_80MHZ = 2,
123 VHT_DATA_SC_20_UPPERST_OF_80MHZ = 3,
124 VHT_DATA_SC_20_LOWEST_OF_80MHZ = 4,
125 VHT_DATA_SC_20_RECV1 = 5,
126 VHT_DATA_SC_20_RECV2 = 6,
127 VHT_DATA_SC_20_RECV3 = 7,
128 VHT_DATA_SC_20_RECV4 = 8,
129 VHT_DATA_SC_40_UPPER_OF_80MHZ = 9,
130 VHT_DATA_SC_40_LOWER_OF_80MHZ = 10,
133 enum PROTECTION_MODE {
134 PROTECTION_MODE_AUTO = 0,
135 PROTECTION_MODE_FORCE_ENABLE = 1,
136 PROTECTION_MODE_FORCE_DISABLE = 2,
139 /* 2007/11/15 MH Define different RF type. */
140 enum RT_RF_TYPE_DEFINITION {
149 u32 rtw_ch2freq(u32 ch);
151 #endif /* _RTL8711_RF_H_ */