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