diff options
Diffstat (limited to 'sys/contrib/dev/rtw89/chan.h')
| -rw-r--r-- | sys/contrib/dev/rtw89/chan.h | 92 | 
1 files changed, 88 insertions, 4 deletions
| diff --git a/sys/contrib/dev/rtw89/chan.h b/sys/contrib/dev/rtw89/chan.h index 092a6f676894..b1175419f92b 100644 --- a/sys/contrib/dev/rtw89/chan.h +++ b/sys/contrib/dev/rtw89/chan.h @@ -18,6 +18,12 @@  #define RTW89_MCC_EARLY_RX_BCN_TIME 5  #define RTW89_MCC_MIN_RX_BCN_TIME 10  #define RTW89_MCC_DFLT_BCN_OFST_TIME 40 +#define RTW89_MCC_SWITCH_CH_TIME 3 + +#define RTW89_MCC_PROBE_TIMEOUT 100 +#define RTW89_MCC_PROBE_MAX_TRIES 3 + +#define RTW89_MCC_DETECT_BCN_MAX_TRIES 2  #define RTW89_MCC_MIN_GO_DURATION \  	(RTW89_MCC_EARLY_TX_BCN_TIME + RTW89_MCC_MIN_RX_BCN_TIME) @@ -25,17 +31,77 @@  #define RTW89_MCC_MIN_STA_DURATION \  	(RTW89_MCC_EARLY_RX_BCN_TIME + RTW89_MCC_MIN_RX_BCN_TIME) +#define RTW89_MCC_MIN_RX_BCN_WITH_SWITCH_CH_TIME \ +	(RTW89_MCC_MIN_RX_BCN_TIME + RTW89_MCC_SWITCH_CH_TIME) +  #define RTW89_MCC_DFLT_GROUP 0  #define RTW89_MCC_NEXT_GROUP(cur) (((cur) + 1) % 4) -#define RTW89_MCC_DFLT_TX_NULL_EARLY 3 +#define RTW89_MCC_DFLT_TX_NULL_EARLY 7  #define RTW89_MCC_DFLT_COURTESY_SLOT 3 +#define RTW89_MCC_REQ_COURTESY_TIME 5 +#define RTW89_MCC_REQ_COURTESY(pattern, role)			\ +({								\ +	const struct rtw89_mcc_pattern *p = pattern;		\ +	p->tob_ ## role <= RTW89_MCC_REQ_COURTESY_TIME ||	\ +	p->toa_ ## role <= RTW89_MCC_REQ_COURTESY_TIME;		\ +}) +  #define NUM_OF_RTW89_MCC_ROLES 2 +enum rtw89_mr_wtype { +	RTW89_MR_WTYPE_NONE, +	RTW89_MR_WTYPE_NONMLD, +	RTW89_MR_WTYPE_MLD1L1R, +	RTW89_MR_WTYPE_MLD2L1R, +	RTW89_MR_WTYPE_MLD2L2R, +	RTW89_MR_WTYPE_NONMLD_NONMLD, +	RTW89_MR_WTYPE_MLD1L1R_NONMLD, +	RTW89_MR_WTYPE_MLD2L1R_NONMLD, +	RTW89_MR_WTYPE_MLD2L2R_NONMLD, +	RTW89_MR_WTYPE_UNKNOWN, +}; + +enum rtw89_mr_wmode { +	RTW89_MR_WMODE_NONE, +	RTW89_MR_WMODE_1CLIENT, +	RTW89_MR_WMODE_1AP, +	RTW89_MR_WMODE_1AP_1CLIENT, +	RTW89_MR_WMODE_2CLIENTS, +	RTW89_MR_WMODE_2APS, +	RTW89_MR_WMODE_UNKNOWN, +}; + +enum rtw89_mr_ctxtype { +	RTW89_MR_CTX_NONE, +	RTW89_MR_CTX1_2GHZ, +	RTW89_MR_CTX1_5GHZ, +	RTW89_MR_CTX1_6GHZ, +	RTW89_MR_CTX2_2GHZ, +	RTW89_MR_CTX2_5GHZ, +	RTW89_MR_CTX2_6GHZ, +	RTW89_MR_CTX2_2GHZ_5GHZ, +	RTW89_MR_CTX2_2GHZ_6GHZ, +	RTW89_MR_CTX2_5GHZ_6GHZ, +	RTW89_MR_CTX_UNKNOWN, +}; + +struct rtw89_mr_chanctx_info { +	enum rtw89_mr_wtype wtype; +	enum rtw89_mr_wmode wmode; +	enum rtw89_mr_ctxtype ctxtype; +}; +  enum rtw89_chanctx_pause_reasons {  	RTW89_CHANCTX_PAUSE_REASON_HW_SCAN,  	RTW89_CHANCTX_PAUSE_REASON_ROC, +	RTW89_CHANCTX_PAUSE_REASON_GC_BCN_LOSS, +}; + +struct rtw89_chanctx_pause_parm { +	const struct rtw89_vif_link *trigger; +	enum rtw89_chanctx_pause_reasons rsn;  };  struct rtw89_chanctx_cb_parm { @@ -45,6 +111,7 @@ struct rtw89_chanctx_cb_parm {  };  struct rtw89_entity_weight { +	unsigned int registered_chanctxs;  	unsigned int active_chanctxs;  	unsigned int active_roles;  }; @@ -95,17 +162,19 @@ void rtw89_config_entity_chandef(struct rtw89_dev *rtwdev,  				 enum rtw89_chanctx_idx idx,  				 const struct cfg80211_chan_def *chandef);  void rtw89_config_roc_chandef(struct rtw89_dev *rtwdev, -			      enum rtw89_chanctx_idx idx, +			      struct rtw89_vif_link *rtwvif_link,  			      const struct cfg80211_chan_def *chandef);  void rtw89_entity_init(struct rtw89_dev *rtwdev);  enum rtw89_entity_mode rtw89_entity_recalc(struct rtw89_dev *rtwdev); -void rtw89_chanctx_work(struct work_struct *work); +void rtw89_chanctx_work(struct wiphy *wiphy, struct wiphy_work *work);  void rtw89_queue_chanctx_work(struct rtw89_dev *rtwdev);  void rtw89_queue_chanctx_change(struct rtw89_dev *rtwdev,  				enum rtw89_chanctx_changes change); +void rtw89_query_mr_chanctx_info(struct rtw89_dev *rtwdev, u8 inst_idx, +				 struct rtw89_mr_chanctx_info *info);  void rtw89_chanctx_track(struct rtw89_dev *rtwdev);  void rtw89_chanctx_pause(struct rtw89_dev *rtwdev, -			 enum rtw89_chanctx_pause_reasons rsn); +			 const struct rtw89_chanctx_pause_parm *parm);  void rtw89_chanctx_proceed(struct rtw89_dev *rtwdev,  			   const struct rtw89_chanctx_cb_parm *cb_parm); @@ -116,6 +185,16 @@ const struct rtw89_chan *__rtw89_mgnt_chan_get(struct rtw89_dev *rtwdev,  #define rtw89_mgnt_chan_get(rtwdev, link_index) \  	__rtw89_mgnt_chan_get(rtwdev, __func__, link_index) +struct rtw89_mcc_links_info { +	struct rtw89_vif_link *links[NUM_OF_RTW89_MCC_ROLES]; +}; + +void rtw89_mcc_get_links(struct rtw89_dev *rtwdev, struct rtw89_mcc_links_info *info); +void rtw89_mcc_prepare_done_work(struct wiphy *wiphy, struct wiphy_work *work); +void rtw89_mcc_gc_detect_beacon_work(struct wiphy *wiphy, struct wiphy_work *work); +bool rtw89_mcc_detect_go_bcn(struct rtw89_dev *rtwdev, +			     struct rtw89_vif_link *rtwvif_link); +  int rtw89_chanctx_ops_add(struct rtw89_dev *rtwdev,  			  struct ieee80211_chanctx_conf *ctx);  void rtw89_chanctx_ops_remove(struct rtw89_dev *rtwdev, @@ -129,5 +208,10 @@ int rtw89_chanctx_ops_assign_vif(struct rtw89_dev *rtwdev,  void rtw89_chanctx_ops_unassign_vif(struct rtw89_dev *rtwdev,  				    struct rtw89_vif_link *rtwvif_link,  				    struct ieee80211_chanctx_conf *ctx); +int rtw89_chanctx_ops_reassign_vif(struct rtw89_dev *rtwdev, +				   struct rtw89_vif_link *rtwvif_link, +				   struct ieee80211_chanctx_conf *old_ctx, +				   struct ieee80211_chanctx_conf *new_ctx, +				   bool replace);  #endif | 
