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/regulatory.h"
11 #include "fw/api/commands.h"
12 #include "fw/api/power.h"
13 #include "fw/api/phy.h"
14 #include "fw/api/nvm-reg.h"
15 #include "fw/api/config.h"
16 #include "fw/img.h"
17 #include "iwl-trans.h"
18
19
20 #define ACPI_WRDS_METHOD "WRDS"
21 #define ACPI_EWRD_METHOD "EWRD"
22 #define ACPI_WGDS_METHOD "WGDS"
23 #define ACPI_WRDD_METHOD "WRDD"
24 #define ACPI_SPLC_METHOD "SPLC"
25 #define ACPI_ECKV_METHOD "ECKV"
26 #define ACPI_PPAG_METHOD "PPAG"
27 #define ACPI_WTAS_METHOD "WTAS"
28 #define ACPI_WPFC_METHOD "WPFC"
29 #define ACPI_GLAI_METHOD "GLAI"
30 #define ACPI_WBEM_METHOD "WBEM"
31 #define ACPI_DSBR_METHOD "DSBR"
32
33 #define ACPI_WIFI_DOMAIN (0x07)
34
35 #define ACPI_SAR_PROFILE_NUM 4
36
37 #define ACPI_NUM_GEO_PROFILES 3
38 #define ACPI_NUM_GEO_PROFILES_REV3 8
39 #define ACPI_GEO_PER_CHAIN_SIZE 3
40
41 #define ACPI_SAR_NUM_CHAINS_REV0 2
42 #define ACPI_SAR_NUM_CHAINS_REV1 2
43 #define ACPI_SAR_NUM_CHAINS_REV2 4
44 #define ACPI_SAR_NUM_SUB_BANDS_REV0 5
45 #define ACPI_SAR_NUM_SUB_BANDS_REV1 11
46 #define ACPI_SAR_NUM_SUB_BANDS_REV2 11
47
48 #define ACPI_WRDS_WIFI_DATA_SIZE_REV0 (ACPI_SAR_NUM_CHAINS_REV0 * \
49 ACPI_SAR_NUM_SUB_BANDS_REV0 + 2)
50 #define ACPI_WRDS_WIFI_DATA_SIZE_REV1 (ACPI_SAR_NUM_CHAINS_REV1 * \
51 ACPI_SAR_NUM_SUB_BANDS_REV1 + 2)
52 #define ACPI_WRDS_WIFI_DATA_SIZE_REV2 (ACPI_SAR_NUM_CHAINS_REV2 * \
53 ACPI_SAR_NUM_SUB_BANDS_REV2 + 2)
54 #define ACPI_EWRD_WIFI_DATA_SIZE_REV0 ((ACPI_SAR_PROFILE_NUM - 1) * \
55 ACPI_SAR_NUM_CHAINS_REV0 * \
56 ACPI_SAR_NUM_SUB_BANDS_REV0 + 3)
57 #define ACPI_EWRD_WIFI_DATA_SIZE_REV1 ((ACPI_SAR_PROFILE_NUM - 1) * \
58 ACPI_SAR_NUM_CHAINS_REV1 * \
59 ACPI_SAR_NUM_SUB_BANDS_REV1 + 3)
60 #define ACPI_EWRD_WIFI_DATA_SIZE_REV2 ((ACPI_SAR_PROFILE_NUM - 1) * \
61 ACPI_SAR_NUM_CHAINS_REV2 * \
62 ACPI_SAR_NUM_SUB_BANDS_REV2 + 3)
63 #define ACPI_WPFC_WIFI_DATA_SIZE 5 /* domain and 4 filter config words */
64
65 /* revision 0 and 1 are identical, except for the semantics in the FW */
66 #define ACPI_GEO_NUM_BANDS_REV0 2
67 #define ACPI_GEO_NUM_BANDS_REV2 3
68
69 #define ACPI_WRDD_WIFI_DATA_SIZE 2
70 #define ACPI_SPLC_WIFI_DATA_SIZE 2
71 #define ACPI_ECKV_WIFI_DATA_SIZE 2
72
73 /*
74 * One element for domain type,
75 * and one for enablement of Wi-Fi 320MHz per MCC
76 */
77 #define ACPI_WBEM_WIFI_DATA_SIZE 2
78 /*
79 * One element for domain type,
80 * and one for DSBR response data
81 */
82 #define ACPI_DSBR_WIFI_DATA_SIZE 2
83 #define ACPI_DSBR_WIFI_DATA_REV 1
84
85 /*
86 * One element for domain type,
87 * and one for the status
88 */
89 #define ACPI_GLAI_WIFI_DATA_SIZE 2
90 #define ACPI_GLAI_MAX_STATUS 2
91 /*
92 * TAS size: 1 elelment for type,
93 * 1 element for enabled field,
94 * 1 element for block list size,
95 * 16 elements for block list array
96 */
97 #define ACPI_WTAS_WIFI_DATA_SIZE (3 + IWL_WTAS_BLACK_LIST_MAX)
98
99 #define ACPI_PPAG_WIFI_DATA_SIZE_V1 ((IWL_NUM_CHAIN_LIMITS * \
100 IWL_NUM_SUB_BANDS_V1) + 2)
101 #define ACPI_PPAG_WIFI_DATA_SIZE_V2 ((IWL_NUM_CHAIN_LIMITS * \
102 IWL_NUM_SUB_BANDS_V2) + 2)
103
104 #define IWL_SAR_ENABLE_MSK BIT(0)
105 #define IWL_REDUCE_POWER_FLAGS_POS 1
106
107 /* The Inidcator whether UEFI WIFI GUID tables are locked is read from ACPI */
108 #define UEFI_WIFI_GUID_UNLOCKED 0
109
110 #define ACPI_DSM_REV 0
111
112 #define DSM_INTERNAL_FUNC_GET_PLAT_INFO 1
113 /* TBD: VPRO is BIT(0) in the result, but what's the result? */
114
115 #define DSM_INTERNAL_FUNC_PRODUCT_RESET 2
116
117 /* DSM_INTERNAL_FUNC_PRODUCT_RESET - product reset (aka "PLDR") */
118 enum iwl_dsm_internal_product_reset_cmds {
119 DSM_INTERNAL_PLDR_CMD_GET_MODE = 1,
120 DSM_INTERNAL_PLDR_CMD_SET_MODE = 2,
121 DSM_INTERNAL_PLDR_CMD_GET_STATUS = 3,
122 };
123
124 enum iwl_dsm_internal_product_reset_mode {
125 DSM_INTERNAL_PLDR_MODE_EN_PROD_RESET = BIT(0),
126 DSM_INTERNAL_PLDR_MODE_EN_WIFI_FLR = BIT(1),
127 DSM_INTERNAL_PLDR_MODE_EN_BT_OFF_ON = BIT(2),
128 };
129
130 struct iwl_dsm_internal_product_reset_cmd {
131 /* cmd is from enum iwl_dsm_internal_product_reset_cmds */
132 u16 cmd;
133 u16 value;
134 } __packed;
135
136 #define IWL_ACPI_WBEM_REV0_MASK (BIT(0) | BIT(1))
137 #define IWL_ACPI_WBEM_REVISION 0
138
139 #ifdef CONFIG_ACPI
140
141 struct iwl_fw_runtime;
142
143 extern const guid_t iwl_guid;
144
145 union acpi_object *iwl_acpi_get_dsm_object(struct device *dev, int rev,
146 int func, union acpi_object *args,
147 const guid_t *guid);
148
149 /**
150 * iwl_acpi_get_mcc - read MCC from ACPI, if available
151 *
152 * @fwrt: the fw runtime struct
153 * @mcc: output buffer (3 bytes) that will get the MCC
154 *
155 * This function tries to read the current MCC from ACPI if available.
156 */
157 int iwl_acpi_get_mcc(struct iwl_fw_runtime *fwrt, char *mcc);
158
159 int iwl_acpi_get_pwr_limit(struct iwl_fw_runtime *fwrt, u64 *dflt_pwr_limit);
160
161 /*
162 * iwl_acpi_get_eckv - read external clock validation from ACPI, if available
163 *
164 * @fwrt: the fw runtime struct
165 * @extl_clk: output var (2 bytes) that will get the clk indication.
166 *
167 * This function tries to read the external clock indication
168 * from ACPI if available.
169 */
170 int iwl_acpi_get_eckv(struct iwl_fw_runtime *fwrt, u32 *extl_clk);
171
172 int iwl_acpi_get_wrds_table(struct iwl_fw_runtime *fwrt);
173
174 int iwl_acpi_get_ewrd_table(struct iwl_fw_runtime *fwrt);
175
176 int iwl_acpi_get_wgds_table(struct iwl_fw_runtime *fwrt);
177
178 int iwl_acpi_get_tas_table(struct iwl_fw_runtime *fwrt,
179 struct iwl_tas_data *data);
180
181 int iwl_acpi_get_ppag_table(struct iwl_fw_runtime *fwrt);
182
183 void iwl_acpi_get_phy_filters(struct iwl_fw_runtime *fwrt,
184 struct iwl_phy_specific_cfg *filters);
185
186 void iwl_acpi_get_guid_lock_status(struct iwl_fw_runtime *fwrt);
187
188 int iwl_acpi_get_dsm(struct iwl_fw_runtime *fwrt,
189 enum iwl_dsm_funcs func, u32 *value);
190
191 int iwl_acpi_get_wbem(struct iwl_fw_runtime *fwrt, u32 *value);
192
193 int iwl_acpi_get_dsbr(struct iwl_fw_runtime *fwrt, u32 *value);
194
195 #else /* CONFIG_ACPI */
196
197 static inline union acpi_object *
iwl_acpi_get_dsm_object(struct device * dev,int rev,int func,union acpi_object * args,const guid_t * guid)198 iwl_acpi_get_dsm_object(struct device *dev, int rev, int func,
199 union acpi_object *args, const guid_t *guid)
200 {
201 return ERR_PTR(-ENOENT);
202 }
203
iwl_acpi_get_mcc(struct iwl_fw_runtime * fwrt,char * mcc)204 static inline int iwl_acpi_get_mcc(struct iwl_fw_runtime *fwrt, char *mcc)
205 {
206 return -ENOENT;
207 }
208
iwl_acpi_get_pwr_limit(struct iwl_fw_runtime * fwrt,u64 * dflt_pwr_limit)209 static inline int iwl_acpi_get_pwr_limit(struct iwl_fw_runtime *fwrt,
210 u64 *dflt_pwr_limit)
211 {
212 *dflt_pwr_limit = 0;
213 return 0;
214 }
215
iwl_acpi_get_eckv(struct iwl_fw_runtime * fwrt,u32 * extl_clk)216 static inline int iwl_acpi_get_eckv(struct iwl_fw_runtime *fwrt, u32 *extl_clk)
217 {
218 return -ENOENT;
219 }
220
iwl_acpi_get_wrds_table(struct iwl_fw_runtime * fwrt)221 static inline int iwl_acpi_get_wrds_table(struct iwl_fw_runtime *fwrt)
222 {
223 return -ENOENT;
224 }
225
iwl_acpi_get_ewrd_table(struct iwl_fw_runtime * fwrt)226 static inline int iwl_acpi_get_ewrd_table(struct iwl_fw_runtime *fwrt)
227 {
228 return -ENOENT;
229 }
230
iwl_acpi_get_wgds_table(struct iwl_fw_runtime * fwrt)231 static inline int iwl_acpi_get_wgds_table(struct iwl_fw_runtime *fwrt)
232 {
233 return 1;
234 }
235
iwl_acpi_get_tas_table(struct iwl_fw_runtime * fwrt,struct iwl_tas_data * data)236 static inline int iwl_acpi_get_tas_table(struct iwl_fw_runtime *fwrt,
237 struct iwl_tas_data *data)
238 {
239 return -ENOENT;
240 }
241
iwl_acpi_get_ppag_table(struct iwl_fw_runtime * fwrt)242 static inline int iwl_acpi_get_ppag_table(struct iwl_fw_runtime *fwrt)
243 {
244 return -ENOENT;
245 }
246
247 /* macro since the second argument doesn't always exist */
248 #define iwl_acpi_get_phy_filters(fwrt, filters) do { } while (0)
249
iwl_acpi_get_guid_lock_status(struct iwl_fw_runtime * fwrt)250 static inline void iwl_acpi_get_guid_lock_status(struct iwl_fw_runtime *fwrt)
251 {
252 }
253
iwl_acpi_get_dsm(struct iwl_fw_runtime * fwrt,enum iwl_dsm_funcs func,u32 * value)254 static inline int iwl_acpi_get_dsm(struct iwl_fw_runtime *fwrt,
255 enum iwl_dsm_funcs func, u32 *value)
256 {
257 return -ENOENT;
258 }
259
iwl_acpi_get_wbem(struct iwl_fw_runtime * fwrt,u32 * value)260 static inline int iwl_acpi_get_wbem(struct iwl_fw_runtime *fwrt, u32 *value)
261 {
262 return -ENOENT;
263 }
264
iwl_acpi_get_dsbr(struct iwl_fw_runtime * fwrt,u32 * value)265 static inline int iwl_acpi_get_dsbr(struct iwl_fw_runtime *fwrt, u32 *value)
266 {
267 return -ENOENT;
268 }
269 #endif /* CONFIG_ACPI */
270
271 #endif /* __iwl_fw_acpi__ */
272