xref: /freebsd/sys/contrib/dev/iwlwifi/mvm/constants.h (revision a4128aad8503277614f2d214011ef60a19447b83)
1bfcc09ddSBjoern A. Zeeb /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2bfcc09ddSBjoern A. Zeeb /*
3bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2013-2015 Intel Mobile Communications GmbH
4*a4128aadSBjoern A. Zeeb  * Copyright (C) 2013-2014, 2018-2024 Intel Corporation
5bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2015 Intel Deutschland GmbH
6bfcc09ddSBjoern A. Zeeb  */
7bfcc09ddSBjoern A. Zeeb #ifndef __MVM_CONSTANTS_H
8bfcc09ddSBjoern A. Zeeb #define __MVM_CONSTANTS_H
9bfcc09ddSBjoern A. Zeeb 
10bfcc09ddSBjoern A. Zeeb #include <linux/ieee80211.h>
11bfcc09ddSBjoern A. Zeeb #include "fw-api.h"
12bfcc09ddSBjoern A. Zeeb 
13bfcc09ddSBjoern A. Zeeb #define IWL_MVM_UAPSD_NOAGG_BSSIDS_NUM		20
14*a4128aadSBjoern A. Zeeb #define IWL_MVM_BT_COEX_DISABLE_ESR_THRESH	69
15*a4128aadSBjoern A. Zeeb #define IWL_MVM_BT_COEX_ENABLE_ESR_THRESH	63
16*a4128aadSBjoern A. Zeeb #define IWL_MVM_BT_COEX_WIFI_LOSS_THRESH	0
17*a4128aadSBjoern A. Zeeb #define IWL_MVM_TRIGGER_LINK_SEL_TIME_SEC	30
18*a4128aadSBjoern A. Zeeb #define IWL_MVM_TPT_COUNT_WINDOW_SEC		5
19bfcc09ddSBjoern A. Zeeb 
20bfcc09ddSBjoern A. Zeeb #define IWL_MVM_DEFAULT_PS_TX_DATA_TIMEOUT	(100 * USEC_PER_MSEC)
21bfcc09ddSBjoern A. Zeeb #define IWL_MVM_DEFAULT_PS_RX_DATA_TIMEOUT	(100 * USEC_PER_MSEC)
22bfcc09ddSBjoern A. Zeeb #define IWL_MVM_WOWLAN_PS_TX_DATA_TIMEOUT	(10 * USEC_PER_MSEC)
23bfcc09ddSBjoern A. Zeeb #define IWL_MVM_WOWLAN_PS_RX_DATA_TIMEOUT	(10 * USEC_PER_MSEC)
24bfcc09ddSBjoern A. Zeeb #define IWL_MVM_SHORT_PS_TX_DATA_TIMEOUT	(2 * 1024) /* defined in TU */
25bfcc09ddSBjoern A. Zeeb #define IWL_MVM_SHORT_PS_RX_DATA_TIMEOUT	(40 * 1024) /* defined in TU */
26*a4128aadSBjoern A. Zeeb #define IWL_MVM_P2P_LOWLATENCY_PS_ENABLE	1
27bfcc09ddSBjoern A. Zeeb #define IWL_MVM_UAPSD_RX_DATA_TIMEOUT		(50 * USEC_PER_MSEC)
28bfcc09ddSBjoern A. Zeeb #define IWL_MVM_UAPSD_TX_DATA_TIMEOUT		(50 * USEC_PER_MSEC)
29bfcc09ddSBjoern A. Zeeb #define IWL_MVM_UAPSD_QUEUES		(IEEE80211_WMM_IE_STA_QOSINFO_AC_VO |\
30bfcc09ddSBjoern A. Zeeb 					 IEEE80211_WMM_IE_STA_QOSINFO_AC_VI |\
31bfcc09ddSBjoern A. Zeeb 					 IEEE80211_WMM_IE_STA_QOSINFO_AC_BK |\
32bfcc09ddSBjoern A. Zeeb 					 IEEE80211_WMM_IE_STA_QOSINFO_AC_BE)
33bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_HEAVY_TX_THLD_PACKETS	20
34bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_HEAVY_RX_THLD_PACKETS	8
35bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_SNOOZE_HEAVY_TX_THLD_PACKETS	30
36bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_SNOOZE_HEAVY_RX_THLD_PACKETS	20
37bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_HEAVY_TX_THLD_PERCENT	50
38bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_HEAVY_RX_THLD_PERCENT	50
39bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_SNOOZE_INTERVAL		25
40bfcc09ddSBjoern A. Zeeb #define IWL_MVM_PS_SNOOZE_WINDOW		50
41bfcc09ddSBjoern A. Zeeb #define IWL_MVM_WOWLAN_PS_SNOOZE_WINDOW		25
42bfcc09ddSBjoern A. Zeeb #define IWL_MVM_LOWLAT_QUOTA_MIN_PERCENT	64
43bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_EN_RED_TXP_THRESH	62
44bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_DIS_RED_TXP_THRESH	65
45bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_SYNC2SCO		1
46bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_MPLUT			1
47bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_RRC			1
48bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_TTC			1
49bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_MPLUT_REG0		0x22002200
50bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_MPLUT_REG1		0x11118451
51bfcc09ddSBjoern A. Zeeb #define IWL_MVM_BT_COEX_ANTENNA_COUPLING_THRS	30
52bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FW_MCAST_FILTER_PASS_ALL	0
53bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FW_BCAST_FILTER_PASS_ALL	0
54bfcc09ddSBjoern A. Zeeb #define IWL_MVM_QUOTA_THRESHOLD			4
55bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_RSSI_BASED_INIT_RATE         0
56bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_80_20_FAR_RANGE_TWEAK	1
57bfcc09ddSBjoern A. Zeeb #define IWL_MVM_TOF_IS_RESPONDER		0
58bfcc09ddSBjoern A. Zeeb #define IWL_MVM_HW_CSUM_DISABLE			0
59bfcc09ddSBjoern A. Zeeb #define IWL_MVM_ADWELL_ENABLE			1
60bfcc09ddSBjoern A. Zeeb #define IWL_MVM_ADWELL_MAX_BUDGET		0
61bfcc09ddSBjoern A. Zeeb #define IWL_MVM_TCM_LOAD_MEDIUM_THRESH		10 /* percentage */
62bfcc09ddSBjoern A. Zeeb #define IWL_MVM_TCM_LOAD_HIGH_THRESH		50 /* percentage */
63bfcc09ddSBjoern A. Zeeb #define IWL_MVM_TCM_LOWLAT_ENABLE_THRESH	100 /* packets/10 seconds */
64bfcc09ddSBjoern A. Zeeb #define IWL_MVM_UAPSD_NONAGG_PERIOD		5000 /* msecs */
65bfcc09ddSBjoern A. Zeeb #define IWL_MVM_UAPSD_NOAGG_LIST_LEN		IWL_MVM_UAPSD_NOAGG_BSSIDS_NUM
66bfcc09ddSBjoern A. Zeeb #define IWL_MVM_NON_TRANSMITTING_AP		0
67*a4128aadSBjoern A. Zeeb #define IWL_MVM_CONN_LISTEN_INTERVAL		10
68bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_NUM_TRY_BEFORE_ANT_TOGGLE    1
69bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_HT_VHT_RETRIES_PER_RATE      2
70bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_HT_VHT_RETRIES_PER_RATE_TW   1
71bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_INITIAL_MIMO_NUM_RATES       3
72bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_INITIAL_SISO_NUM_RATES       3
73bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_INITIAL_LEGACY_NUM_RATES     2
74bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_INITIAL_LEGACY_RETRIES       2
75bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_SECONDARY_LEGACY_RETRIES	1
76bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_SECONDARY_LEGACY_NUM_RATES   16
77bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_SECONDARY_SISO_NUM_RATES     3
78bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_SECONDARY_SISO_RETRIES       1
79bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_RATE_MIN_FAILURE_TH		3
80bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_RATE_MIN_SUCCESS_TH		8
81bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_STAY_IN_COLUMN_TIMEOUT	5	/* Seconds */
82bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_IDLE_TIMEOUT			5	/* Seconds */
83bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_MISSED_RATE_MAX		15
84bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_LEGACY_FAILURE_LIMIT		160
85bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_LEGACY_SUCCESS_LIMIT		480
86bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_LEGACY_TABLE_COUNT		160
87bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_NON_LEGACY_FAILURE_LIMIT	400
88bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_NON_LEGACY_SUCCESS_LIMIT	4500
89bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_NON_LEGACY_TABLE_COUNT	1500
90bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_SR_FORCE_DECREASE		15	/* percent */
91bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_SR_NO_DECREASE		85	/* percent */
92bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_AGG_TIME_LIMIT	        4000    /* 4 msecs. valid 100-8000 */
93bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_AGG_DISABLE_START	        3
94bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_AGG_START_THRESHOLD	        10	/* num frames per second */
95bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_TPC_SR_FORCE_INCREASE	75	/* percent */
96bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_TPC_SR_NO_INCREASE		85	/* percent */
97bfcc09ddSBjoern A. Zeeb #define IWL_MVM_RS_TPC_TX_POWER_STEP		3
98bfcc09ddSBjoern A. Zeeb #define IWL_MVM_ENABLE_EBS			1
99bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_ALGO		IWL_TOF_ALGO_TYPE_MAX_LIKE
100bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_DYNACK		true
101bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_LMR_FEEDBACK_TERMINATE	false
102*a4128aadSBjoern A. Zeeb #define IWL_MVM_FTM_TEST_INCORRECT_SAC	        false
103bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_R2I_MAX_REP			7
104bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_I2R_MAX_REP			7
105bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_R2I_MAX_STS			1
106bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_I2R_MAX_STS			1
107bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_R2I_MAX_TOTAL_LTF		3
108bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_I2R_MAX_TOTAL_LTF		3
109bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_SECURE_LTF	false
110bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_RESP_NDP_SUPPORT		true
111bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_RESP_LMR_FEEDBACK_SUPPORT	true
112bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_NON_TB_MIN_TIME_BETWEEN_MSR	5
113bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_NON_TB_MAX_TIME_BETWEEN_MSR	1000
114bfcc09ddSBjoern A. Zeeb #define IWL_MVM_D3_DEBUG			false
115bfcc09ddSBjoern A. Zeeb #define IWL_MVM_USE_TWT				true
116d9836fb4SBjoern A. Zeeb #define IWL_MVM_AMPDU_CONSEC_DROPS_DELBA	20
117bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_ENABLE_SMOOTH     false
118bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_SMOOTH_ALPHA      40
119bfcc09ddSBjoern A. Zeeb /*  20016 pSec is 6 meter RTT, meaning 3 meter range */
120bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_SMOOTH_UNDERSHOOT 20016
121bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_SMOOTH_OVERSHOOT  20016
122bfcc09ddSBjoern A. Zeeb #define IWL_MVM_FTM_INITIATOR_SMOOTH_AGE_SEC    2
123bfcc09ddSBjoern A. Zeeb #define IWL_MVM_DISABLE_AP_FILS			false
124bfcc09ddSBjoern A. Zeeb #define IWL_MVM_6GHZ_PASSIVE_SCAN_TIMEOUT       3000 /* in seconds */
125bfcc09ddSBjoern A. Zeeb #define IWL_MVM_6GHZ_PASSIVE_SCAN_ASSOC_TIMEOUT 60   /* in seconds */
126*a4128aadSBjoern A. Zeeb #define IWL_MVM_MIN_BEACON_INTERVAL_TU		16
127*a4128aadSBjoern A. Zeeb #define IWL_MVM_AUTO_EML_ENABLE                 true
128*a4128aadSBjoern A. Zeeb #define IWL_MVM_MISSED_BEACONS_EXIT_ESR_THRESH	7
129bfcc09ddSBjoern A. Zeeb 
130*a4128aadSBjoern A. Zeeb #define IWL_MVM_HIGH_RSSI_THRESH_20MHZ		-67
131*a4128aadSBjoern A. Zeeb #define IWL_MVM_LOW_RSSI_THRESH_20MHZ		-71
132*a4128aadSBjoern A. Zeeb #define IWL_MVM_HIGH_RSSI_THRESH_40MHZ		-64
133*a4128aadSBjoern A. Zeeb #define IWL_MVM_LOW_RSSI_THRESH_40MHZ		-67
134*a4128aadSBjoern A. Zeeb #define IWL_MVM_HIGH_RSSI_THRESH_80MHZ		-61
135*a4128aadSBjoern A. Zeeb #define IWL_MVM_LOW_RSSI_THRESH_80MHZ		-74
136*a4128aadSBjoern A. Zeeb #define IWL_MVM_HIGH_RSSI_THRESH_160MHZ		-58
137*a4128aadSBjoern A. Zeeb #define IWL_MVM_LOW_RSSI_THRESH_160MHZ		-61
138*a4128aadSBjoern A. Zeeb 
139*a4128aadSBjoern A. Zeeb #define IWL_MVM_ENTER_ESR_TPT_THRESH		400
140bfcc09ddSBjoern A. Zeeb #endif /* __MVM_CONSTANTS_H */
141