Linux Audio

Check our new training course

Loading...
  1/* SPDX-License-Identifier: ISC */
  2/*
  3 * Copyright (C) 2022 MediaTek Inc.
  4 */
  5
  6#ifndef __MT7996_MCU_H
  7#define __MT7996_MCU_H
  8
  9#include "../mt76_connac_mcu.h"
 10
 11struct mt7996_mcu_rxd {
 12	__le32 rxd[8];
 13
 14	__le16 len;
 15	__le16 pkt_type_id;
 16
 17	u8 eid;
 18	u8 seq;
 19	u8 option;
 20	u8 __rsv;
 21
 22	u8 ext_eid;
 23	u8 __rsv1[2];
 24	u8 s2d_index;
 25};
 26
 27struct mt7996_mcu_uni_event {
 28	u8 cid;
 29	u8 __rsv[3];
 30	__le32 status; /* 0: success, others: fail */
 31} __packed;
 32
 33struct mt7996_mcu_thermal_ctrl {
 34	u8 ctrl_id;
 35	u8 band_idx;
 36	union {
 37		struct {
 38			u8 protect_type; /* 1: duty admit, 2: radio off */
 39			u8 trigger_type; /* 0: low, 1: high */
 40		} __packed type;
 41		struct {
 42			u8 duty_level;	/* level 0~3 */
 43			u8 duty_cycle;
 44		} __packed duty;
 45	};
 46} __packed;
 47
 48struct mt7996_mcu_thermal_enable {
 49	__le32 trigger_temp;
 50	__le32 restore_temp;
 51	__le16 sustain_time;
 52	u8 rsv[2];
 53} __packed;
 54
 55struct mt7996_mcu_csa_notify {
 56	struct mt7996_mcu_rxd rxd;
 57
 58	u8 omac_idx;
 59	u8 csa_count;
 60	u8 band_idx;
 61	u8 rsv;
 62} __packed;
 63
 64struct mt7996_mcu_rdd_report {
 65	struct mt7996_mcu_rxd rxd;
 66
 67	u8 __rsv1[4];
 68
 69	__le16 tag;
 70	__le16 len;
 71
 72	u8 band_idx;
 73	u8 long_detected;
 74	u8 constant_prf_detected;
 75	u8 staggered_prf_detected;
 76	u8 radar_type_idx;
 77	u8 periodic_pulse_num;
 78	u8 long_pulse_num;
 79	u8 hw_pulse_num;
 80
 81	u8 out_lpn;
 82	u8 out_spn;
 83	u8 out_crpn;
 84	u8 out_crpw;
 85	u8 out_crbn;
 86	u8 out_stgpn;
 87	u8 out_stgpw;
 88
 89	u8 __rsv2;
 90
 91	__le32 out_pri_const;
 92	__le32 out_pri_stg[3];
 93	__le32 out_pri_stg_dmin;
 94
 95	struct {
 96		__le32 start;
 97		__le16 pulse_width;
 98		__le16 pulse_power;
 99		u8 mdrdy_flag;
100		u8 rsv[3];
101	} long_pulse[32];
102
103	struct {
104		__le32 start;
105		__le16 pulse_width;
106		__le16 pulse_power;
107		u8 mdrdy_flag;
108		u8 rsv[3];
109	} periodic_pulse[32];
110
111	struct {
112		__le32 start;
113		__le16 pulse_width;
114		__le16 pulse_power;
115		u8 sc_pass;
116		u8 sw_reset;
117		u8 mdrdy_flag;
118		u8 tx_active;
119	} hw_pulse[32];
120} __packed;
121
122struct mt7996_mcu_background_chain_ctrl {
123	u8 _rsv[4];
124
125	__le16 tag;
126	__le16 len;
127
128	u8 chan;		/* primary channel */
129	u8 central_chan;	/* central channel */
130	u8 bw;
131	u8 tx_stream;
132	u8 rx_stream;
133
134	u8 monitor_chan;	/* monitor channel */
135	u8 monitor_central_chan;/* monitor central channel */
136	u8 monitor_bw;
137	u8 monitor_tx_stream;
138	u8 monitor_rx_stream;
139
140	u8 scan_mode;		/* 0: ScanStop
141				 * 1: ScanStart
142				 * 2: ScanRunning
143				 */
144	u8 band_idx;		/* DBDC */
145	u8 monitor_scan_type;
146	u8 band;		/* 0: 2.4GHz, 1: 5GHz */
147	u8 rsv[2];
148} __packed;
149
150struct mt7996_mcu_eeprom {
151	u8 _rsv[4];
152
153	__le16 tag;
154	__le16 len;
155	u8 buffer_mode;
156	u8 format;
157	__le16 buf_len;
158} __packed;
159
160struct mt7996_mcu_phy_rx_info {
161	u8 category;
162	u8 rate;
163	u8 mode;
164	u8 nsts;
165	u8 gi;
166	u8 coding;
167	u8 stbc;
168	u8 bw;
169};
170
171struct mt7996_mcu_mib {
172	__le16 tag;
173	__le16 len;
174	__le32 offs;
175	__le64 data;
176} __packed;
177
178struct all_sta_trx_rate {
179	__le16 wlan_idx;
180	u8 __rsv1[2];
181	u8 tx_mode;
182	u8 flags;
183	u8 tx_stbc;
184	u8 tx_gi;
185	u8 tx_bw;
186	u8 tx_ldpc;
187	u8 tx_mcs;
188	u8 tx_nss;
189	u8 rx_rate;
190	u8 rx_mode;
191	u8 rx_nsts;
192	u8 rx_gi;
193	u8 rx_coding;
194	u8 rx_stbc;
195	u8 rx_bw;
196	u8 __rsv2;
197} __packed;
198
199struct mt7996_mcu_all_sta_info_event {
200	u8 rsv[4];
201	__le16 tag;
202	__le16 len;
203	u8 more;
204	u8 rsv2;
205	__le16 sta_num;
206	u8 rsv3[4];
207
208	union {
209		DECLARE_FLEX_ARRAY(struct all_sta_trx_rate, rate);
210		DECLARE_FLEX_ARRAY(struct {
211			__le16 wlan_idx;
212			u8 rsv[2];
213			__le32 tx_bytes[IEEE80211_NUM_ACS];
214			__le32 rx_bytes[IEEE80211_NUM_ACS];
215		} __packed, adm_stat);
216
217		DECLARE_FLEX_ARRAY(struct {
218			__le16 wlan_idx;
219			u8 rsv[2];
220			__le32 tx_msdu_cnt;
221			__le32 rx_msdu_cnt;
222		} __packed, msdu_cnt);
223	} __packed;
224} __packed;
225
226struct mt7996_mcu_wed_rro_event {
227	struct mt7996_mcu_rxd rxd;
228
229	u8 __rsv1[4];
230
231	__le16 tag;
232	__le16 len;
233} __packed;
234
235struct mt7996_mcu_wed_rro_ba_event {
236	__le16 tag;
237	__le16 len;
238
239	__le16 wlan_id;
240	u8 tid;
241	u8 __rsv1;
242	__le32 status;
243	__le16 id;
244	u8 __rsv2[2];
245} __packed;
246
247struct mt7996_mcu_wed_rro_ba_delete_event {
248	__le16 tag;
249	__le16 len;
250
251	__le16 session_id;
252	u8 __rsv2[2];
253} __packed;
254
255enum  {
256	UNI_WED_RRO_BA_SESSION_STATUS,
257	UNI_WED_RRO_BA_SESSION_TBL,
258	UNI_WED_RRO_BA_SESSION_DELETE,
259};
260
261struct mt7996_mcu_thermal_notify {
262	struct mt7996_mcu_rxd rxd;
263
264	u8 __rsv1[4];
265
266	__le16 tag;
267	__le16 len;
268
269	u8 event_id;
270	u8 band_idx;
271	u8 level_idx;
272	u8 duty_percent;
273	__le32 restore_temp;
274	u8 __rsv2[4];
275} __packed;
276
277enum mt7996_chan_mib_offs {
278	UNI_MIB_OBSS_AIRTIME = 26,
279	UNI_MIB_NON_WIFI_TIME = 27,
280	UNI_MIB_TX_TIME = 28,
281	UNI_MIB_RX_TIME = 29
282};
283
284struct edca {
285	__le16 tag;
286	__le16 len;
287
288	u8 queue;
289	u8 set;
290	u8 cw_min;
291	u8 cw_max;
292	__le16 txop;
293	u8 aifs;
294	u8 __rsv;
295};
296
297#define MCU_PQ_ID(p, q)			(((p) << 15) | ((q) << 10))
298#define MCU_PKT_ID			0xa0
299
300enum {
301	MCU_FW_LOG_WM,
302	MCU_FW_LOG_WA,
303	MCU_FW_LOG_TO_HOST,
304	MCU_FW_LOG_RELAY = 16
305};
306
307enum {
308	MCU_TWT_AGRT_ADD,
309	MCU_TWT_AGRT_MODIFY,
310	MCU_TWT_AGRT_DELETE,
311	MCU_TWT_AGRT_TEARDOWN,
312	MCU_TWT_AGRT_GET_TSF,
313};
314
315enum {
316	MCU_WA_PARAM_CMD_QUERY,
317	MCU_WA_PARAM_CMD_SET,
318	MCU_WA_PARAM_CMD_CAPABILITY,
319	MCU_WA_PARAM_CMD_DEBUG,
320};
321
322enum {
323	MCU_WA_PARAM_PDMA_RX = 0x04,
324	MCU_WA_PARAM_CPU_UTIL = 0x0b,
325	MCU_WA_PARAM_RED = 0x0e,
326	MCU_WA_PARAM_HW_PATH_HIF_VER = 0x2f,
327};
328
329enum mcu_mmps_mode {
330	MCU_MMPS_STATIC,
331	MCU_MMPS_DYNAMIC,
332	MCU_MMPS_RSV,
333	MCU_MMPS_DISABLE,
334};
335
336struct bss_rate_tlv {
337	__le16 tag;
338	__le16 len;
339	u8 __rsv1[4];
340	__le16 bc_trans;
341	__le16 mc_trans;
342	u8 short_preamble;
343	u8 bc_fixed_rate;
344	u8 mc_fixed_rate;
345	u8 __rsv2[9];
346} __packed;
347
348enum {
349	BP_DISABLE,
350	BP_SW_MODE,
351	BP_HW_MODE,
352};
353
354struct mt7996_mcu_bcn_prot_tlv {
355	__le16 tag;
356	__le16 len;
357	u8 pn[6];
358	u8 enable;
359	u8 cipher_id;
360	u8 key[WLAN_MAX_KEY_LEN];
361	u8 key_id;
362	u8 __rsv[3];
363} __packed;
364
365struct bss_ra_tlv {
366	__le16 tag;
367	__le16 len;
368	u8 short_preamble;
369	u8 force_sgi;
370	u8 force_gf;
371	u8 ht_mode;
372	u8 se_off;
373	u8 antenna_idx;
374	__le16 max_phyrate;
375	u8 force_tx_streams;
376	u8 __rsv[3];
377} __packed;
378
379struct bss_rlm_tlv {
380	__le16 tag;
381	__le16 len;
382	u8 control_channel;
383	u8 center_chan;
384	u8 center_chan2;
385	u8 bw;
386	u8 tx_streams;
387	u8 rx_streams;
388	u8 ht_op_info;
389	u8 sco;
390	u8 band;
391	u8 __rsv[3];
392} __packed;
393
394struct bss_color_tlv {
395	__le16 tag;
396	__le16 len;
397	u8 enable;
398	u8 color;
399	u8 rsv[2];
400} __packed;
401
402struct bss_inband_discovery_tlv {
403	__le16 tag;
404	__le16 len;
405	u8 tx_type;
406	u8 tx_mode;
407	u8 tx_interval;
408	u8 enable;
409	__le16 wcid;
410	__le16 prob_rsp_len;
411} __packed;
412
413struct bss_bcn_content_tlv {
414	__le16 tag;
415	__le16 len;
416	__le16 tim_ie_pos;
417	__le16 csa_ie_pos;
418	__le16 bcc_ie_pos;
419	u8 enable;
420	u8 type;
421	__le16 pkt_len;
422} __packed;
423
424struct bss_bcn_cntdwn_tlv {
425	__le16 tag;
426	__le16 len;
427	u8 cnt;
428	u8 rsv[3];
429} __packed;
430
431struct bss_bcn_mbss_tlv {
432	__le16 tag;
433	__le16 len;
434	__le32 bitmap;
435#define MAX_BEACON_NUM	32
436	__le16 offset[MAX_BEACON_NUM];
437} __packed __aligned(4);
438
439struct bss_txcmd_tlv {
440	__le16 tag;
441	__le16 len;
442	u8 txcmd_mode;
443	u8 __rsv[3];
444} __packed;
445
446struct bss_sec_tlv {
447	__le16 tag;
448	__le16 len;
449	u8 __rsv1[2];
450	u8 cipher;
451	u8 __rsv2[1];
452} __packed;
453
454struct bss_ifs_time_tlv {
455	__le16 tag;
456	__le16 len;
457	u8 slot_valid;
458	u8 sifs_valid;
459	u8 rifs_valid;
460	u8 eifs_valid;
461	__le16 slot_time;
462	__le16 sifs_time;
463	__le16 rifs_time;
464	__le16 eifs_time;
465	u8 eifs_cck_valid;
466	u8 rsv;
467	__le16 eifs_cck_time;
468} __packed;
469
470struct bss_power_save {
471	__le16 tag;
472	__le16 len;
473	u8 profile;
474	u8 _rsv[3];
475} __packed;
476
477struct bss_mld_tlv {
478	__le16 tag;
479	__le16 len;
480	u8 group_mld_id;
481	u8 own_mld_id;
482	u8 mac_addr[ETH_ALEN];
483	u8 remap_idx;
484	u8 __rsv[3];
485} __packed;
486
487struct sta_rec_ht_uni {
488	__le16 tag;
489	__le16 len;
490	__le16 ht_cap;
491	__le16 ht_cap_ext;
492	u8 ampdu_param;
493	u8 _rsv[3];
494} __packed;
495
496struct sta_rec_ba_uni {
497	__le16 tag;
498	__le16 len;
499	u8 tid;
500	u8 ba_type;
501	u8 amsdu;
502	u8 ba_en;
503	__le16 ssn;
504	__le16 winsize;
505	u8 ba_rdd_rro;
506	u8 __rsv[3];
507} __packed;
508
509struct sta_rec_eht {
510	__le16 tag;
511	__le16 len;
512	u8 tid_bitmap;
513	u8 _rsv;
514	__le16 mac_cap;
515	__le64 phy_cap;
516	__le64 phy_cap_ext;
517	u8 mcs_map_bw20[4];
518	u8 mcs_map_bw80[3];
519	u8 mcs_map_bw160[3];
520	u8 mcs_map_bw320[3];
521	u8 _rsv2[3];
522} __packed;
523
524struct sec_key_uni {
525	__le16 wlan_idx;
526	u8 mgmt_prot;
527	u8 cipher_id;
528	u8 cipher_len;
529	u8 key_id;
530	u8 key_len;
531	u8 need_resp;
532	u8 key[32];
533} __packed;
534
535struct sta_rec_sec_uni {
536	__le16 tag;
537	__le16 len;
538	u8 add;
539	u8 n_cipher;
540	u8 rsv[2];
541
542	struct sec_key_uni key[2];
543} __packed;
544
545struct sta_phy_uni {
546	u8 type;
547	u8 flag;
548	u8 stbc;
549	u8 sgi;
550	u8 bw;
551	u8 ldpc;
552	u8 mcs;
553	u8 nss;
554	u8 he_ltf;
555	u8 rsv[3];
556};
557
558struct sta_rec_ra_uni {
559	__le16 tag;
560	__le16 len;
561
562	u8 valid;
563	u8 auto_rate;
564	u8 phy_mode;
565	u8 channel;
566	u8 bw;
567	u8 disable_cck;
568	u8 ht_mcs32;
569	u8 ht_gf;
570	u8 ht_mcs[4];
571	u8 mmps_mode;
572	u8 gband_256;
573	u8 af;
574	u8 auth_wapi_mode;
575	u8 rate_len;
576
577	u8 supp_mode;
578	u8 supp_cck_rate;
579	u8 supp_ofdm_rate;
580	__le32 supp_ht_mcs;
581	__le16 supp_vht_mcs[4];
582
583	u8 op_mode;
584	u8 op_vht_chan_width;
585	u8 op_vht_rx_nss;
586	u8 op_vht_rx_nss_type;
587
588	__le32 sta_cap;
589
590	struct sta_phy_uni phy;
591	u8 rx_rcpi[4];
592} __packed;
593
594struct sta_rec_ra_fixed_uni {
595	__le16 tag;
596	__le16 len;
597
598	__le32 field;
599	u8 op_mode;
600	u8 op_vht_chan_width;
601	u8 op_vht_rx_nss;
602	u8 op_vht_rx_nss_type;
603
604	struct sta_phy_uni phy;
605
606	u8 spe_idx;
607	u8 short_preamble;
608	u8 is_5g;
609	u8 mmps_mode;
610} __packed;
611
612struct sta_rec_hdrt {
613	__le16 tag;
614	__le16 len;
615	u8 hdrt_mode;
616	u8 rsv[3];
617} __packed;
618
619struct sta_rec_hdr_trans {
620	__le16 tag;
621	__le16 len;
622	u8 from_ds;
623	u8 to_ds;
624	u8 dis_rx_hdr_tran;
625	u8 mesh;
626} __packed;
627
628struct hdr_trans_en {
629	__le16 tag;
630	__le16 len;
631	u8 enable;
632	u8 check_bssid;
633	u8 mode;
634	u8 __rsv;
635} __packed;
636
637struct hdr_trans_vlan {
638	__le16 tag;
639	__le16 len;
640	u8 insert_vlan;
641	u8 remove_vlan;
642	u8 tid;
643	u8 __rsv;
644} __packed;
645
646struct hdr_trans_blacklist {
647	__le16 tag;
648	__le16 len;
649	u8 idx;
650	u8 enable;
651	__le16 type;
652} __packed;
653
654struct uni_header {
655	u8 __rsv[4];
656} __packed;
657
658struct vow_rx_airtime {
659	__le16 tag;
660	__le16 len;
661
662	u8 enable;
663	u8 band;
664	u8 __rsv[2];
665} __packed;
666
667struct bf_sounding_on {
668	__le16 tag;
669	__le16 len;
670
671	u8 snd_mode;
672	u8 sta_num;
673	u8 __rsv[2];
674	__le16 wlan_id[4];
675	__le32 snd_period;
676} __packed;
677
678struct bf_hw_en_status_update {
679	__le16 tag;
680	__le16 len;
681
682	bool ebf;
683	bool ibf;
684	u8 __rsv[2];
685} __packed;
686
687struct bf_mod_en_ctrl {
688	__le16 tag;
689	__le16 len;
690
691	u8 bf_num;
692	u8 bf_bitmap;
693	u8 bf_sel[8];
694	u8 __rsv[2];
695} __packed;
696
697union bf_tag_tlv {
698	struct bf_sounding_on bf_snd;
699	struct bf_hw_en_status_update bf_hw_en;
700	struct bf_mod_en_ctrl bf_mod_en;
701};
702
703struct ra_rate {
704	__le16 wlan_idx;
705	u8 mode;
706	u8 stbc;
707	__le16 gi;
708	u8 bw;
709	u8 ldpc;
710	u8 mcs;
711	u8 nss;
712	__le16 ltf;
713	u8 spe;
714	u8 preamble;
715	u8 __rsv[2];
716} __packed;
717
718struct ra_fixed_rate {
719	__le16 tag;
720	__le16 len;
721
722	__le16 version;
723	struct ra_rate rate;
724} __packed;
725
726enum {
727	UNI_RA_FIXED_RATE = 0xf,
728};
729
730#define MT7996_HDR_TRANS_MAX_SIZE	(sizeof(struct hdr_trans_en) +	 \
731					 sizeof(struct hdr_trans_vlan) + \
732					 sizeof(struct hdr_trans_blacklist))
733
734enum {
735	UNI_HDR_TRANS_EN,
736	UNI_HDR_TRANS_VLAN,
737	UNI_HDR_TRANS_BLACKLIST,
738};
739
740enum {
741	RATE_PARAM_FIXED = 3,
742	RATE_PARAM_MMPS_UPDATE = 5,
743	RATE_PARAM_FIXED_HE_LTF = 7,
744	RATE_PARAM_FIXED_MCS,
745	RATE_PARAM_FIXED_GI = 11,
746	RATE_PARAM_AUTO = 20,
747};
748
749enum {
750	BF_SOUNDING_ON = 1,
751	BF_HW_EN_UPDATE = 17,
752	BF_MOD_EN_CTRL = 20,
753};
754
755enum {
756	CMD_BAND_NONE,
757	CMD_BAND_24G,
758	CMD_BAND_5G,
759	CMD_BAND_6G,
760};
761
762struct bss_req_hdr {
763	u8 bss_idx;
764	u8 __rsv[3];
765} __packed;
766
767enum {
768	UNI_CHANNEL_SWITCH,
769	UNI_CHANNEL_RX_PATH,
770};
771
772#define MT7996_BSS_UPDATE_MAX_SIZE	(sizeof(struct bss_req_hdr) +		\
773					 sizeof(struct mt76_connac_bss_basic_tlv) +	\
774					 sizeof(struct bss_rlm_tlv) +		\
775					 sizeof(struct bss_ra_tlv) +		\
776					 sizeof(struct bss_info_uni_he) +	\
777					 sizeof(struct bss_rate_tlv) +		\
778					 sizeof(struct bss_txcmd_tlv) +		\
779					 sizeof(struct bss_power_save) +	\
780					 sizeof(struct bss_sec_tlv) +		\
781					 sizeof(struct bss_ifs_time_tlv) +	\
782					 sizeof(struct bss_mld_tlv))
783
784#define MT7996_STA_UPDATE_MAX_SIZE	(sizeof(struct sta_req_hdr) +		\
785					 sizeof(struct sta_rec_basic) +		\
786					 sizeof(struct sta_rec_bf) +		\
787					 sizeof(struct sta_rec_ht_uni) +	\
788					 sizeof(struct sta_rec_he_v2) +		\
789					 sizeof(struct sta_rec_ba_uni) +	\
790					 sizeof(struct sta_rec_vht) +		\
791					 sizeof(struct sta_rec_uapsd) + 	\
792					 sizeof(struct sta_rec_amsdu) +		\
793					 sizeof(struct sta_rec_bfee) +		\
794					 sizeof(struct sta_rec_ra_uni) +	\
795					 sizeof(struct sta_rec_sec) +		\
796					 sizeof(struct sta_rec_ra_fixed_uni) +	\
797					 sizeof(struct sta_rec_he_6g_capa) +	\
798					 sizeof(struct sta_rec_eht) +		\
799					 sizeof(struct sta_rec_hdrt) +		\
800					 sizeof(struct sta_rec_hdr_trans) +	\
801					 sizeof(struct tlv))
802
803#define MT7996_MAX_BEACON_SIZE		1338
804#define MT7996_BEACON_UPDATE_SIZE	(sizeof(struct bss_req_hdr) +		\
805					 sizeof(struct bss_bcn_content_tlv) +	\
806					 4 + MT_TXD_SIZE +			\
807					 sizeof(struct bss_bcn_cntdwn_tlv) +	\
808					 sizeof(struct bss_bcn_mbss_tlv))
809#define MT7996_MAX_BSS_OFFLOAD_SIZE	(MT7996_MAX_BEACON_SIZE +		\
810					 MT7996_BEACON_UPDATE_SIZE)
811
812static inline s8
813mt7996_get_power_bound(struct mt7996_phy *phy, s8 txpower)
814{
815	struct mt76_phy *mphy = phy->mt76;
816	int n_chains = hweight16(mphy->chainmask);
817
818	txpower = mt76_get_sar_power(mphy, mphy->chandef.chan, txpower * 2);
819	txpower -= mt76_tx_power_nss_delta(n_chains);
820
821	return txpower;
822}
823
824enum {
825	UNI_BAND_CONFIG_RADIO_ENABLE,
826	UNI_BAND_CONFIG_RTS_THRESHOLD = 0x08,
827};
828
829enum {
830	UNI_WSYS_CONFIG_FW_LOG_CTRL,
831	UNI_WSYS_CONFIG_FW_DBG_CTRL,
832};
833
834enum {
835	UNI_RDD_CTRL_PARM,
836	UNI_RDD_CTRL_SET_TH = 0x3,
837};
838
839enum {
840	UNI_EFUSE_ACCESS = 1,
841	UNI_EFUSE_BUFFER_MODE,
842	UNI_EFUSE_FREE_BLOCK,
843	UNI_EFUSE_BUFFER_RD,
844};
845
846enum {
847	UNI_VOW_DRR_CTRL,
848	UNI_VOW_RX_AT_AIRTIME_EN = 0x0b,
849	UNI_VOW_RX_AT_AIRTIME_CLR_EN = 0x0e,
850};
851
852enum {
853	UNI_CMD_MIB_DATA,
854};
855
856enum {
857	UNI_POWER_OFF,
858};
859
860enum {
861	UNI_CMD_TWT_ARGT_UPDATE = 0x0,
862	UNI_CMD_TWT_MGMT_OFFLOAD,
863};
864
865enum {
866	UNI_RRO_DEL_ENTRY = 0x1,
867	UNI_RRO_SET_PLATFORM_TYPE,
868	UNI_RRO_GET_BA_SESSION_TABLE,
869	UNI_RRO_SET_BYPASS_MODE,
870	UNI_RRO_SET_TXFREE_PATH,
871	UNI_RRO_DEL_BA_SESSION,
872	UNI_RRO_SET_FLUSH_TIMEOUT
873};
874
875enum{
876	UNI_CMD_SR_ENABLE = 0x1,
877	UNI_CMD_SR_ENABLE_SD,
878	UNI_CMD_SR_ENABLE_MODE,
879	UNI_CMD_SR_ENABLE_DPD = 0x12,
880	UNI_CMD_SR_ENABLE_TX,
881	UNI_CMD_SR_SET_SRG_BITMAP = 0x80,
882	UNI_CMD_SR_SET_PARAM = 0xc1,
883	UNI_CMD_SR_SET_SIGA = 0xd0,
884};
885
886enum {
887	UNI_CMD_THERMAL_PROTECT_ENABLE = 0x6,
888	UNI_CMD_THERMAL_PROTECT_DISABLE,
889	UNI_CMD_THERMAL_PROTECT_DUTY_CONFIG,
890};
891
892enum {
893	UNI_TXPOWER_POWER_LIMIT_TABLE_CTRL = 4,
894};
895
896enum {
897	UNI_CMD_ACCESS_REG_BASIC = 0x0,
898	UNI_CMD_ACCESS_RF_REG_BASIC,
899};
900
901enum {
902	UNI_CMD_SER_QUERY,
903	/* recovery */
904	UNI_CMD_SER_SET_RECOVER_L1,
905	UNI_CMD_SER_SET_RECOVER_L2,
906	UNI_CMD_SER_SET_RECOVER_L3_RX_ABORT,
907	UNI_CMD_SER_SET_RECOVER_L3_TX_ABORT,
908	UNI_CMD_SER_SET_RECOVER_L3_TX_DISABLE,
909	UNI_CMD_SER_SET_RECOVER_L3_BF,
910	UNI_CMD_SER_SET_RECOVER_L4_MDP,
911	UNI_CMD_SER_SET_RECOVER_FULL,
912	UNI_CMD_SER_SET_SYSTEM_ASSERT,
913	/* action */
914	UNI_CMD_SER_ENABLE = 1,
915	UNI_CMD_SER_SET,
916	UNI_CMD_SER_TRIGGER
917};
918
919enum {
920	MT7996_SEC_MODE_PLAIN,
921	MT7996_SEC_MODE_AES,
922	MT7996_SEC_MODE_SCRAMBLE,
923	MT7996_SEC_MODE_MAX,
924};
925
926#define MT7996_PATCH_SEC		GENMASK(31, 24)
927#define MT7996_PATCH_SCRAMBLE_KEY	GENMASK(15, 8)
928#define MT7996_PATCH_AES_KEY		GENMASK(7, 0)
929
930#define MT7996_SEC_ENCRYPT		BIT(0)
931#define MT7996_SEC_KEY_IDX		GENMASK(2, 1)
932#define MT7996_SEC_IV			BIT(3)
933
934struct fixed_rate_table_ctrl {
935	u8 _rsv[4];
936
937	__le16 tag;
938	__le16 len;
939
940	u8 table_idx;
941	u8 antenna_idx;
942	__le16 rate_idx;
943	u8 spe_idx_sel;
944	u8 spe_idx;
945	u8 gi;
946	u8 he_ltf;
947	bool ldpc;
948	bool txbf;
949	bool dynamic_bw;
950
951	u8 _rsv2;
952} __packed;
953
954#endif