xref: /freebsd/sys/contrib/dev/iwlwifi/fw/api/phy.h (revision d9836fb4b9380e2ed1c38455fb31a3832b452671)
1bfcc09ddSBjoern A. Zeeb /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2bfcc09ddSBjoern A. Zeeb /*
3bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2012-2014, 2019-2021 Intel Corporation
4bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2013-2015 Intel Mobile Communications GmbH
5bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2016-2017 Intel Deutschland GmbH
6bfcc09ddSBjoern A. Zeeb  */
7bfcc09ddSBjoern A. Zeeb #ifndef __iwl_fw_api_phy_h__
8bfcc09ddSBjoern A. Zeeb #define __iwl_fw_api_phy_h__
9bfcc09ddSBjoern A. Zeeb 
10bfcc09ddSBjoern A. Zeeb /**
11bfcc09ddSBjoern A. Zeeb  * enum iwl_phy_ops_subcmd_ids - PHY group commands
12bfcc09ddSBjoern A. Zeeb  */
13bfcc09ddSBjoern A. Zeeb enum iwl_phy_ops_subcmd_ids {
14bfcc09ddSBjoern A. Zeeb 	/**
15bfcc09ddSBjoern A. Zeeb 	 * @CMD_DTS_MEASUREMENT_TRIGGER_WIDE:
16bfcc09ddSBjoern A. Zeeb 	 * Uses either &struct iwl_dts_measurement_cmd or
17bfcc09ddSBjoern A. Zeeb 	 * &struct iwl_ext_dts_measurement_cmd
18bfcc09ddSBjoern A. Zeeb 	 */
19bfcc09ddSBjoern A. Zeeb 	CMD_DTS_MEASUREMENT_TRIGGER_WIDE = 0x0,
20bfcc09ddSBjoern A. Zeeb 
21bfcc09ddSBjoern A. Zeeb 	/**
22bfcc09ddSBjoern A. Zeeb 	 * @CTDP_CONFIG_CMD: &struct iwl_mvm_ctdp_cmd
23bfcc09ddSBjoern A. Zeeb 	 */
24bfcc09ddSBjoern A. Zeeb 	CTDP_CONFIG_CMD = 0x03,
25bfcc09ddSBjoern A. Zeeb 
26bfcc09ddSBjoern A. Zeeb 	/**
27bfcc09ddSBjoern A. Zeeb 	 * @TEMP_REPORTING_THRESHOLDS_CMD: &struct temp_report_ths_cmd
28bfcc09ddSBjoern A. Zeeb 	 */
29bfcc09ddSBjoern A. Zeeb 	TEMP_REPORTING_THRESHOLDS_CMD = 0x04,
30bfcc09ddSBjoern A. Zeeb 
31bfcc09ddSBjoern A. Zeeb 	/**
32bfcc09ddSBjoern A. Zeeb 	 * @PER_CHAIN_LIMIT_OFFSET_CMD: &struct iwl_geo_tx_power_profiles_cmd
33bfcc09ddSBjoern A. Zeeb 	 */
34bfcc09ddSBjoern A. Zeeb 	PER_CHAIN_LIMIT_OFFSET_CMD = 0x05,
35bfcc09ddSBjoern A. Zeeb 
36bfcc09ddSBjoern A. Zeeb 	/**
37bfcc09ddSBjoern A. Zeeb 	 * @PER_PLATFORM_ANT_GAIN_CMD: &struct iwl_ppag_table_cmd
38bfcc09ddSBjoern A. Zeeb 	 */
39bfcc09ddSBjoern A. Zeeb 	PER_PLATFORM_ANT_GAIN_CMD = 0x07,
40bfcc09ddSBjoern A. Zeeb 
41bfcc09ddSBjoern A. Zeeb 	/**
42bfcc09ddSBjoern A. Zeeb 	 * @CT_KILL_NOTIFICATION: &struct ct_kill_notif
43bfcc09ddSBjoern A. Zeeb 	 */
44bfcc09ddSBjoern A. Zeeb 	CT_KILL_NOTIFICATION = 0xFE,
45bfcc09ddSBjoern A. Zeeb 
46bfcc09ddSBjoern A. Zeeb 	/**
47bfcc09ddSBjoern A. Zeeb 	 * @DTS_MEASUREMENT_NOTIF_WIDE:
48bfcc09ddSBjoern A. Zeeb 	 * &struct iwl_dts_measurement_notif_v1 or
49bfcc09ddSBjoern A. Zeeb 	 * &struct iwl_dts_measurement_notif_v2
50bfcc09ddSBjoern A. Zeeb 	 */
51bfcc09ddSBjoern A. Zeeb 	DTS_MEASUREMENT_NOTIF_WIDE = 0xFF,
52bfcc09ddSBjoern A. Zeeb };
53bfcc09ddSBjoern A. Zeeb 
54bfcc09ddSBjoern A. Zeeb /* DTS measurements */
55bfcc09ddSBjoern A. Zeeb 
56bfcc09ddSBjoern A. Zeeb enum iwl_dts_measurement_flags {
57bfcc09ddSBjoern A. Zeeb 	DTS_TRIGGER_CMD_FLAGS_TEMP	= BIT(0),
58bfcc09ddSBjoern A. Zeeb 	DTS_TRIGGER_CMD_FLAGS_VOLT	= BIT(1),
59bfcc09ddSBjoern A. Zeeb };
60bfcc09ddSBjoern A. Zeeb 
61bfcc09ddSBjoern A. Zeeb /**
62bfcc09ddSBjoern A. Zeeb  * struct iwl_dts_measurement_cmd - request DTS temp and/or voltage measurements
63bfcc09ddSBjoern A. Zeeb  *
64bfcc09ddSBjoern A. Zeeb  * @flags: indicates which measurements we want as specified in
65bfcc09ddSBjoern A. Zeeb  *	&enum iwl_dts_measurement_flags
66bfcc09ddSBjoern A. Zeeb  */
67bfcc09ddSBjoern A. Zeeb struct iwl_dts_measurement_cmd {
68bfcc09ddSBjoern A. Zeeb 	__le32 flags;
69bfcc09ddSBjoern A. Zeeb } __packed; /* TEMPERATURE_MEASUREMENT_TRIGGER_CMD_S */
70bfcc09ddSBjoern A. Zeeb 
71bfcc09ddSBjoern A. Zeeb /**
72bfcc09ddSBjoern A. Zeeb * enum iwl_dts_control_measurement_mode - DTS measurement type
73bfcc09ddSBjoern A. Zeeb * @DTS_AUTOMATIC: Automatic mode (full SW control). Provide temperature read
74bfcc09ddSBjoern A. Zeeb *                 back (latest value. Not waiting for new value). Use automatic
75bfcc09ddSBjoern A. Zeeb *                 SW DTS configuration.
76bfcc09ddSBjoern A. Zeeb * @DTS_REQUEST_READ: Request DTS read. Configure DTS with manual settings,
77bfcc09ddSBjoern A. Zeeb *                    trigger DTS reading and provide read back temperature read
78bfcc09ddSBjoern A. Zeeb *                    when available.
79bfcc09ddSBjoern A. Zeeb * @DTS_OVER_WRITE: over-write the DTS temperatures in the SW until next read
80bfcc09ddSBjoern A. Zeeb * @DTS_DIRECT_WITHOUT_MEASURE: DTS returns its latest temperature result,
81bfcc09ddSBjoern A. Zeeb *                              without measurement trigger.
82bfcc09ddSBjoern A. Zeeb */
83bfcc09ddSBjoern A. Zeeb enum iwl_dts_control_measurement_mode {
84bfcc09ddSBjoern A. Zeeb 	DTS_AUTOMATIC			= 0,
85bfcc09ddSBjoern A. Zeeb 	DTS_REQUEST_READ		= 1,
86bfcc09ddSBjoern A. Zeeb 	DTS_OVER_WRITE			= 2,
87bfcc09ddSBjoern A. Zeeb 	DTS_DIRECT_WITHOUT_MEASURE	= 3,
88bfcc09ddSBjoern A. Zeeb };
89bfcc09ddSBjoern A. Zeeb 
90bfcc09ddSBjoern A. Zeeb /**
91bfcc09ddSBjoern A. Zeeb * enum iwl_dts_used - DTS to use or used for measurement in the DTS request
92bfcc09ddSBjoern A. Zeeb * @DTS_USE_TOP: Top
93bfcc09ddSBjoern A. Zeeb * @DTS_USE_CHAIN_A: chain A
94bfcc09ddSBjoern A. Zeeb * @DTS_USE_CHAIN_B: chain B
95bfcc09ddSBjoern A. Zeeb * @DTS_USE_CHAIN_C: chain C
96bfcc09ddSBjoern A. Zeeb * @XTAL_TEMPERATURE: read temperature from xtal
97bfcc09ddSBjoern A. Zeeb */
98bfcc09ddSBjoern A. Zeeb enum iwl_dts_used {
99bfcc09ddSBjoern A. Zeeb 	DTS_USE_TOP		= 0,
100bfcc09ddSBjoern A. Zeeb 	DTS_USE_CHAIN_A		= 1,
101bfcc09ddSBjoern A. Zeeb 	DTS_USE_CHAIN_B		= 2,
102bfcc09ddSBjoern A. Zeeb 	DTS_USE_CHAIN_C		= 3,
103bfcc09ddSBjoern A. Zeeb 	XTAL_TEMPERATURE	= 4,
104bfcc09ddSBjoern A. Zeeb };
105bfcc09ddSBjoern A. Zeeb 
106bfcc09ddSBjoern A. Zeeb /**
107bfcc09ddSBjoern A. Zeeb * enum iwl_dts_bit_mode - bit-mode to use in DTS request read mode
108bfcc09ddSBjoern A. Zeeb * @DTS_BIT6_MODE: bit 6 mode
109bfcc09ddSBjoern A. Zeeb * @DTS_BIT8_MODE: bit 8 mode
110bfcc09ddSBjoern A. Zeeb */
111bfcc09ddSBjoern A. Zeeb enum iwl_dts_bit_mode {
112bfcc09ddSBjoern A. Zeeb 	DTS_BIT6_MODE	= 0,
113bfcc09ddSBjoern A. Zeeb 	DTS_BIT8_MODE	= 1,
114bfcc09ddSBjoern A. Zeeb };
115bfcc09ddSBjoern A. Zeeb 
116bfcc09ddSBjoern A. Zeeb /**
117bfcc09ddSBjoern A. Zeeb  * struct iwl_ext_dts_measurement_cmd - request extended DTS temp measurements
118bfcc09ddSBjoern A. Zeeb  * @control_mode: see &enum iwl_dts_control_measurement_mode
119bfcc09ddSBjoern A. Zeeb  * @temperature: used when over write DTS mode is selected
120bfcc09ddSBjoern A. Zeeb  * @sensor: set temperature sensor to use. See &enum iwl_dts_used
121bfcc09ddSBjoern A. Zeeb  * @avg_factor: average factor to DTS in request DTS read mode
122bfcc09ddSBjoern A. Zeeb  * @bit_mode: value defines the DTS bit mode to use. See &enum iwl_dts_bit_mode
123bfcc09ddSBjoern A. Zeeb  * @step_duration: step duration for the DTS
124bfcc09ddSBjoern A. Zeeb  */
125bfcc09ddSBjoern A. Zeeb struct iwl_ext_dts_measurement_cmd {
126bfcc09ddSBjoern A. Zeeb 	__le32 control_mode;
127bfcc09ddSBjoern A. Zeeb 	__le32 temperature;
128bfcc09ddSBjoern A. Zeeb 	__le32 sensor;
129bfcc09ddSBjoern A. Zeeb 	__le32 avg_factor;
130bfcc09ddSBjoern A. Zeeb 	__le32 bit_mode;
131bfcc09ddSBjoern A. Zeeb 	__le32 step_duration;
132bfcc09ddSBjoern A. Zeeb } __packed; /* XVT_FW_DTS_CONTROL_MEASUREMENT_REQUEST_API_S */
133bfcc09ddSBjoern A. Zeeb 
134bfcc09ddSBjoern A. Zeeb /**
135bfcc09ddSBjoern A. Zeeb  * struct iwl_dts_measurement_notif_v1 - measurements notification
136bfcc09ddSBjoern A. Zeeb  *
137bfcc09ddSBjoern A. Zeeb  * @temp: the measured temperature
138bfcc09ddSBjoern A. Zeeb  * @voltage: the measured voltage
139bfcc09ddSBjoern A. Zeeb  */
140bfcc09ddSBjoern A. Zeeb struct iwl_dts_measurement_notif_v1 {
141bfcc09ddSBjoern A. Zeeb 	__le32 temp;
142bfcc09ddSBjoern A. Zeeb 	__le32 voltage;
143bfcc09ddSBjoern A. Zeeb } __packed; /* TEMPERATURE_MEASUREMENT_TRIGGER_NTFY_S_VER_1*/
144bfcc09ddSBjoern A. Zeeb 
145bfcc09ddSBjoern A. Zeeb /**
146bfcc09ddSBjoern A. Zeeb  * struct iwl_dts_measurement_notif_v2 - measurements notification
147bfcc09ddSBjoern A. Zeeb  *
148bfcc09ddSBjoern A. Zeeb  * @temp: the measured temperature
149bfcc09ddSBjoern A. Zeeb  * @voltage: the measured voltage
150bfcc09ddSBjoern A. Zeeb  * @threshold_idx: the trip index that was crossed
151bfcc09ddSBjoern A. Zeeb  */
152bfcc09ddSBjoern A. Zeeb struct iwl_dts_measurement_notif_v2 {
153bfcc09ddSBjoern A. Zeeb 	__le32 temp;
154bfcc09ddSBjoern A. Zeeb 	__le32 voltage;
155bfcc09ddSBjoern A. Zeeb 	__le32 threshold_idx;
156bfcc09ddSBjoern A. Zeeb } __packed; /* TEMPERATURE_MEASUREMENT_TRIGGER_NTFY_S_VER_2 */
157bfcc09ddSBjoern A. Zeeb 
158bfcc09ddSBjoern A. Zeeb /**
159bfcc09ddSBjoern A. Zeeb  * struct iwl_dts_measurement_resp - measurements response
160bfcc09ddSBjoern A. Zeeb  *
161bfcc09ddSBjoern A. Zeeb  * @temp: the measured temperature
162bfcc09ddSBjoern A. Zeeb  */
163bfcc09ddSBjoern A. Zeeb struct iwl_dts_measurement_resp {
164bfcc09ddSBjoern A. Zeeb 	__le32 temp;
165bfcc09ddSBjoern A. Zeeb } __packed; /* CMD_DTS_MEASUREMENT_RSP_API_S_VER_1 */
166bfcc09ddSBjoern A. Zeeb 
167bfcc09ddSBjoern A. Zeeb /**
168bfcc09ddSBjoern A. Zeeb  * struct ct_kill_notif - CT-kill entry notification
169*d9836fb4SBjoern A. Zeeb  * This structure represent both versions of this notification.
170bfcc09ddSBjoern A. Zeeb  *
171bfcc09ddSBjoern A. Zeeb  * @temperature: the current temperature in celsius
172*d9836fb4SBjoern A. Zeeb  * @dts: only in v2: DTS that trigger the CT Kill bitmap:
173*d9836fb4SBjoern A. Zeeb  *			bit 0: ToP master
174*d9836fb4SBjoern A. Zeeb  *			bit 1: PA chain A master
175*d9836fb4SBjoern A. Zeeb  *			bit 2: PA chain B master
176*d9836fb4SBjoern A. Zeeb  *			bit 3: ToP slave
177*d9836fb4SBjoern A. Zeeb  *			bit 4: PA chain A slave
178*d9836fb4SBjoern A. Zeeb  *			bit 5: PA chain B slave)
179*d9836fb4SBjoern A. Zeeb  *			bits 6,7: reserved (set to 0)
180*d9836fb4SBjoern A. Zeeb  * @scheme: only for v2: scheme that trigger the CT Kill (0-SW, 1-HW)
181bfcc09ddSBjoern A. Zeeb  */
182bfcc09ddSBjoern A. Zeeb struct ct_kill_notif {
183bfcc09ddSBjoern A. Zeeb 	__le16 temperature;
184*d9836fb4SBjoern A. Zeeb 	u8 dts;
185*d9836fb4SBjoern A. Zeeb 	u8 scheme;
186*d9836fb4SBjoern A. Zeeb } __packed; /* CT_KILL_NOTIFICATION_API_S_VER_1, CT_KILL_NOTIFICATION_API_S_VER_2 */
187bfcc09ddSBjoern A. Zeeb 
188bfcc09ddSBjoern A. Zeeb /**
189bfcc09ddSBjoern A. Zeeb * enum ctdp_cmd_operation - CTDP command operations
190bfcc09ddSBjoern A. Zeeb * @CTDP_CMD_OPERATION_START: update the current budget
191bfcc09ddSBjoern A. Zeeb * @CTDP_CMD_OPERATION_STOP: stop ctdp
192bfcc09ddSBjoern A. Zeeb * @CTDP_CMD_OPERATION_REPORT: get the average budget
193bfcc09ddSBjoern A. Zeeb */
194bfcc09ddSBjoern A. Zeeb enum iwl_mvm_ctdp_cmd_operation {
195bfcc09ddSBjoern A. Zeeb 	CTDP_CMD_OPERATION_START	= 0x1,
196bfcc09ddSBjoern A. Zeeb 	CTDP_CMD_OPERATION_STOP		= 0x2,
197bfcc09ddSBjoern A. Zeeb 	CTDP_CMD_OPERATION_REPORT	= 0x4,
198bfcc09ddSBjoern A. Zeeb };/* CTDP_CMD_OPERATION_TYPE_E */
199bfcc09ddSBjoern A. Zeeb 
200bfcc09ddSBjoern A. Zeeb /**
201bfcc09ddSBjoern A. Zeeb  * struct iwl_mvm_ctdp_cmd - track and manage the FW power consumption budget
202bfcc09ddSBjoern A. Zeeb  *
203bfcc09ddSBjoern A. Zeeb  * @operation: see &enum iwl_mvm_ctdp_cmd_operation
204bfcc09ddSBjoern A. Zeeb  * @budget: the budget in milliwatt
205bfcc09ddSBjoern A. Zeeb  * @window_size: defined in API but not used
206bfcc09ddSBjoern A. Zeeb  */
207bfcc09ddSBjoern A. Zeeb struct iwl_mvm_ctdp_cmd {
208bfcc09ddSBjoern A. Zeeb 	__le32 operation;
209bfcc09ddSBjoern A. Zeeb 	__le32 budget;
210bfcc09ddSBjoern A. Zeeb 	__le32 window_size;
211bfcc09ddSBjoern A. Zeeb } __packed;
212bfcc09ddSBjoern A. Zeeb 
213bfcc09ddSBjoern A. Zeeb #define IWL_MAX_DTS_TRIPS	8
214bfcc09ddSBjoern A. Zeeb 
215bfcc09ddSBjoern A. Zeeb /**
216bfcc09ddSBjoern A. Zeeb  * struct temp_report_ths_cmd - set temperature thresholds
217bfcc09ddSBjoern A. Zeeb  *
218bfcc09ddSBjoern A. Zeeb  * @num_temps: number of temperature thresholds passed
219bfcc09ddSBjoern A. Zeeb  * @thresholds: array with the thresholds to be configured
220bfcc09ddSBjoern A. Zeeb  */
221bfcc09ddSBjoern A. Zeeb struct temp_report_ths_cmd {
222bfcc09ddSBjoern A. Zeeb 	__le32 num_temps;
223bfcc09ddSBjoern A. Zeeb 	__le16 thresholds[IWL_MAX_DTS_TRIPS];
224bfcc09ddSBjoern A. Zeeb } __packed; /* GRP_PHY_TEMP_REPORTING_THRESHOLDS_CMD */
225bfcc09ddSBjoern A. Zeeb 
226bfcc09ddSBjoern A. Zeeb #endif /* __iwl_fw_api_phy_h__ */
227