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