xref: /OK3568_Linux_fs/kernel/drivers/net/wireless/intel/iwlwifi/fw/acpi.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /******************************************************************************
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * This file is provided under a dual BSD/GPLv2 license.  When using or
4*4882a593Smuzhiyun  * redistributing this file, you may do so under either license.
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * GPL LICENSE SUMMARY
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  * Copyright(c) 2017        Intel Deutschland GmbH
9*4882a593Smuzhiyun  * Copyright(c) 2018 - 2020        Intel Corporation
10*4882a593Smuzhiyun  *
11*4882a593Smuzhiyun  * This program is free software; you can redistribute it and/or modify
12*4882a593Smuzhiyun  * it under the terms of version 2 of the GNU General Public License as
13*4882a593Smuzhiyun  * published by the Free Software Foundation.
14*4882a593Smuzhiyun  *
15*4882a593Smuzhiyun  * This program is distributed in the hope that it will be useful, but
16*4882a593Smuzhiyun  * WITHOUT ANY WARRANTY; without even the implied warranty of
17*4882a593Smuzhiyun  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
18*4882a593Smuzhiyun  * General Public License for more details.
19*4882a593Smuzhiyun  *
20*4882a593Smuzhiyun  * The full GNU General Public License is included in this distribution
21*4882a593Smuzhiyun  * in the file called COPYING.
22*4882a593Smuzhiyun  *
23*4882a593Smuzhiyun  * Contact Information:
24*4882a593Smuzhiyun  *  Intel Linux Wireless <linuxwifi@intel.com>
25*4882a593Smuzhiyun  * Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
26*4882a593Smuzhiyun  *
27*4882a593Smuzhiyun  * BSD LICENSE
28*4882a593Smuzhiyun  *
29*4882a593Smuzhiyun  * Copyright(c) 2017        Intel Deutschland GmbH
30*4882a593Smuzhiyun  * Copyright(c) 2018 - 2020       Intel Corporation
31*4882a593Smuzhiyun  * All rights reserved.
32*4882a593Smuzhiyun  *
33*4882a593Smuzhiyun  * Redistribution and use in source and binary forms, with or without
34*4882a593Smuzhiyun  * modification, are permitted provided that the following conditions
35*4882a593Smuzhiyun  * are met:
36*4882a593Smuzhiyun  *
37*4882a593Smuzhiyun  *  * Redistributions of source code must retain the above copyright
38*4882a593Smuzhiyun  *    notice, this list of conditions and the following disclaimer.
39*4882a593Smuzhiyun  *  * Redistributions in binary form must reproduce the above copyright
40*4882a593Smuzhiyun  *    notice, this list of conditions and the following disclaimer in
41*4882a593Smuzhiyun  *    the documentation and/or other materials provided with the
42*4882a593Smuzhiyun  *    distribution.
43*4882a593Smuzhiyun  *  * Neither the name Intel Corporation nor the names of its
44*4882a593Smuzhiyun  *    contributors may be used to endorse or promote products derived
45*4882a593Smuzhiyun  *    from this software without specific prior written permission.
46*4882a593Smuzhiyun  *
47*4882a593Smuzhiyun  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
48*4882a593Smuzhiyun  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
49*4882a593Smuzhiyun  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
50*4882a593Smuzhiyun  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
51*4882a593Smuzhiyun  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
52*4882a593Smuzhiyun  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
53*4882a593Smuzhiyun  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
54*4882a593Smuzhiyun  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
55*4882a593Smuzhiyun  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
56*4882a593Smuzhiyun  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
57*4882a593Smuzhiyun  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
58*4882a593Smuzhiyun  *
59*4882a593Smuzhiyun  *****************************************************************************/
60*4882a593Smuzhiyun #ifndef __iwl_fw_acpi__
61*4882a593Smuzhiyun #define __iwl_fw_acpi__
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun #include <linux/acpi.h>
64*4882a593Smuzhiyun #include "fw/api/commands.h"
65*4882a593Smuzhiyun #include "fw/api/power.h"
66*4882a593Smuzhiyun #include "fw/api/phy.h"
67*4882a593Smuzhiyun #include "fw/api/nvm-reg.h"
68*4882a593Smuzhiyun #include "fw/img.h"
69*4882a593Smuzhiyun #include "iwl-trans.h"
70*4882a593Smuzhiyun 
71*4882a593Smuzhiyun 
72*4882a593Smuzhiyun #define ACPI_WRDS_METHOD	"WRDS"
73*4882a593Smuzhiyun #define ACPI_EWRD_METHOD	"EWRD"
74*4882a593Smuzhiyun #define ACPI_WGDS_METHOD	"WGDS"
75*4882a593Smuzhiyun #define ACPI_WRDD_METHOD	"WRDD"
76*4882a593Smuzhiyun #define ACPI_SPLC_METHOD	"SPLC"
77*4882a593Smuzhiyun #define ACPI_ECKV_METHOD	"ECKV"
78*4882a593Smuzhiyun #define ACPI_PPAG_METHOD	"PPAG"
79*4882a593Smuzhiyun #define ACPI_WTAS_METHOD	"WTAS"
80*4882a593Smuzhiyun 
81*4882a593Smuzhiyun #define ACPI_WIFI_DOMAIN	(0x07)
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun #define ACPI_SAR_TABLE_SIZE		10
84*4882a593Smuzhiyun #define ACPI_SAR_PROFILE_NUM		4
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun #define ACPI_GEO_TABLE_SIZE		6
87*4882a593Smuzhiyun #define ACPI_NUM_GEO_PROFILES		3
88*4882a593Smuzhiyun #define ACPI_GEO_PER_CHAIN_SIZE		3
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun #define ACPI_SAR_NUM_CHAIN_LIMITS	2
91*4882a593Smuzhiyun #define ACPI_SAR_NUM_SUB_BANDS		5
92*4882a593Smuzhiyun #define ACPI_SAR_NUM_TABLES		1
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun #define ACPI_WRDS_WIFI_DATA_SIZE	(ACPI_SAR_TABLE_SIZE + 2)
95*4882a593Smuzhiyun #define ACPI_EWRD_WIFI_DATA_SIZE	((ACPI_SAR_PROFILE_NUM - 1) * \
96*4882a593Smuzhiyun 					 ACPI_SAR_TABLE_SIZE + 3)
97*4882a593Smuzhiyun #define ACPI_WGDS_WIFI_DATA_SIZE	19
98*4882a593Smuzhiyun #define ACPI_WRDD_WIFI_DATA_SIZE	2
99*4882a593Smuzhiyun #define ACPI_SPLC_WIFI_DATA_SIZE	2
100*4882a593Smuzhiyun #define ACPI_ECKV_WIFI_DATA_SIZE	2
101*4882a593Smuzhiyun 
102*4882a593Smuzhiyun /*
103*4882a593Smuzhiyun  * 1 type, 1 enabled, 1 block list size, 16 block list array
104*4882a593Smuzhiyun  */
105*4882a593Smuzhiyun #define APCI_WTAS_BLACK_LIST_MAX	16
106*4882a593Smuzhiyun #define ACPI_WTAS_WIFI_DATA_SIZE	(3 + APCI_WTAS_BLACK_LIST_MAX)
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun #define ACPI_WGDS_TABLE_SIZE		3
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun #define ACPI_PPAG_WIFI_DATA_SIZE	((IWL_NUM_CHAIN_LIMITS * \
111*4882a593Smuzhiyun 					IWL_NUM_SUB_BANDS) + 3)
112*4882a593Smuzhiyun #define ACPI_PPAG_WIFI_DATA_SIZE_V2	((IWL_NUM_CHAIN_LIMITS * \
113*4882a593Smuzhiyun 					IWL_NUM_SUB_BANDS_V2) + 3)
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun /* PPAG gain value bounds in 1/8 dBm */
116*4882a593Smuzhiyun #define ACPI_PPAG_MIN_LB -16
117*4882a593Smuzhiyun #define ACPI_PPAG_MAX_LB 24
118*4882a593Smuzhiyun #define ACPI_PPAG_MIN_HB -16
119*4882a593Smuzhiyun #define ACPI_PPAG_MAX_HB 40
120*4882a593Smuzhiyun 
121*4882a593Smuzhiyun struct iwl_sar_profile {
122*4882a593Smuzhiyun 	bool enabled;
123*4882a593Smuzhiyun 	u8 table[ACPI_SAR_TABLE_SIZE];
124*4882a593Smuzhiyun };
125*4882a593Smuzhiyun 
126*4882a593Smuzhiyun struct iwl_geo_profile {
127*4882a593Smuzhiyun 	u8 values[ACPI_GEO_TABLE_SIZE];
128*4882a593Smuzhiyun };
129*4882a593Smuzhiyun 
130*4882a593Smuzhiyun enum iwl_dsm_funcs_rev_0 {
131*4882a593Smuzhiyun 	DSM_FUNC_QUERY = 0,
132*4882a593Smuzhiyun 	DSM_FUNC_DISABLE_SRD = 1,
133*4882a593Smuzhiyun 	DSM_FUNC_ENABLE_INDONESIA_5G2 = 2,
134*4882a593Smuzhiyun };
135*4882a593Smuzhiyun 
136*4882a593Smuzhiyun enum iwl_dsm_values_srd {
137*4882a593Smuzhiyun 	DSM_VALUE_SRD_ACTIVE,
138*4882a593Smuzhiyun 	DSM_VALUE_SRD_PASSIVE,
139*4882a593Smuzhiyun 	DSM_VALUE_SRD_DISABLE,
140*4882a593Smuzhiyun 	DSM_VALUE_SRD_MAX
141*4882a593Smuzhiyun };
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun enum iwl_dsm_values_indonesia {
144*4882a593Smuzhiyun 	DSM_VALUE_INDONESIA_DISABLE,
145*4882a593Smuzhiyun 	DSM_VALUE_INDONESIA_ENABLE,
146*4882a593Smuzhiyun 	DSM_VALUE_INDONESIA_RESERVED,
147*4882a593Smuzhiyun 	DSM_VALUE_INDONESIA_MAX
148*4882a593Smuzhiyun };
149*4882a593Smuzhiyun 
150*4882a593Smuzhiyun #ifdef CONFIG_ACPI
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun struct iwl_fw_runtime;
153*4882a593Smuzhiyun 
154*4882a593Smuzhiyun void *iwl_acpi_get_object(struct device *dev, acpi_string method);
155*4882a593Smuzhiyun 
156*4882a593Smuzhiyun int iwl_acpi_get_dsm_u8(struct device *dev, int rev, int func);
157*4882a593Smuzhiyun 
158*4882a593Smuzhiyun union acpi_object *iwl_acpi_get_wifi_pkg(struct device *dev,
159*4882a593Smuzhiyun 					 union acpi_object *data,
160*4882a593Smuzhiyun 					 int data_size, int *tbl_rev);
161*4882a593Smuzhiyun 
162*4882a593Smuzhiyun /**
163*4882a593Smuzhiyun  * iwl_acpi_get_mcc - read MCC from ACPI, if available
164*4882a593Smuzhiyun  *
165*4882a593Smuzhiyun  * @dev: the struct device
166*4882a593Smuzhiyun  * @mcc: output buffer (3 bytes) that will get the MCC
167*4882a593Smuzhiyun  *
168*4882a593Smuzhiyun  * This function tries to read the current MCC from ACPI if available.
169*4882a593Smuzhiyun  */
170*4882a593Smuzhiyun int iwl_acpi_get_mcc(struct device *dev, char *mcc);
171*4882a593Smuzhiyun 
172*4882a593Smuzhiyun u64 iwl_acpi_get_pwr_limit(struct device *dev);
173*4882a593Smuzhiyun 
174*4882a593Smuzhiyun /*
175*4882a593Smuzhiyun  * iwl_acpi_get_eckv - read external clock validation from ACPI, if available
176*4882a593Smuzhiyun  *
177*4882a593Smuzhiyun  * @dev: the struct device
178*4882a593Smuzhiyun  * @extl_clk: output var (2 bytes) that will get the clk indication.
179*4882a593Smuzhiyun  *
180*4882a593Smuzhiyun  * This function tries to read the external clock indication
181*4882a593Smuzhiyun  * from ACPI if available.
182*4882a593Smuzhiyun  */
183*4882a593Smuzhiyun int iwl_acpi_get_eckv(struct device *dev, u32 *extl_clk);
184*4882a593Smuzhiyun 
185*4882a593Smuzhiyun int iwl_sar_select_profile(struct iwl_fw_runtime *fwrt,
186*4882a593Smuzhiyun 			   __le16 *per_chain, u32 n_tables, u32 n_subbands,
187*4882a593Smuzhiyun 			   int prof_a, int prof_b);
188*4882a593Smuzhiyun 
189*4882a593Smuzhiyun int iwl_sar_get_wrds_table(struct iwl_fw_runtime *fwrt);
190*4882a593Smuzhiyun 
191*4882a593Smuzhiyun int iwl_sar_get_ewrd_table(struct iwl_fw_runtime *fwrt);
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun int iwl_sar_get_wgds_table(struct iwl_fw_runtime *fwrt);
194*4882a593Smuzhiyun 
195*4882a593Smuzhiyun bool iwl_sar_geo_support(struct iwl_fw_runtime *fwrt);
196*4882a593Smuzhiyun 
197*4882a593Smuzhiyun int iwl_sar_geo_init(struct iwl_fw_runtime *fwrt,
198*4882a593Smuzhiyun 		     struct iwl_per_chain_offset *table, u32 n_bands);
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun int iwl_acpi_get_tas(struct iwl_fw_runtime *fwrt, __le32 *block_list_array,
201*4882a593Smuzhiyun 		     int *block_list_size);
202*4882a593Smuzhiyun 
203*4882a593Smuzhiyun #else /* CONFIG_ACPI */
204*4882a593Smuzhiyun 
iwl_acpi_get_object(struct device * dev,acpi_string method)205*4882a593Smuzhiyun static inline void *iwl_acpi_get_object(struct device *dev, acpi_string method)
206*4882a593Smuzhiyun {
207*4882a593Smuzhiyun 	return ERR_PTR(-ENOENT);
208*4882a593Smuzhiyun }
209*4882a593Smuzhiyun 
iwl_acpi_get_dsm_object(struct device * dev,int rev,int func,union acpi_object * args)210*4882a593Smuzhiyun static inline void *iwl_acpi_get_dsm_object(struct device *dev, int rev,
211*4882a593Smuzhiyun 					    int func, union acpi_object *args)
212*4882a593Smuzhiyun {
213*4882a593Smuzhiyun 	return ERR_PTR(-ENOENT);
214*4882a593Smuzhiyun }
215*4882a593Smuzhiyun 
iwl_acpi_get_dsm_u8(struct device * dev,int rev,int func)216*4882a593Smuzhiyun static inline int iwl_acpi_get_dsm_u8(struct device *dev, int rev, int func)
217*4882a593Smuzhiyun {
218*4882a593Smuzhiyun 	return -ENOENT;
219*4882a593Smuzhiyun }
220*4882a593Smuzhiyun 
iwl_acpi_get_wifi_pkg(struct device * dev,union acpi_object * data,int data_size,int * tbl_rev)221*4882a593Smuzhiyun static inline union acpi_object *iwl_acpi_get_wifi_pkg(struct device *dev,
222*4882a593Smuzhiyun 						       union acpi_object *data,
223*4882a593Smuzhiyun 						       int data_size,
224*4882a593Smuzhiyun 						       int *tbl_rev)
225*4882a593Smuzhiyun {
226*4882a593Smuzhiyun 	return ERR_PTR(-ENOENT);
227*4882a593Smuzhiyun }
228*4882a593Smuzhiyun 
iwl_acpi_get_mcc(struct device * dev,char * mcc)229*4882a593Smuzhiyun static inline int iwl_acpi_get_mcc(struct device *dev, char *mcc)
230*4882a593Smuzhiyun {
231*4882a593Smuzhiyun 	return -ENOENT;
232*4882a593Smuzhiyun }
233*4882a593Smuzhiyun 
iwl_acpi_get_pwr_limit(struct device * dev)234*4882a593Smuzhiyun static inline u64 iwl_acpi_get_pwr_limit(struct device *dev)
235*4882a593Smuzhiyun {
236*4882a593Smuzhiyun 	return 0;
237*4882a593Smuzhiyun }
238*4882a593Smuzhiyun 
iwl_acpi_get_eckv(struct device * dev,u32 * extl_clk)239*4882a593Smuzhiyun static inline int iwl_acpi_get_eckv(struct device *dev, u32 *extl_clk)
240*4882a593Smuzhiyun {
241*4882a593Smuzhiyun 	return -ENOENT;
242*4882a593Smuzhiyun }
243*4882a593Smuzhiyun 
iwl_sar_select_profile(struct iwl_fw_runtime * fwrt,__le16 * per_chain,u32 n_tables,u32 n_subbands,int prof_a,int prof_b)244*4882a593Smuzhiyun static inline int iwl_sar_select_profile(struct iwl_fw_runtime *fwrt,
245*4882a593Smuzhiyun 			   __le16 *per_chain, u32 n_tables, u32 n_subbands,
246*4882a593Smuzhiyun 			   int prof_a, int prof_b)
247*4882a593Smuzhiyun {
248*4882a593Smuzhiyun 	return -ENOENT;
249*4882a593Smuzhiyun }
250*4882a593Smuzhiyun 
iwl_sar_get_wrds_table(struct iwl_fw_runtime * fwrt)251*4882a593Smuzhiyun static inline int iwl_sar_get_wrds_table(struct iwl_fw_runtime *fwrt)
252*4882a593Smuzhiyun {
253*4882a593Smuzhiyun 	return -ENOENT;
254*4882a593Smuzhiyun }
255*4882a593Smuzhiyun 
iwl_sar_get_ewrd_table(struct iwl_fw_runtime * fwrt)256*4882a593Smuzhiyun static inline int iwl_sar_get_ewrd_table(struct iwl_fw_runtime *fwrt)
257*4882a593Smuzhiyun {
258*4882a593Smuzhiyun 	return -ENOENT;
259*4882a593Smuzhiyun }
260*4882a593Smuzhiyun 
iwl_sar_get_wgds_table(struct iwl_fw_runtime * fwrt)261*4882a593Smuzhiyun static inline int iwl_sar_get_wgds_table(struct iwl_fw_runtime *fwrt)
262*4882a593Smuzhiyun {
263*4882a593Smuzhiyun 	return -ENOENT;
264*4882a593Smuzhiyun }
265*4882a593Smuzhiyun 
iwl_sar_geo_support(struct iwl_fw_runtime * fwrt)266*4882a593Smuzhiyun static inline bool iwl_sar_geo_support(struct iwl_fw_runtime *fwrt)
267*4882a593Smuzhiyun {
268*4882a593Smuzhiyun 	return false;
269*4882a593Smuzhiyun }
270*4882a593Smuzhiyun 
iwl_acpi_get_tas(struct iwl_fw_runtime * fwrt,__le32 * block_list_array,int * block_list_size)271*4882a593Smuzhiyun static inline int iwl_acpi_get_tas(struct iwl_fw_runtime *fwrt,
272*4882a593Smuzhiyun 				   __le32 *block_list_array,
273*4882a593Smuzhiyun 				   int *block_list_size)
274*4882a593Smuzhiyun {
275*4882a593Smuzhiyun 	return -ENOENT;
276*4882a593Smuzhiyun }
277*4882a593Smuzhiyun #endif /* CONFIG_ACPI */
278*4882a593Smuzhiyun #endif /* __iwl_fw_acpi__ */
279