1  /*
2   * Copyright (c) 2012-2021 The Linux Foundation. All rights reserved.
3   * Copyright (c) 2021-2024 Qualcomm Innovation Center, Inc. All rights reserved.
4   *
5   * Permission to use, copy, modify, and/or distribute this software for
6   * any purpose with or without fee is hereby granted, provided that the
7   * above copyright notice and this permission notice appear in all
8   * copies.
9   *
10   * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11   * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12   * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13   * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
14   * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
15   * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
16   * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17   * PERFORMANCE OF THIS SOFTWARE.
18   */
19  
20  #ifndef WLAN_QCT_WLANSAP_INTERNAL_H
21  #define WLAN_QCT_WLANSAP_INTERNAL_H
22  
23  /*
24   * This file contains the internal API exposed by the wlan SAP PAL layer
25   * module.
26   */
27  
28  #include "cds_api.h"
29  #include "cds_packet.h"
30  
31  /* Pick up the CSR API definitions */
32  #include "csr_api.h"
33  #include "sap_api.h"
34  #include "sap_fsm_ext.h"
35  #include "sap_ch_select.h"
36  #include <wlan_scan_public_structs.h>
37  #include <wlan_objmgr_pdev_obj.h>
38  #include "wlan_vdev_mlme_main.h"
39  #include "wlan_vdev_mlme_api.h"
40  
41  /* DFS Non Occupancy Period =30 minutes, in microseconds */
42  #define SAP_DFS_NON_OCCUPANCY_PERIOD      (30 * 60 * 1000 * 1000)
43  
44  #define SAP_DEBUG
45  
46  #define IS_ETSI_WEATHER_FREQ(_freq)   ((_freq >= 5600) && (_freq <= 5650))
47  #define IS_CH_BONDING_WITH_WEATHER_CH(_ch)   (_ch == 116)
48  #define IS_CHAN_JAPAN_INDOOR(_ch) ((_ch >= 36)  && (_ch <= 64))
49  #define IS_CHAN_JAPAN_OUTDOOR(_ch)((_ch >= 100) && (_ch <= 140))
50  #define DEFAULT_CAC_TIMEOUT (60 * 1000) /* msecs - 1 min */
51  #define ETSI_WEATHER_CH_CAC_TIMEOUT (10 * 60 * 1000)    /* msecs - 10 min */
52  #define SAP_CHAN_PREFERRED_INDOOR  1
53  #define SAP_CHAN_PREFERRED_OUTDOOR 2
54  
55  /*SAP Specific logging*/
56  
57  #define sap_alert(params...) QDF_TRACE_FATAL(QDF_MODULE_ID_SAP, params)
58  #define sap_err(params...) QDF_TRACE_ERROR(QDF_MODULE_ID_SAP, params)
59  #define sap_warn(params...) QDF_TRACE_WARN(QDF_MODULE_ID_SAP, params)
60  #define sap_info(params...) QDF_TRACE_INFO(QDF_MODULE_ID_SAP, params)
61  #define sap_debug(params...) QDF_TRACE_DEBUG(QDF_MODULE_ID_SAP, params)
62  
63  #define sap_nofl_alert(params...) \
64  	QDF_TRACE_FATAL_NO_FL(QDF_MODULE_ID_SAP, params)
65  #define sap_nofl_err(params...) \
66  	QDF_TRACE_ERROR_NO_FL(QDF_MODULE_ID_SAP, params)
67  #define sap_nofl_warn(params...) \
68  	QDF_TRACE_WARN_NO_FL(QDF_MODULE_ID_SAP, params)
69  #define sap_nofl_info(params...) \
70  	QDF_TRACE_INFO_NO_FL(QDF_MODULE_ID_SAP, params)
71  #define sap_nofl_debug(params...) \
72  	QDF_TRACE_DEBUG_NO_FL(QDF_MODULE_ID_SAP, params)
73  
74  #define sap_alert_rl(params...) QDF_TRACE_FATAL_RL(QDF_MODULE_ID_SAP, params)
75  #define sap_err_rl(params...) QDF_TRACE_ERROR_RL(QDF_MODULE_ID_SAP, params)
76  #define sap_warn_rl(params...) QDF_TRACE_WARN_RL(QDF_MODULE_ID_SAP, params)
77  #define sap_info_rl(params...) QDF_TRACE_INFO_RL(QDF_MODULE_ID_SAP, params)
78  #define sap_debug_rl(params...) QDF_TRACE_DEBUG_RL(QDF_MODULE_ID_SAP, params)
79  
80  /*----------------------------------------------------------------------------
81   *  Typedefs
82   * -------------------------------------------------------------------------*/
83  /*----------------------------------------------------------------------------
84   *  Type Declarations - For internal SAP context information
85   * -------------------------------------------------------------------------*/
86  /*----------------------------------------------------------------------------
87   *  Opaque SAP context Type Declaration
88   * -------------------------------------------------------------------------*/
89  /* We were only using this syntax, when this was truly opaque. */
90  /* (I.E., it was defined in a different file.) */
91  
92  /**
93   * enum sap_fsm_state - SAP FSM states for Access Point role
94   * @SAP_INIT: init state
95   * @SAP_STARTING: starting phase
96   * @SAP_STARTED: up and running
97   * @SAP_STOPPING: about to stop and transitions to init
98   */
99  enum sap_fsm_state {
100  	SAP_INIT,
101  	SAP_STARTING,
102  	SAP_STARTED,
103  	SAP_STOPPING
104  };
105  
106  #ifdef FEATURE_AP_MCC_CH_AVOIDANCE
107  /*
108   * In a setup having two MDM both operating in AP+AP MCC scenario
109   * if both the AP decides to use same or close channel set, CTS to
110   * self, mechanism is causing issues with connectivity. For this, its
111   * proposed that 2nd MDM devices which comes up later should detect
112   * presence of first MDM device via special Q2Q IE present in becon
113   * and avoid those channels mentioned in IE.
114   *
115   * Following struct will keep this info in sapCtx struct, and will be used
116   * to avoid such channels in Random Channel Select in case of radar ind.
117   */
118  struct sap_avoid_channels_info {
119  	bool       present;
120  	uint8_t    channels[CFG_VALID_CHANNEL_LIST_LEN];
121  };
122  #endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
123  
124  #define MAX_VLAN 4
125  struct sap_context {
126  
127  	/* Include the current channel frequency of AP */
128  	uint32_t chan_freq;
129  	uint32_t sec_ch_freq;
130  
131  #ifdef DCS_INTERFERENCE_DETECTION
132  	qdf_freq_t dcs_ch_freq;
133  #endif
134  	union {
135  		uint8_t sessionId;
136  		uint8_t vdev_id;
137  	};
138  	uint8_t sap_radar_found_status;
139  
140  	/* vdev object corresponding to sessionId */
141  	struct wlan_objmgr_vdev *vdev;
142  
143  	/* Include the associations MAC addresses */
144  	uint8_t self_mac_addr[CDS_MAC_ADDRESS_LEN];
145  	struct start_bss_config sap_bss_cfg;
146  
147  	/* SAP event Callback to hdd */
148  	sap_event_cb sap_event_cb;
149  
150  	/*
151  	 * Include the state machine structure here, state var that keeps
152  	 * track of state machine
153  	 */
154  	enum sap_fsm_state fsm_state;
155  	enum sap_csa_reason_code csa_reason;
156  
157  	/* Actual storage for AP and self (STA) SSID */
158  	tCsrSSIDInfo SSIDList[2];
159  
160  	/* Actual storage for AP bssid */
161  	struct qdf_mac_addr bssid;
162  
163  	/* Mac filtering settings */
164  	eSapMacAddrACL eSapMacAddrAclMode;
165  	struct qdf_mac_addr acceptMacList[MAX_ACL_MAC_ADDRESS];
166  	uint16_t nAcceptMac;
167  	struct qdf_mac_addr denyMacList[MAX_ACL_MAC_ADDRESS];
168  	uint16_t nDenyMac;
169  
170  	void *user_context;
171  
172  	uint32_t nStaWPARSnReqIeLength;
173  	uint8_t pStaWpaRsnReqIE[MAX_ASSOC_IND_IE_LEN];
174  
175  	eCsrPhyMode phyMode;
176  	uint32_t *freq_list;
177  	uint8_t num_of_channel;
178  	uint16_t ch_width_orig;
179  	struct ch_params ch_params;
180  	uint32_t chan_freq_before_switch_band;
181  	enum phy_ch_width chan_width_before_switch_band;
182  	uint32_t auto_channel_select_weight;
183  	bool enableOverLapCh;
184  	struct sap_acs_cfg *acs_cfg;
185  
186  	qdf_time_t acs_req_timestamp;
187  
188  #ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
189  	uint8_t cc_switch_mode;
190  #endif
191  
192  #if defined(FEATURE_WLAN_STA_AP_MODE_DFS_DISABLE)
193  	bool dfs_ch_disable;
194  #endif
195  	bool isCacEndNotified;
196  	bool isCacStartNotified;
197  	bool is_sap_ready_for_chnl_chng;
198  #ifdef FEATURE_RADAR_HISTORY
199  	struct prev_cac_result cac_result;
200  #endif
201  #ifdef FEATURE_AP_MCC_CH_AVOIDANCE
202  	/*
203  	 * In a setup having two MDM both operating in AP+AP MCC scenario
204  	 * if both the AP decides to use same or close channel set, CTS to
205  	 * self, mechanism is causing issues with connectivity. For this, its
206  	 * proposed that 2nd MDM devices which comes up later should detect
207  	 * presence of first MDM device via special Q2Q IE present in becon
208  	 * and avoid those channels mentioned in IE.
209  	 *
210  	 * this struct contains the list of channels on which another MDM AP
211  	 * in MCC mode were detected.
212  	 */
213  	struct sap_avoid_channels_info sap_detected_avoid_ch_ie;
214  #endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
215  	/*
216  	 * sap_state, sap_status are created
217  	 * to inform upper layers about ACS scan status.
218  	 * Don't use these members for any other purposes.
219  	 */
220  	eSapHddEvent sap_state;
221  	eSapStatus sap_status;
222  	uint32_t roc_ind_scan_id;
223  	bool vendor_acs_dfs_lte_enabled;
224  	uint8_t dfs_vendor_channel;
225  	uint8_t dfs_vendor_chan_bw;
226  	uint16_t beacon_tx_rate;
227  	enum sap_acs_dfs_mode dfs_mode;
228  	wlan_scan_requester req_id;
229  	uint8_t sap_sta_id;
230  	bool dfs_cac_offload;
231  	bool is_chan_change_inprogress;
232  	/* Disabled mcs13 by sap or not */
233  	bool disabled_mcs13;
234  	qdf_list_t owe_pending_assoc_ind_list;
235  	qdf_list_t ft_pending_assoc_ind_list;
236  	qdf_event_t ft_pending_event;
237  	uint32_t freq_before_ch_switch;
238  	struct ch_params ch_params_before_ch_switch;
239  #ifdef WLAN_FEATURE_P2P_P2P_STA
240  /*
241   *This param is used for GO+GO force scc logic where after
242   *setkey first GO will move to latest GO's channel
243   */
244  	bool is_forcescc_restart_required;
245  #endif
246  	qdf_freq_t candidate_freq;
247  #ifdef FEATURE_WLAN_CH_AVOID_EXT
248  	uint32_t restriction_mask;
249  #endif
250  	bool require_h2e;
251  	bool partial_acs_scan;
252  	bool optimize_acs_chan_selected;
253  #ifdef WLAN_FEATURE_SAP_ACS_OPTIMIZE
254  /*
255   * This param is used to track clean channels where there
256   * is no AP found on these channels
257   */
258  	bool clean_channel_array[NUM_CHANNELS];
259  #endif
260  #ifdef QCA_MULTIPASS_SUPPORT
261  	uint16_t vlan_map[2 * MAX_VLAN];
262  #endif
263  };
264  
265  /*----------------------------------------------------------------------------
266   *  External declarations for global context
267   * -------------------------------------------------------------------------*/
268  
269  /**
270   * struct sap_sm_event - SAP state machine event definition
271   * @params: A VOID pointer type for all possible inputs
272   * @event: State machine input event message
273   * @u1: Introduced to handle csr_roam_complete_cb roamStatus
274   * @u2: Introduced to handle csr_roam_complete_cb roamResult
275   */
276  struct sap_sm_event {
277  	void *params;
278  	uint32_t event;
279  	uint32_t u1;
280  	uint32_t u2;
281  };
282  
283  /*----------------------------------------------------------------------------
284   * Function Declarations and Documentation
285   * -------------------------------------------------------------------------*/
286  
287  /**
288   * sap_get_mac_context() - Get a pointer to the global MAC context
289   *
290   * Return: pointer to the global MAC context, or NULL if the MAC
291   *         context is no longer registered
292   */
sap_get_mac_context(void)293  static inline struct mac_context *sap_get_mac_context(void)
294  {
295  	return cds_get_context(QDF_MODULE_ID_PE);
296  }
297  
298  QDF_STATUS wlansap_context_get(struct sap_context *ctx);
299  void wlansap_context_put(struct sap_context *ctx);
300  
301  /**
302   * wlansap_pre_start_bss_acs_scan_callback() - callback for scan results
303   * @mac_handle:    the mac_handle passed in with the scan request
304   * @sap_ctx:       the SAP context pointer.
305   * @scanid:        scan id passed
306   * @sessionid:     session identifier
307   * @scan_status:        status of scan -success, failure or abort
308   *
309   * Api for scan callback. This function is invoked as a result of scan
310   * completion and reports the scan results.
311   *
312   * Return: The QDF_STATUS code associated with performing the operation
313   */
314  QDF_STATUS wlansap_pre_start_bss_acs_scan_callback(mac_handle_t mac_handle,
315  						   struct sap_context *sap_ctx,
316  						   uint8_t sessionid,
317  						   uint32_t scanid,
318  						   eCsrScanStatus scan_status);
319  
320  /**
321   * sap_chan_sel_exit() - Exit function for free out the allocated memory,
322   * @ch_info_params: Pointer to sap_sel_ch_info structure
323   *
324   * Return: None
325   */
326  void sap_chan_sel_exit(struct sap_sel_ch_info *ch_info_params);
327  
328  /**
329   * sap_sort_channel_list() - Sort channel list based on channel weight
330   * @mac_ctx: Pointer to mac_context
331   * @vdev_id: Vdev ID
332   * @ch_list: Pointer to qdf_list_t
333   * @ch_info: Pointer to sap_sel_ch_info structure
334   * @domain: Regulatory Domain
335   * @operating_band: Operating band
336   *
337   * Return: None
338   *
339   */
340  void
341  sap_sort_channel_list(struct mac_context *mac_ctx, uint8_t vdev_id,
342  		      qdf_list_t *ch_list, struct sap_sel_ch_info *ch_info,
343  		      v_REGDOMAIN_t *domain, uint32_t *operating_band);
344  
345  /**
346   * sap_select_channel() - select SAP channel
347   * @mac_handle: Opaque handle to the global MAC context
348   * @sap_ctx: Sap context
349   * @scan_list: scan entry list
350   *
351   * Runs a algorithm to select the best channel to operate in based on BSS
352   * rssi and bss count on each channel
353   *
354   * Returns: channel frequency if success, 0 otherwise
355   */
356  uint32_t sap_select_channel(mac_handle_t mac_handle, struct sap_context *sap_ctx,
357  			   qdf_list_t *scan_list);
358  
359  QDF_STATUS
360  sap_signal_hdd_event(struct sap_context *sap_ctx,
361  		  struct csr_roam_info *pCsrRoamInfo,
362  		  eSapHddEvent sapHddevent, void *);
363  
364  QDF_STATUS sap_fsm(struct sap_context *sap_ctx, struct sap_sm_event *sap_event);
365  
366  QDF_STATUS
367  sap_is_peer_mac_allowed(struct sap_context *sap_ctx, uint8_t *peerMac);
368  
369  void
370  sap_sort_mac_list(struct qdf_mac_addr *macList, uint16_t size);
371  
372  void
373  sap_add_mac_to_acl(struct qdf_mac_addr *macList, uint16_t *size,
374  		   uint8_t *peerMac);
375  
376  void
377  sap_remove_mac_from_acl(struct qdf_mac_addr *macList, uint16_t *size,
378  			uint16_t index);
379  
380  void
381  sap_print_acl(struct qdf_mac_addr *macList, uint16_t size);
382  
383  bool
384  sap_search_mac_list(struct qdf_mac_addr *macList, uint16_t num_mac,
385  		    uint8_t *peerMac, uint16_t *index);
386  
387  QDF_STATUS sap_init_dfs_channel_nol_list(struct sap_context *sap_ctx);
388  
389  bool sap_dfs_is_channel_in_nol_list(struct sap_context *sap_ctx,
390  				    qdf_freq_t chan_freq,
391  				    ePhyChanBondState chanBondState);
392  void sap_dfs_cac_timer_callback(void *data);
393  
394  /**
395   * sap_cac_reset_notify() - BSS cleanup notification handler
396   * @mac_handle: Opaque handle to the global MAC context
397   *
398   * This function should be called upon stop bss indication to clean up
399   * DFS global structure.
400   */
401  void sap_cac_reset_notify(mac_handle_t mac_handle);
402  
403  bool is_concurrent_sap_ready_for_channel_change(mac_handle_t mac_handle,
404  						struct sap_context *sap_ctx);
405  
406  bool sap_is_conc_sap_doing_scc_dfs(mac_handle_t mac_handle,
407  				   struct sap_context *given_sapctx);
408  
409  uint8_t sap_get_total_number_sap_intf(mac_handle_t mac_handle);
410  
411  /**
412   * sap_channel_sel - Function for initiating scan request for ACS
413   * @sap_context: Sap Context value.
414   *
415   * Initiates Scan for ACS to pick a channel.
416   *
417   * Return: The QDF_STATUS code associated with performing the operation.
418   */
419  QDF_STATUS sap_channel_sel(struct sap_context *sap_context);
420  
421  /**
422   * sap_validate_chan - Function validate the channel and forces SCC
423   * @sap_context: Sap Context value.
424   * @pre_start_bss: if its called pre start BSS with valid channel.
425   * @check_for_connection_update: true, check and wait for connection update
426   *				 false, do not perform connection update
427   *
428   * validate and update the channel in case of force SCC.
429   *
430   * Return: The QDF_STATUS code associated with performing the operation.
431   */
432  QDF_STATUS
433  sap_validate_chan(struct sap_context *sap_context,
434  		  bool pre_start_bss,
435  		  bool check_for_connection_update);
436  
437  /**
438   * sap_check_in_avoid_ch_list() - checks if given channel present is channel
439   * avoidance list
440   * avoid_channels_info struct
441   * @sap_ctx:        sap context.
442   * @channel:        channel to be checked in sap_ctx's avoid ch list
443   *
444   * sap_ctx contains sap_avoid_ch_info strcut containing the list of channels on
445   * which MDM device's AP with MCC was detected. This function checks if given
446   * channel is present in that list.
447   *
448   * Return: true, if channel was present, false othersie.
449   */
450  bool
451  sap_check_in_avoid_ch_list(struct sap_context *sap_ctx, uint8_t channel);
452  
453  /**
454   * sap_set_session_param() - set sap related param to sap context and global var
455   * @mac_handle: Opaque handle to the global MAC context
456   * @sapctx: pointer to sapctx
457   * @session_id: session id for sap
458   *
459   * This API will set appropriate softap parameters to sap context
460   *
461   * Return: QDF_STATUS
462   */
463  QDF_STATUS sap_set_session_param(mac_handle_t mac_handle,
464  				 struct sap_context *sapctx,
465  				 uint32_t session_id);
466  
467  /**
468   * sap_clear_session_param() - clear sap related param from sap context
469   * @mac_handle: Opaque handle to the global MAC context
470   * @sapctx: pointer to sapctx
471   * @session_id: session id for sap
472   *
473   * This API will clear appropriate softap parameters from sap context
474   *
475   * Return: QDF_STATUS
476   */
477  QDF_STATUS sap_clear_session_param(mac_handle_t mac_handle,
478  				   struct sap_context *sapctx,
479  				   uint32_t session_id);
480  
481  void sap_scan_event_callback(struct wlan_objmgr_vdev *vdev,
482  			struct scan_event *event, void *arg);
483  
484  #ifdef DFS_COMPONENT_ENABLE
485  /**
486   * sap_indicate_radar() - Process radar indication
487   * @sap_ctx: pointer to sap context
488   *
489   * process radar indication.
490   *
491   * Return: frequency to which sap wishes to switch.
492   */
493  qdf_freq_t sap_indicate_radar(struct sap_context *sap_ctx);
494  #else
sap_indicate_radar(struct sap_context * sap_ctx)495  static inline qdf_freq_t sap_indicate_radar(struct sap_context *sap_ctx)
496  {
497  	return 0;
498  }
499  #endif
500  
501  /**
502   * sap_select_default_oper_chan() - Select AP mode default operating channel
503   * @mac_ctx: mac context
504   * @acs_cfg: pointer to ACS config info
505   *
506   * Select AP mode default operating channel based on ACS hw mode and channel
507   * range configuration when ACS scan fails due to some reasons, such as scan
508   * timeout, etc.
509   *
510   * Return: Selected operating channel frequency
511   */
512  uint32_t sap_select_default_oper_chan(struct mac_context *mac_ctx,
513  				      struct sap_acs_cfg *acs_cfg);
514  
515  /*
516   * sap_is_dfs_cac_wait_state() - check if sap is in cac wait state
517   * @sap_ctx: sap context to check
518   *
519   * Return: true if sap is in cac wait state
520   */
521  bool sap_is_dfs_cac_wait_state(struct sap_context *sap_ctx);
522  
523  /**
524   * sap_chan_bond_dfs_sub_chan - check bonded channel includes dfs sub chan
525   * @sap_context: Handle to SAP context.
526   * @channel_freq: chan whose bonded chan will be checked
527   * @bond_state: The channel bonding mode of the passed channel.
528   *
529   * This function checks if a given bonded channel includes dfs sub chan.
530   *
531   * Return: true if at least one dfs sub chan is bonded, otherwise false
532   */
533  bool
534  sap_chan_bond_dfs_sub_chan(struct sap_context *sap_context,
535  			   qdf_freq_t channel_freq,
536  			   ePhyChanBondState bond_state);
537  
538  /**
539   * sap_plus_sap_cac_skip() - Check current sap can skip CAC or not
540   *  in SAP+SAP concurrency
541   * @mac: mac ctx
542   * @sap_ctx: SAP context
543   * @chan_freq: SAP channel frequency
544   *
545   * All APs are done with CAC timer, all APs should start beaconing.
546   * Lets assume AP1 and AP2 started beaconing on DFS channel, Now lets
547   * say AP1 goes down and comes back on same DFS channel. In this case
548   * AP1 shouldn't start CAC timer and start beacon immediately because
549   * AP2 is already beaconing on this channel. This case will be handled
550   * by checking CAC completion on AP2.
551   *
552   * Return: true if current SAP can skip CAC
553   */
554  bool sap_plus_sap_cac_skip(struct mac_context *mac,
555  			   struct sap_context *sap_ctx,
556  			   qdf_freq_t chan_freq);
557  
558  void
559  sap_build_start_bss_config(struct start_bss_config *sap_bss_cfg,
560  			   struct sap_config *config);
561  #endif
562