xref: /linux/drivers/net/wireless/intel/iwlwifi/fw/acpi.h (revision 04317b129e4eb5c6f4a58bb899b2019c1545320b)
1 /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2 /*
3  * Copyright (C) 2017 Intel Deutschland GmbH
4  * Copyright (C) 2018-2023 Intel Corporation
5  */
6 #ifndef __iwl_fw_acpi__
7 #define __iwl_fw_acpi__
8 
9 #include <linux/acpi.h>
10 #include "fw/api/commands.h"
11 #include "fw/api/power.h"
12 #include "fw/api/phy.h"
13 #include "fw/api/nvm-reg.h"
14 #include "fw/api/config.h"
15 #include "fw/img.h"
16 #include "iwl-trans.h"
17 
18 
19 #define ACPI_WRDS_METHOD	"WRDS"
20 #define ACPI_EWRD_METHOD	"EWRD"
21 #define ACPI_WGDS_METHOD	"WGDS"
22 #define ACPI_WRDD_METHOD	"WRDD"
23 #define ACPI_SPLC_METHOD	"SPLC"
24 #define ACPI_ECKV_METHOD	"ECKV"
25 #define ACPI_PPAG_METHOD	"PPAG"
26 #define ACPI_WTAS_METHOD	"WTAS"
27 #define ACPI_WPFC_METHOD	"WPFC"
28 
29 #define ACPI_WIFI_DOMAIN	(0x07)
30 
31 #define ACPI_SAR_PROFILE_NUM		4
32 
33 #define ACPI_NUM_GEO_PROFILES		3
34 #define ACPI_NUM_GEO_PROFILES_REV3	8
35 #define ACPI_GEO_PER_CHAIN_SIZE		3
36 
37 #define ACPI_SAR_NUM_CHAINS_REV0	2
38 #define ACPI_SAR_NUM_CHAINS_REV1	2
39 #define ACPI_SAR_NUM_CHAINS_REV2	4
40 #define ACPI_SAR_NUM_SUB_BANDS_REV0	5
41 #define ACPI_SAR_NUM_SUB_BANDS_REV1	11
42 #define ACPI_SAR_NUM_SUB_BANDS_REV2	11
43 
44 #define ACPI_WRDS_WIFI_DATA_SIZE_REV0	(ACPI_SAR_NUM_CHAINS_REV0 * \
45 					 ACPI_SAR_NUM_SUB_BANDS_REV0 + 2)
46 #define ACPI_WRDS_WIFI_DATA_SIZE_REV1	(ACPI_SAR_NUM_CHAINS_REV1 * \
47 					 ACPI_SAR_NUM_SUB_BANDS_REV1 + 2)
48 #define ACPI_WRDS_WIFI_DATA_SIZE_REV2	(ACPI_SAR_NUM_CHAINS_REV2 * \
49 					 ACPI_SAR_NUM_SUB_BANDS_REV2 + 2)
50 #define ACPI_EWRD_WIFI_DATA_SIZE_REV0	((ACPI_SAR_PROFILE_NUM - 1) * \
51 					 ACPI_SAR_NUM_CHAINS_REV0 * \
52 					 ACPI_SAR_NUM_SUB_BANDS_REV0 + 3)
53 #define ACPI_EWRD_WIFI_DATA_SIZE_REV1	((ACPI_SAR_PROFILE_NUM - 1) * \
54 					 ACPI_SAR_NUM_CHAINS_REV1 * \
55 					 ACPI_SAR_NUM_SUB_BANDS_REV1 + 3)
56 #define ACPI_EWRD_WIFI_DATA_SIZE_REV2	((ACPI_SAR_PROFILE_NUM - 1) * \
57 					 ACPI_SAR_NUM_CHAINS_REV2 * \
58 					 ACPI_SAR_NUM_SUB_BANDS_REV2 + 3)
59 #define ACPI_WPFC_WIFI_DATA_SIZE	4 /* 4 filter config words */
60 
61 /* revision 0 and 1 are identical, except for the semantics in the FW */
62 #define ACPI_GEO_NUM_BANDS_REV0		2
63 #define ACPI_GEO_NUM_BANDS_REV2		3
64 #define ACPI_GEO_NUM_CHAINS		2
65 
66 #define ACPI_WRDD_WIFI_DATA_SIZE	2
67 #define ACPI_SPLC_WIFI_DATA_SIZE	2
68 #define ACPI_ECKV_WIFI_DATA_SIZE	2
69 
70 /*
71  * TAS size: 1 elelment for type,
72  *	     1 element for enabled field,
73  *	     1 element for block list size,
74  *	     16 elements for block list array
75  */
76 #define APCI_WTAS_BLACK_LIST_MAX	16
77 #define ACPI_WTAS_WIFI_DATA_SIZE	(3 + APCI_WTAS_BLACK_LIST_MAX)
78 #define ACPI_WTAS_ENABLED_MSK		0x1
79 #define ACPI_WTAS_OVERRIDE_IEC_MSK	0x2
80 #define ACPI_WTAS_ENABLE_IEC_MSK	0x4
81 #define ACPI_WTAS_OVERRIDE_IEC_POS	0x1
82 #define ACPI_WTAS_ENABLE_IEC_POS	0x2
83 #define ACPI_WTAS_USA_UHB_MSK		BIT(16)
84 #define ACPI_WTAS_USA_UHB_POS		16
85 
86 
87 #define ACPI_PPAG_WIFI_DATA_SIZE_V1	((IWL_NUM_CHAIN_LIMITS * \
88 					  IWL_NUM_SUB_BANDS_V1) + 2)
89 #define ACPI_PPAG_WIFI_DATA_SIZE_V2	((IWL_NUM_CHAIN_LIMITS * \
90 					  IWL_NUM_SUB_BANDS_V2) + 2)
91 
92 /* PPAG gain value bounds in 1/8 dBm */
93 #define ACPI_PPAG_MIN_LB -16
94 #define ACPI_PPAG_MAX_LB 24
95 #define ACPI_PPAG_MIN_HB -16
96 #define ACPI_PPAG_MAX_HB 40
97 #define ACPI_PPAG_MASK 3
98 #define IWL_PPAG_ETSI_MASK BIT(0)
99 
100 #define IWL_SAR_ENABLE_MSK		BIT(0)
101 #define IWL_REDUCE_POWER_FLAGS_POS	1
102 
103 /*
104  * The profile for revision 2 is a superset of revision 1, which is in
105  * turn a superset of revision 0.  So we can store all revisions
106  * inside revision 2, which is what we represent here.
107  */
108 struct iwl_sar_profile_chain {
109 	u8 subbands[ACPI_SAR_NUM_SUB_BANDS_REV2];
110 };
111 
112 struct iwl_sar_profile {
113 	bool enabled;
114 	struct iwl_sar_profile_chain chains[ACPI_SAR_NUM_CHAINS_REV2];
115 };
116 
117 /* Same thing as with SAR, all revisions fit in revision 2 */
118 struct iwl_geo_profile_band {
119 	u8 max;
120 	u8 chains[ACPI_GEO_NUM_CHAINS];
121 };
122 
123 struct iwl_geo_profile {
124 	struct iwl_geo_profile_band bands[ACPI_GEO_NUM_BANDS_REV2];
125 };
126 
127 /* Same thing as with SAR, all revisions fit in revision 2 */
128 struct iwl_ppag_chain {
129 	s8 subbands[ACPI_SAR_NUM_SUB_BANDS_REV2];
130 };
131 
132 enum iwl_dsm_funcs_rev_0 {
133 	DSM_FUNC_QUERY = 0,
134 	DSM_FUNC_DISABLE_SRD = 1,
135 	DSM_FUNC_ENABLE_INDONESIA_5G2 = 2,
136 	DSM_FUNC_ENABLE_6E = 3,
137 	DSM_FUNC_REGULATORY_CONFIG = 4,
138 	DSM_FUNC_11AX_ENABLEMENT = 6,
139 	DSM_FUNC_ENABLE_UNII4_CHAN = 7,
140 	DSM_FUNC_ACTIVATE_CHANNEL = 8,
141 	DSM_FUNC_FORCE_DISABLE_CHANNELS = 9
142 };
143 
144 enum iwl_dsm_values_srd {
145 	DSM_VALUE_SRD_ACTIVE,
146 	DSM_VALUE_SRD_PASSIVE,
147 	DSM_VALUE_SRD_DISABLE,
148 	DSM_VALUE_SRD_MAX
149 };
150 
151 enum iwl_dsm_values_indonesia {
152 	DSM_VALUE_INDONESIA_DISABLE,
153 	DSM_VALUE_INDONESIA_ENABLE,
154 	DSM_VALUE_INDONESIA_RESERVED,
155 	DSM_VALUE_INDONESIA_MAX
156 };
157 
158 /* DSM RFI uses a different GUID, so need separate definitions */
159 
160 #define DSM_RFI_FUNC_ENABLE 3
161 
162 enum iwl_dsm_values_rfi {
163 	DSM_VALUE_RFI_ENABLE,
164 	DSM_VALUE_RFI_DISABLE,
165 	DSM_VALUE_RFI_MAX
166 };
167 
168 enum iwl_dsm_masks_reg {
169 	DSM_MASK_CHINA_22_REG = BIT(2)
170 };
171 
172 #ifdef CONFIG_ACPI
173 
174 struct iwl_fw_runtime;
175 
176 extern const guid_t iwl_guid;
177 extern const guid_t iwl_rfi_guid;
178 
179 int iwl_acpi_get_dsm_u8(struct device *dev, int rev, int func,
180 			const guid_t *guid, u8 *value);
181 
182 int iwl_acpi_get_dsm_u32(struct device *dev, int rev, int func,
183 			 const guid_t *guid, u32 *value);
184 
185 /**
186  * iwl_acpi_get_mcc - read MCC from ACPI, if available
187  *
188  * @dev: the struct device
189  * @mcc: output buffer (3 bytes) that will get the MCC
190  *
191  * This function tries to read the current MCC from ACPI if available.
192  */
193 int iwl_acpi_get_mcc(struct device *dev, char *mcc);
194 
195 u64 iwl_acpi_get_pwr_limit(struct device *dev);
196 
197 /*
198  * iwl_acpi_get_eckv - read external clock validation from ACPI, if available
199  *
200  * @dev: the struct device
201  * @extl_clk: output var (2 bytes) that will get the clk indication.
202  *
203  * This function tries to read the external clock indication
204  * from ACPI if available.
205  */
206 int iwl_acpi_get_eckv(struct device *dev, u32 *extl_clk);
207 
208 int iwl_sar_select_profile(struct iwl_fw_runtime *fwrt,
209 			   __le16 *per_chain, u32 n_tables, u32 n_subbands,
210 			   int prof_a, int prof_b);
211 
212 int iwl_sar_get_wrds_table(struct iwl_fw_runtime *fwrt);
213 
214 int iwl_sar_get_ewrd_table(struct iwl_fw_runtime *fwrt);
215 
216 int iwl_sar_get_wgds_table(struct iwl_fw_runtime *fwrt);
217 
218 bool iwl_sar_geo_support(struct iwl_fw_runtime *fwrt);
219 
220 int iwl_sar_geo_init(struct iwl_fw_runtime *fwrt,
221 		     struct iwl_per_chain_offset *table,
222 		     u32 n_bands, u32 n_profiles);
223 
224 int iwl_acpi_get_tas(struct iwl_fw_runtime *fwrt,
225 		     union iwl_tas_config_cmd *cmd, int fw_ver);
226 
227 __le32 iwl_acpi_get_lari_config_bitmap(struct iwl_fw_runtime *fwrt);
228 
229 int iwl_acpi_get_ppag_table(struct iwl_fw_runtime *fwrt);
230 
231 int iwl_read_ppag_table(struct iwl_fw_runtime *fwrt, union iwl_ppag_table_cmd *cmd,
232 			int *cmd_size);
233 
234 bool iwl_acpi_is_ppag_approved(struct iwl_fw_runtime *fwrt);
235 
236 void iwl_acpi_get_phy_filters(struct iwl_fw_runtime *fwrt,
237 			      struct iwl_phy_specific_cfg *filters);
238 
239 #else /* CONFIG_ACPI */
240 
241 static inline void *iwl_acpi_get_dsm_object(struct device *dev, int rev,
242 					    int func, union acpi_object *args)
243 {
244 	return ERR_PTR(-ENOENT);
245 }
246 
247 static inline int iwl_acpi_get_dsm_u8(struct device *dev, int rev, int func,
248 				      const guid_t *guid, u8 *value)
249 {
250 	return -ENOENT;
251 }
252 
253 static inline int iwl_acpi_get_dsm_u32(struct device *dev, int rev, int func,
254 				       const guid_t *guid, u32 *value)
255 {
256 	return -ENOENT;
257 }
258 
259 static inline int iwl_acpi_get_mcc(struct device *dev, char *mcc)
260 {
261 	return -ENOENT;
262 }
263 
264 static inline u64 iwl_acpi_get_pwr_limit(struct device *dev)
265 {
266 	return 0;
267 }
268 
269 static inline int iwl_acpi_get_eckv(struct device *dev, u32 *extl_clk)
270 {
271 	return -ENOENT;
272 }
273 
274 static inline int iwl_sar_select_profile(struct iwl_fw_runtime *fwrt,
275 			   __le16 *per_chain, u32 n_tables, u32 n_subbands,
276 			   int prof_a, int prof_b)
277 {
278 	return -ENOENT;
279 }
280 
281 static inline int iwl_sar_get_wrds_table(struct iwl_fw_runtime *fwrt)
282 {
283 	return -ENOENT;
284 }
285 
286 static inline int iwl_sar_get_ewrd_table(struct iwl_fw_runtime *fwrt)
287 {
288 	return -ENOENT;
289 }
290 
291 static inline int iwl_sar_get_wgds_table(struct iwl_fw_runtime *fwrt)
292 {
293 	return 1;
294 }
295 
296 static inline bool iwl_sar_geo_support(struct iwl_fw_runtime *fwrt)
297 {
298 	return false;
299 }
300 
301 static inline int iwl_acpi_get_tas(struct iwl_fw_runtime *fwrt,
302 				   union iwl_tas_config_cmd *cmd, int fw_ver)
303 {
304 	return -ENOENT;
305 }
306 
307 static inline __le32 iwl_acpi_get_lari_config_bitmap(struct iwl_fw_runtime *fwrt)
308 {
309 	return 0;
310 }
311 
312 static inline int iwl_acpi_get_ppag_table(struct iwl_fw_runtime *fwrt)
313 {
314 	return -ENOENT;
315 }
316 
317 static inline int iwl_read_ppag_table(struct iwl_fw_runtime *fwrt,
318 				    union iwl_ppag_table_cmd *cmd, int *cmd_size)
319 {
320 	return -ENOENT;
321 }
322 
323 static inline bool iwl_acpi_is_ppag_approved(struct iwl_fw_runtime *fwrt)
324 {
325 	return false;
326 }
327 
328 static inline void iwl_acpi_get_phy_filters(struct iwl_fw_runtime *fwrt,
329 					    struct iwl_phy_specific_cfg *filters)
330 {
331 }
332 
333 #endif /* CONFIG_ACPI */
334 
335 #endif /* __iwl_fw_acpi__ */
336