1 /*
2 * Copyright (c) 2019-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 any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 */
17
18 /**
19 * DOC: Define Common MLME structure and APIs
20 */
21 #ifndef _WLAN_MLME_CMN_H_
22 #define _WLAN_MLME_CMN_H_
23
24 #include <include/wlan_psoc_mlme.h>
25 #include <include/wlan_pdev_mlme.h>
26 #include <include/wlan_vdev_mlme.h>
27 #include "wlan_cm_public_struct.h"
28 #ifdef WLAN_FEATURE_ROAM_OFFLOAD
29 #include "wlan_cm_roam_public_struct.h"
30 #endif
31 #include "wlan_twt_public_structs.h"
32
33 /**
34 * struct mlme_cm_ops: connection manager osif callbacks
35 * @mlme_cm_connect_active_notify_cb: Connect active notify callback
36 * @mlme_cm_connect_complete_cb: Connect done callback
37 * @vdev: vdev pointer
38 * @rsp: connect response
39 *
40 * @mlme_cm_failed_candidate_cb: Callback to indicate failed candidate
41 * @vdev: vdev pointer
42 * @rsp: connect response
43 *
44 * @mlme_cm_update_id_and_src_cb: Callback to update connect id and
45 * source of the connect request
46 * @vdev: vdev pointer
47 * @Source: Source of the connect req
48 * @cm_id: connection manager id
49 *
50 * @mlme_cm_disconnect_complete_cb: Disconnect done callback
51 * @vdev: vdev pointer
52 * @rsp: Disconnect response
53 *
54 * @mlme_cm_disconnect_start_cb: Disconnect start callback
55 * @vdev: vdev pointer
56 *
57 * @mlme_cm_roam_sync_cb: Roam sync callback
58 * @vdev: vdev pointer
59 *
60 * @mlme_cm_pmksa_candidate_notify_cb: Roam pmksa candidate notify callback
61 * @vdev: vdev pointer
62 * @bssid: bssid
63 * @index: index
64 * @preauth: preauth flag
65 *
66 * @mlme_cm_send_keys_cb:
67 * @vdev: vdev pointer
68 * @key_index: key index
69 * @pairwise: true if a pairwise key
70 * @cipher_type: key cipher type
71 *
72 * @mlme_cm_link_reconfig_notify_cb:
73 * @vdev: vdev object
74 *
75 * @mlme_cm_roam_start_cb: Roam start callback
76 * @vdev: vdev pointer
77 *
78 * @mlme_cm_roam_abort_cb: Roam abort callback
79 * @vdev: vdev pointer
80 *
81 * @mlme_cm_roam_cmpl_cb: Roam sync complete cb
82 * @vdev: vdev pointer
83 *
84 * @mlme_cm_roam_get_scan_ie_cb: Get scan ie cb
85 * @vdev: vdev pointer
86 * @scan_ie: scan ie element pointer
87 * @dot11mode_filter: dot11mode filter enumn pointer
88 *
89 * @mlme_cm_roam_rt_stats_cb: Roam stats cb
90 * @roam_stats_event: roam_stats_event pointer
91 * @idx: TLV idx for roam_stats_event
92 *
93 * @mlme_cm_ft_preauth_cmpl_cb: Roam ft preauth complete cb
94 * @vdev: vdev pointer
95 * @rsp: preauth response pointer
96 *
97 * @mlme_cm_cckm_preauth_cmpl_cb: Roam cckm preauth complete cb
98 * @vdev: vdev pointer
99 * @rsp: preauth response pointer
100 *
101 * @mlme_cm_get_vendor_handoff_params_cb: get vendor handoff params cb
102 * @psoc: psoc pointer
103 * @rsp: vendor handoff response pointer
104 * @vendor_handoff_context: vendor handoff context
105 *
106 * @mlme_cm_perfd_reset_cpufreq_ctrl_cb: callback to reset CPU min freq
107 */
108 struct mlme_cm_ops {
109 void (*mlme_cm_connect_active_notify_cb)(uint8_t vdev_id);
110 QDF_STATUS (*mlme_cm_connect_complete_cb)(
111 struct wlan_objmgr_vdev *vdev,
112 struct wlan_cm_connect_resp *rsp);
113 QDF_STATUS (*mlme_cm_failed_candidate_cb)(
114 struct wlan_objmgr_vdev *vdev,
115 struct wlan_cm_connect_resp *rsp);
116 QDF_STATUS (*mlme_cm_update_id_and_src_cb)(
117 struct wlan_objmgr_vdev *vdev,
118 enum wlan_cm_source source,
119 wlan_cm_id cm_id);
120 QDF_STATUS (*mlme_cm_disconnect_complete_cb)(
121 struct wlan_objmgr_vdev *vdev,
122 struct wlan_cm_discon_rsp *rsp);
123 QDF_STATUS (*mlme_cm_disconnect_start_cb)(
124 struct wlan_objmgr_vdev *vdev,
125 enum wlan_cm_source source);
126 #ifdef CONN_MGR_ADV_FEATURE
127 QDF_STATUS (*mlme_cm_roam_sync_cb)(struct wlan_objmgr_vdev *vdev);
128 QDF_STATUS (*mlme_cm_pmksa_candidate_notify_cb)(
129 struct wlan_objmgr_vdev *vdev,
130 struct qdf_mac_addr *bssid,
131 int index, bool preauth);
132 QDF_STATUS (*mlme_cm_send_keys_cb)(struct wlan_objmgr_vdev *vdev,
133 uint8_t key_index, bool pairwise,
134 enum wlan_crypto_cipher_type cipher_type);
135 QDF_STATUS (*mlme_cm_link_reconfig_notify_cb)(
136 struct wlan_objmgr_vdev *vdev);
137 #endif
138 #ifdef WLAN_FEATURE_ROAM_OFFLOAD
139 QDF_STATUS (*mlme_cm_roam_start_cb)(struct wlan_objmgr_vdev *vdev);
140 QDF_STATUS (*mlme_cm_roam_abort_cb)(struct wlan_objmgr_vdev *vdev);
141 QDF_STATUS (*mlme_cm_roam_cmpl_cb)(struct wlan_objmgr_vdev *vdev);
142 QDF_STATUS (*mlme_cm_roam_get_scan_ie_cb)(struct wlan_objmgr_vdev *vdev,
143 struct element_info *scan_ie,
144 enum dot11_mode_filter *dot11mode_filter);
145 void (*mlme_cm_roam_rt_stats_cb)(struct roam_stats_event *roam_stats,
146 uint8_t idx);
147 #endif
148 #ifdef WLAN_FEATURE_PREAUTH_ENABLE
149 QDF_STATUS (*mlme_cm_ft_preauth_cmpl_cb)(
150 struct wlan_objmgr_vdev *vdev,
151 struct wlan_preauth_rsp *rsp);
152 #ifdef FEATURE_WLAN_ESE
153 QDF_STATUS (*mlme_cm_cckm_preauth_cmpl_cb)(
154 struct wlan_objmgr_vdev *vdev,
155 struct wlan_preauth_rsp *rsp);
156 #endif
157 #endif
158 #ifdef WLAN_VENDOR_HANDOFF_CONTROL
159 QDF_STATUS (*mlme_cm_get_vendor_handoff_params_cb)(
160 struct wlan_objmgr_psoc *psoc,
161 void *vendor_handoff_context);
162 #endif
163 #ifdef WLAN_BOOST_CPU_FREQ_IN_ROAM
164 void (*mlme_cm_perfd_reset_cpufreq_ctrl_cb)(void);
165 #endif
166 };
167
168 /**
169 * struct mlme_vdev_mgr_ops - MLME VDEV mgr osif callbacks
170 * @mlme_vdev_mgr_set_mac_addr_response: Callback to indicate set MAC address
171 * response to osif
172 * @mlme_vdev_mgr_send_scan_done_complete_cb: Callback to indicate scan done
173 * complete to osif
174 */
175 struct mlme_vdev_mgr_ops {
176 #ifdef WLAN_FEATURE_DYNAMIC_MAC_ADDR_UPDATE
177 QDF_STATUS (*mlme_vdev_mgr_set_mac_addr_response)(uint8_t vdev_id,
178 uint8_t resp_status);
179 #endif
180 void (*mlme_vdev_mgr_send_scan_done_complete_cb)(uint8_t vdev_id);
181 };
182
183 /**
184 * struct mlme_twt_ops: twt component osif callbacks
185 * @mlme_twt_enable_complete_cb: TWT enable complete callback
186 * @psoc: psoc pointer
187 * @event: response
188 * @context: context
189 *
190 * @mlme_twt_disable_complete_cb: TWT disable complete callback
191 * @psoc: psoc pointer
192 * @event: response
193 * @context: context
194 *
195 * @mlme_twt_ack_complete_cb: TWT ack complete callback
196 * @psoc: psoc pointer
197 * @event: response
198 * @context: context
199 *
200 * @mlme_twt_setup_complete_cb: TWT setup complete callback
201 * @psoc: psoc pointer
202 * @event: response
203 * @renego_fail: flag to indicate if renegotiation failure case
204 *
205 * @mlme_twt_teardown_complete_cb: TWT teardown complete callback
206 * @psoc: psoc pointer
207 * @event: response
208 *
209 * @mlme_twt_pause_complete_cb: TWT pause complete callback
210 * @psoc: psoc pointer
211 * @event: response
212 *
213 * @mlme_twt_resume_complete_cb: TWT resume complete callback
214 * @psoc: psoc pointer
215 * @event: response
216 *
217 * @mlme_twt_nudge_complete_cb: TWT nudge complete callback
218 * @psoc: psoc pointer
219 * @event: response
220 *
221 * @mlme_twt_notify_complete_cb: TWT notify complete callback
222 * @psoc: psoc pointer
223 * @event: response
224 *
225 * @mlme_twt_vdev_create_cb: TWT vdev create callback
226 * @vdev: vdev pointer
227 *
228 * @mlme_twt_vdev_destroy_cb: TWT vdev destroy callback
229 * @vdev: vdev pointer
230 */
231 struct mlme_twt_ops {
232 QDF_STATUS (*mlme_twt_enable_complete_cb)(
233 struct wlan_objmgr_psoc *psoc,
234 struct twt_enable_complete_event_param *event,
235 void *context);
236
237 QDF_STATUS (*mlme_twt_disable_complete_cb)(
238 struct wlan_objmgr_psoc *psoc,
239 struct twt_disable_complete_event_param *event,
240 void *context);
241
242 QDF_STATUS (*mlme_twt_ack_complete_cb)(
243 struct wlan_objmgr_psoc *psoc,
244 struct twt_ack_complete_event_param *event,
245 void *context);
246
247 QDF_STATUS (*mlme_twt_setup_complete_cb)(
248 struct wlan_objmgr_psoc *psoc,
249 struct twt_add_dialog_complete_event *event,
250 bool renego_fail);
251
252 QDF_STATUS (*mlme_twt_teardown_complete_cb)(
253 struct wlan_objmgr_psoc *psoc,
254 struct twt_del_dialog_complete_event_param *event);
255
256 QDF_STATUS (*mlme_twt_pause_complete_cb)(
257 struct wlan_objmgr_psoc *psoc,
258 struct twt_pause_dialog_complete_event_param *event);
259
260 QDF_STATUS (*mlme_twt_resume_complete_cb)(
261 struct wlan_objmgr_psoc *psoc,
262 struct twt_resume_dialog_complete_event_param *event);
263
264 QDF_STATUS (*mlme_twt_nudge_complete_cb)(
265 struct wlan_objmgr_psoc *psoc,
266 struct twt_nudge_dialog_complete_event_param *event);
267
268 QDF_STATUS (*mlme_twt_notify_complete_cb)(
269 struct wlan_objmgr_psoc *psoc,
270 struct twt_notify_event_param *event);
271
272 QDF_STATUS (*mlme_twt_vdev_create_cb)(
273 struct wlan_objmgr_vdev *vdev);
274
275 QDF_STATUS (*mlme_twt_vdev_destroy_cb)(
276 struct wlan_objmgr_vdev *vdev);
277 };
278
279 /**
280 * struct mlme_ext_ops - MLME legacy callbacks structure
281 * @mlme_psoc_ext_hdl_create: callback to invoke creation of
282 * legacy psoc object
283 * @mlme_psoc_ext_hdl_destroy: callback to invoke destroy of legacy
284 * psoc object
285 * @mlme_pdev_ext_hdl_create: callback to invoke creation of
286 * legacy pdev object
287 * @mlme_pdev_ext_hdl_destroy: callback to invoke destroy of legacy
288 * pdev object
289 * @mlme_vdev_ext_hdl_create: callback to invoke creation of
290 * legacy vdev object
291 * @mlme_vdev_ext_hdl_post_create: callback to invoke post creation
292 * actions of legacy vdev object
293 * @mlme_vdev_ext_hdl_destroy: callback to invoke destroy of legacy
294 * vdev object
295 * @mlme_vdev_start_fw_send: callback to invoke vdev start
296 * command
297 * @mlme_vdev_stop_fw_send: callback to invoke vdev stop command
298 * @mlme_vdev_down_fw_send: callback to invoke vdev down command
299 * @mlme_multivdev_restart_fw_send: callback to invoke multivdev restart
300 * command
301 * @mlme_vdev_enqueue_exp_cmd: callback to enqueue exception
302 * command
303 * required by serialization
304 * @mlme_vdev_ext_delete_rsp: callback to process vdev ext delete
305 * @mlme_multi_vdev_restart_resp: callback to process multivdev
306 * restart response
307 * @mlme_cm_ext_hdl_create_cb: callback to create ext cm context
308 * @mlme_cm_ext_hdl_destroy_cb: callback to destroy ext cm context
309 * @mlme_cm_ext_connect_start_ind_cb: callback to indicate connect start
310 * @mlme_cm_ext_bss_select_ind_cb: callback to indicate candidate
311 * select for connect
312 * @mlme_cm_ext_bss_peer_create_req_cb: callback to bss peer create request
313 * @mlme_cm_ext_connect_req_cb: callback for connect request to
314 * VDEV/PEER SM
315 * @mlme_cm_ext_connect_complete_ind_cb: callback to indicate connect
316 * complete
317 * @mlme_cm_ext_disconnect_start_ind_cb : callback to indicate disconnect
318 * start
319 * @mlme_cm_ext_disconnect_req_cb: callback to disconnect req to
320 * VDEV/PEER SM
321 * @mlme_cm_ext_bss_peer_delete_req_cb: callback to bss peer delete request
322 * @mlme_cm_ext_disconnect_complete_ind_cb: callback to indicate disconnect
323 * complete
324 * @mlme_cm_ext_vdev_down_req_cb: callback to send vdev down to FW
325 * @mlme_cm_ext_roam_start_ind_cb: callback to indicate roam start
326 * @mlme_cm_ext_rso_stop_cb: callback to send rso stop to FW
327 * @mlme_cm_ext_reassoc_req_cb: callback for reassoc request to
328 * VDEV/PEER SM
329 * @mlme_psoc_ext_hdl_enable: to enable mlme ext param handler
330 * @mlme_psoc_ext_hdl_disable: to disable mlme ext param handler
331 * @mlme_vdev_send_set_mac_addr: callback to send set MAC address
332 * request to FW
333 * @mlme_ext_get_acs_inprogress: callback to determine if ACS is
334 * in progress on a given vdev
335 */
336 struct mlme_ext_ops {
337 QDF_STATUS (*mlme_psoc_ext_hdl_create)(
338 struct psoc_mlme_obj *psoc_mlme);
339 QDF_STATUS (*mlme_psoc_ext_hdl_destroy)(
340 struct psoc_mlme_obj *pdev_mlme);
341 QDF_STATUS (*mlme_pdev_ext_hdl_create)(
342 struct pdev_mlme_obj *pdev_mlme);
343 QDF_STATUS (*mlme_pdev_ext_hdl_destroy)(
344 struct pdev_mlme_obj *pdev_mlme);
345 QDF_STATUS (*mlme_vdev_ext_hdl_create)(
346 struct vdev_mlme_obj *vdev_mlme);
347 QDF_STATUS (*mlme_vdev_ext_hdl_post_create)(
348 struct vdev_mlme_obj *vdev_mlme);
349 QDF_STATUS (*mlme_vdev_ext_hdl_destroy)(
350 struct vdev_mlme_obj *vdev_mlme);
351 QDF_STATUS (*mlme_vdev_start_fw_send)(
352 struct wlan_objmgr_vdev *vdev, uint8_t restart);
353 QDF_STATUS (*mlme_vdev_stop_fw_send)(struct wlan_objmgr_vdev *vdev);
354 QDF_STATUS (*mlme_vdev_down_fw_send)(struct wlan_objmgr_vdev *vdev);
355 QDF_STATUS (*mlme_multivdev_restart_fw_send)(
356 struct wlan_objmgr_pdev *pdev);
357 QDF_STATUS (*mlme_vdev_enqueue_exp_cmd)(
358 struct vdev_mlme_obj *vdev_mlme,
359 uint8_t cmd_type);
360 QDF_STATUS (*mlme_vdev_ext_delete_rsp)(
361 struct wlan_objmgr_psoc *psoc,
362 struct vdev_delete_response *rsp);
363 QDF_STATUS (*mlme_multi_vdev_restart_resp)(
364 struct wlan_objmgr_psoc *psoc,
365 struct multi_vdev_restart_resp *resp);
366 QDF_STATUS (*mlme_cm_ext_hdl_create_cb)(struct wlan_objmgr_vdev *vdev,
367 cm_ext_t **ext_cm_ptr);
368 QDF_STATUS (*mlme_cm_ext_hdl_destroy_cb)(struct wlan_objmgr_vdev *vdev,
369 cm_ext_t *ext_cm_ptr);
370 QDF_STATUS (*mlme_cm_ext_connect_start_ind_cb)(
371 struct wlan_objmgr_vdev *vdev,
372 struct wlan_cm_connect_req *req);
373 QDF_STATUS (*mlme_cm_ext_bss_select_ind_cb)(
374 struct wlan_objmgr_vdev *vdev,
375 struct wlan_cm_vdev_connect_req *req);
376 QDF_STATUS (*mlme_cm_ext_bss_peer_create_req_cb)(
377 struct wlan_objmgr_vdev *vdev,
378 struct qdf_mac_addr *peer_mac,
379 struct qdf_mac_addr *mld_mac,
380 bool is_assoc_link);
381 QDF_STATUS (*mlme_cm_ext_connect_req_cb)(struct wlan_objmgr_vdev *vdev,
382 struct wlan_cm_vdev_connect_req *req);
383 QDF_STATUS (*mlme_cm_ext_connect_complete_ind_cb)(
384 struct wlan_objmgr_vdev *vdev,
385 struct wlan_cm_connect_resp *rsp);
386 QDF_STATUS (*mlme_cm_ext_disconnect_start_ind_cb)(
387 struct wlan_objmgr_vdev *vdev,
388 struct wlan_cm_disconnect_req *req);
389 QDF_STATUS (*mlme_cm_ext_disconnect_req_cb)
390 (struct wlan_objmgr_vdev *vdev,
391 struct wlan_cm_vdev_discon_req *req);
392 QDF_STATUS (*mlme_cm_ext_bss_peer_delete_req_cb)(
393 struct wlan_objmgr_vdev *vdev);
394 QDF_STATUS (*mlme_cm_ext_disconnect_complete_ind_cb)(
395 struct wlan_objmgr_vdev *vdev,
396 struct wlan_cm_discon_rsp *rsp);
397 QDF_STATUS (*mlme_cm_ext_vdev_down_req_cb)(
398 struct wlan_objmgr_vdev *vdev);
399 QDF_STATUS (*mlme_cm_ext_roam_start_ind_cb)(
400 struct wlan_objmgr_vdev *vdev,
401 struct wlan_cm_roam_req *req);
402 QDF_STATUS (*mlme_cm_ext_rso_stop_cb)(struct wlan_objmgr_vdev *vdev);
403 QDF_STATUS (*mlme_cm_ext_reassoc_req_cb)(
404 struct wlan_objmgr_vdev *vdev,
405 struct wlan_cm_vdev_reassoc_req *req);
406 QDF_STATUS (*mlme_psoc_ext_hdl_enable)(struct wlan_objmgr_psoc *psoc);
407 QDF_STATUS (*mlme_psoc_ext_hdl_disable)(struct wlan_objmgr_psoc *psoc);
408 #ifdef WLAN_FEATURE_DYNAMIC_MAC_ADDR_UPDATE
409 QDF_STATUS (*mlme_vdev_send_set_mac_addr)(
410 struct qdf_mac_addr mac_addr,
411 struct qdf_mac_addr mld_addr,
412 struct wlan_objmgr_vdev *vdev);
413 #endif
414 QDF_STATUS (*mlme_ext_get_acs_inprogress)(
415 struct wlan_objmgr_vdev *vdev,
416 bool *is_acs_inprogress);
417 };
418
419 enum wlan_mlme_peer_param;
420 enum wlan_mlme_vdev_param;
421 enum wlan_mlme_pdev_param;
422
423 /**
424 * struct mlme_external_tx_ops - MLME external callbacks structure
425 * @peer_ops: callback to invoke peer mlme ops from external module
426 * @vdev_ops: callback to invoke vdev mlme ops from external module
427 * @pdev_ops: callback to invoke pdev mlme ops from external module
428 * @scan_db_iterate: callback to invoke scan database iterate
429 */
430 struct mlme_external_tx_ops {
431 QDF_STATUS (*peer_ops)(
432 struct wlan_objmgr_peer *peer,
433 enum wlan_mlme_peer_param type,
434 void *data, void *ret);
435 QDF_STATUS (*vdev_ops)(
436 struct wlan_objmgr_vdev *vdev,
437 enum wlan_mlme_vdev_param type,
438 void *data, void *ret);
439 QDF_STATUS (*pdev_ops)(
440 struct wlan_objmgr_pdev *pdev,
441 enum wlan_mlme_pdev_param type,
442 void *data, void *ret);
443 QDF_STATUS (*scan_db_iterate)(
444 struct wlan_objmgr_pdev *pdev,
445 scan_iterator_func handler, void *arg);
446 };
447
448 /**
449 * mlme_psoc_ops_ext_hdl_create() - Alloc PSOC mlme ext handle
450 * @psoc_mlme: PSOC MLME comp object
451 *
452 * API to allocate PSOC MLME ext handle
453 *
454 * Return: SUCCESS on successful allocation
455 * Else FAILURE
456 */
457 QDF_STATUS mlme_psoc_ops_ext_hdl_create(struct psoc_mlme_obj *psoc_mlme);
458
459 /**
460 * mlme_psoc_ops_ext_hdl_destroy() - Destroy PSOC mlme ext handle
461 * @psoc_mlme: PSOC MLME comp object
462 *
463 * API to free psoc MLME ext handle
464 *
465 * Return: SUCCESS on successful free
466 * Else FAILURE
467 */
468 QDF_STATUS mlme_psoc_ops_ext_hdl_destroy(struct psoc_mlme_obj *psoc_mlme);
469
470 /**
471 * mlme_psoc_ext_enable_cb() - to enable mlme ext param handler callback
472 * @psoc: psoc common object
473 *
474 * Return: QDF_STATUS
475 */
476 QDF_STATUS mlme_psoc_ext_enable_cb(struct wlan_objmgr_psoc *psoc);
477
478 /**
479 * mlme_psoc_ext_disable_cb() - to disable mlme ext param handler callback
480 * @psoc: psoc common object
481 *
482 * Return: QDF_STATUS
483 */
484 QDF_STATUS mlme_psoc_ext_disable_cb(struct wlan_objmgr_psoc *psoc);
485
486 /**
487 * mlme_pdev_ops_ext_hdl_create - Alloc PDEV mlme ext handle
488 * @pdev_mlme: PDEV MLME comp object
489 *
490 * API to allocate PDEV MLME ext handle
491 *
492 * Return: SUCCESS on successful allocation
493 * Else FAILURE
494 */
495 QDF_STATUS mlme_pdev_ops_ext_hdl_create(struct pdev_mlme_obj *pdev_mlme);
496
497 /**
498 * mlme_pdev_ops_ext_hdl_destroy - Destroy PDEV mlme ext handle
499 * @pdev_mlme: PDEV MLME comp object
500 *
501 * API to free pdev MLME ext handle
502 *
503 * Return: SUCCESS on successful free
504 * Else FAILURE
505 */
506 QDF_STATUS mlme_pdev_ops_ext_hdl_destroy(struct pdev_mlme_obj *pdev_mlme);
507
508 /**
509 * mlme_vdev_ops_ext_hdl_create - Alloc VDEV mlme ext handle
510 * @vdev_mlme: VDEV MLME comp object
511 *
512 * API to allocate VDEV MLME ext handle
513 *
514 * Return: SUCCESS on successful allocation
515 * Else FAILURE
516 */
517 QDF_STATUS mlme_vdev_ops_ext_hdl_create(struct vdev_mlme_obj *vdev_mlme);
518
519 /**
520 * mlme_vdev_ops_ext_hdl_post_create - Perform post VDEV mlme ext handle alloc
521 * operations
522 * @vdev_mlme: VDEV MLME comp object
523 *
524 * API to perform post vdev MLME ext handle allocation operations
525 *
526 * Return: SUCCESS on initialization successful
527 * Else FAILURE
528 */
529 QDF_STATUS mlme_vdev_ops_ext_hdl_post_create(struct vdev_mlme_obj *vdev_mlme);
530
531 /**
532 * mlme_vdev_ops_ext_hdl_destroy - Destroy VDEV mlme ext handle
533 * @vdev_mlme: VDEV MLME comp object
534 *
535 * API to free vdev MLME ext handle
536 *
537 * Return: SUCCESS on successful free
538 * Else FAILURE
539 */
540 QDF_STATUS mlme_vdev_ops_ext_hdl_destroy(struct vdev_mlme_obj *vdev_mlme);
541
542 /**
543 * mlme_vdev_enqueue_exp_ser_cmd - Enqueue exception serialization cmd
544 * @vdev_mlme: VDEV MLME comp object
545 * @cmd_type: Serialization command type
546 *
547 * API to enqueue the exception serialization command, used by
548 * mlme-serialization wrapper layer
549 *
550 * Return: SUCCESS on successful enqueuing the command
551 * Else FAILURE
552 */
553 QDF_STATUS mlme_vdev_enqueue_exp_ser_cmd(struct vdev_mlme_obj *vdev_mlme,
554 uint8_t cmd_type);
555
556 /**
557 * mlme_vdev_ops_start_fw_send - Send WMI START/RESTART command to FW
558 * @vdev: VDEV object
559 * @restart: send start vs restart
560 *
561 * API to send WMI start/restart command to FW
562 *
563 * Return: SUCCESS on successful sending the command
564 * Else FAILURE
565 */
566 QDF_STATUS mlme_vdev_ops_start_fw_send(struct wlan_objmgr_vdev *vdev,
567 uint8_t restart);
568
569 /**
570 * mlme_vdev_ops_multivdev_restart_fw_cmd_send - Send WMI Multivdev restart
571 * command to FW
572 * @pdev: PDEV object
573 *
574 * API to send WMI multivdev restart command to FW
575 *
576 * Return: SUCCESS on successful sending the command
577 * Else FAILURE
578 */
579 QDF_STATUS mlme_vdev_ops_multivdev_restart_fw_cmd_send(
580 struct wlan_objmgr_pdev *pdev);
581
582 /**
583 * mlme_vdev_ops_stop_fw_send - Send WMI STOP command to FW
584 * @vdev: VDEV object
585 *
586 * API to send WMI stop command to FW
587 *
588 * Return: SUCCESS on successful sending the command
589 * Else FAILURE
590 */
591 QDF_STATUS mlme_vdev_ops_stop_fw_send(struct wlan_objmgr_vdev *vdev);
592
593 /**
594 * mlme_vdev_ops_down_fw_send - Send WMI Down command to FW
595 * @vdev: VDEV object
596 *
597 * API to send WMI down command to FW
598 *
599 * Return: SUCCESS on successful sending the command
600 * Else FAILURE
601 */
602 QDF_STATUS mlme_vdev_ops_down_fw_send(struct wlan_objmgr_vdev *vdev);
603
604 /**
605 * mlme_vdev_ops_ext_hdl_multivdev_restart_resp() - Handler multivdev restart
606 * response event
607 * @psoc: PSOC object manager handle
608 * @resp: Restart response event
609 *
610 * Return: Success on successful handling of the response event,
611 * Else failure
612 */
613 QDF_STATUS mlme_vdev_ops_ext_hdl_multivdev_restart_resp(
614 struct wlan_objmgr_psoc *psoc,
615 struct multi_vdev_restart_resp *resp);
616
617 /*
618 * typedef mlme_get_global_ops_cb() - callback to get MLME ext ops
619 *
620 * NB: kernel-doc Cannot parse typedef
621 */
622 typedef struct mlme_ext_ops *(*mlme_get_global_ops_cb)(void);
623
624 /**
625 * mlme_set_ops_register_cb - Sets ops registration callback
626 * @ops_cb: Function pointer
627 *
628 * API to set ops registration call back
629 *
630 * Return: void
631 */
632 void mlme_set_ops_register_cb(mlme_get_global_ops_cb ops_cb);
633
634 /**
635 * wlan_cmn_mlme_init - Initializes MLME component
636 *
637 * Registers callbacks with object manager for create/destroy
638 *
639 * Return: SUCCESS on successful registration
640 * FAILURE, if registration fails
641 */
642 QDF_STATUS wlan_cmn_mlme_init(void);
643
644 /**
645 * wlan_cmn_mlme_deinit - Uninitializes MLME component
646 *
647 * Unregisters callbacks with object manager for create/destroy
648 *
649 * Return: SUCCESS on successful registration
650 * FAILURE, if registration fails
651 */
652 QDF_STATUS wlan_cmn_mlme_deinit(void);
653
654 /**
655 * mlme_vdev_ops_ext_hdl_delete_rsp - Vdev Delete response ext handler
656 * @psoc: PSOC object
657 * @rsp: Vdev delete response received from the firmware
658 *
659 * API to invoke the legacy delete response handler for legacy cleanup
660 *
661 * Return: SUCCESS on successful deletion
662 * FAILURE, if deletion fails
663 */
664 QDF_STATUS mlme_vdev_ops_ext_hdl_delete_rsp(struct wlan_objmgr_psoc *psoc,
665 struct vdev_delete_response *rsp);
666
667 /**
668 * mlme_cm_ext_hdl_create() - Connection manager callback to create ext
669 * context
670 * @vdev: VDEV object
671 * @ext_cm_ptr: pointer to connection manager ext pointer
672 *
673 * Return: QDF_STATUS
674 */
675 QDF_STATUS mlme_cm_ext_hdl_create(struct wlan_objmgr_vdev *vdev,
676 cm_ext_t **ext_cm_ptr);
677
678 /**
679 * mlme_cm_ext_hdl_destroy() - Connection manager callback to destroy ext
680 * context
681 * @vdev: VDEV object
682 * @ext_cm_ptr: connection manager ext pointer
683 *
684 * Return: QDF_STATUS
685 */
686 QDF_STATUS mlme_cm_ext_hdl_destroy(struct wlan_objmgr_vdev *vdev,
687 cm_ext_t *ext_cm_ptr);
688
689 /**
690 * mlme_cm_connect_start_ind() - Connection manager ext Connect start indication
691 * @vdev: VDEV object
692 * @req: Connection manager connect request
693 *
694 * Return: QDF_STATUS
695 */
696 QDF_STATUS mlme_cm_connect_start_ind(struct wlan_objmgr_vdev *vdev,
697 struct wlan_cm_connect_req *req);
698
699 /**
700 * mlme_cm_bss_select_ind() - Connection manager ext Connect candidate
701 * select indication, to do operations for the candidate
702 * @vdev: VDEV object
703 * @req: Vdev connect request
704 *
705 * Return: QDF_STATUS
706 */
707 QDF_STATUS mlme_cm_bss_select_ind(struct wlan_objmgr_vdev *vdev,
708 struct wlan_cm_vdev_connect_req *req);
709
710 /**
711 * mlme_cm_bss_peer_create_req() - Connection manager ext bss peer create
712 * request
713 * @vdev: VDEV object
714 * @peer_mac: Peer mac address
715 * @mld_mac: mld mac address
716 * @is_assoc_link: assoc happens on this link or not
717 *
718 * Return: QDF_STATUS
719 */
720 QDF_STATUS mlme_cm_bss_peer_create_req(struct wlan_objmgr_vdev *vdev,
721 struct qdf_mac_addr *peer_mac,
722 struct qdf_mac_addr *mld_mac,
723 bool is_assoc_link);
724
725 /**
726 * mlme_cm_connect_req() - Connection manager ext connect request to start vdev
727 * and peer assoc state machine
728 * @vdev: VDEV object
729 * @req: Vdev connect request
730 *
731 * Context: The req is on stack, so the API need to make a copy, if it want to
732 * use the req after return.
733 *
734 * Return: QDF_STATUS
735 */
736 QDF_STATUS mlme_cm_connect_req(struct wlan_objmgr_vdev *vdev,
737 struct wlan_cm_vdev_connect_req *req);
738
739 #ifdef CONN_MGR_ADV_FEATURE
740 /**
741 * mlme_cm_osif_connect_active_notify() - CNX manager ext connect active
742 * notification.
743 * @vdev_id: VDEV ID
744 *
745 * Return: void
746 */
747 void mlme_cm_osif_connect_active_notify(uint8_t vdev_id);
748 #else
mlme_cm_osif_connect_active_notify(uint8_t vdev_id)749 static inline void mlme_cm_osif_connect_active_notify(uint8_t vdev_id)
750 {
751 }
752 #endif
753
754 /**
755 * mlme_cm_connect_complete_ind() - Connection manager ext connect complete
756 * indication
757 * @vdev: VDEV object
758 * @rsp: Connection manager connect response
759 *
760 * Return: QDF_STATUS
761 */
762 QDF_STATUS mlme_cm_connect_complete_ind(struct wlan_objmgr_vdev *vdev,
763 struct wlan_cm_connect_resp *rsp);
764
765 /**
766 * mlme_cm_roam_start_ind() - Connection manager ext Connect start indication
767 * @vdev: VDEV object
768 * @req: Connection manager roam request
769 *
770 * Return: QDF_STATUS
771 */
772 QDF_STATUS mlme_cm_roam_start_ind(struct wlan_objmgr_vdev *vdev,
773 struct wlan_cm_roam_req *req);
774
775 /**
776 * mlme_cm_rso_stop_req() - Connection manager ext RSO stop request
777 * @vdev: VDEV object
778 *
779 * Return: QDF_STATUS
780 */
781 QDF_STATUS mlme_cm_rso_stop_req(struct wlan_objmgr_vdev *vdev);
782
783 /**
784 * mlme_cm_reassoc_req() - Connection manager ext reassoc request
785 * @vdev: VDEV object
786 * @req: Vdev reassoc request
787 *
788 * Context: The req is on stack, so the API need to make a copy, if it want to
789 * use the req after return.
790 *
791 * Return: QDF_STATUS
792 */
793 QDF_STATUS mlme_cm_reassoc_req(struct wlan_objmgr_vdev *vdev,
794 struct wlan_cm_vdev_reassoc_req *req);
795
796 /**
797 * mlme_cm_disconnect_start_ind() - Connection manager ext disconnect start
798 * indication
799 * @vdev: VDEV object
800 * @req: Connection manager disconnect request
801 *
802 * Return: QDF_STATUS
803 */
804 QDF_STATUS mlme_cm_disconnect_start_ind(struct wlan_objmgr_vdev *vdev,
805 struct wlan_cm_disconnect_req *req);
806
807 /**
808 * mlme_cm_disconnect_req() - Connection manager ext disconnect
809 * req to vdev and peer sm
810 * @vdev: VDEV object
811 * @req: vdev disconnect request
812 *
813 * Return: QDF_STATUS
814 */
815 QDF_STATUS mlme_cm_disconnect_req(struct wlan_objmgr_vdev *vdev,
816 struct wlan_cm_vdev_discon_req *req);
817
818 /**
819 * mlme_cm_bss_peer_delete_req() - Connection manager ext bss peer delete
820 * request
821 * @vdev: VDEV object
822 *
823 * Return: QDF_STATUS
824 */
825 QDF_STATUS
826 mlme_cm_bss_peer_delete_req(struct wlan_objmgr_vdev *vdev);
827
828 /**
829 * mlme_cm_disconnect_complete_ind() - Connection manager ext disconnect
830 * complete indication
831 * @vdev: VDEV object
832 * @rsp: Connection manager disconnect response
833 *
834 * Return: QDF_STATUS
835 */
836 QDF_STATUS mlme_cm_disconnect_complete_ind(struct wlan_objmgr_vdev *vdev,
837 struct wlan_cm_discon_rsp *rsp);
838
839 /**
840 * mlme_cm_vdev_down_req() - Connection manager ext req to send vdev down to FW
841 * @vdev: VDEV object
842 *
843 * Return: QDF_STATUS
844 */
845 QDF_STATUS mlme_cm_vdev_down_req(struct wlan_objmgr_vdev *vdev);
846
847 /**
848 * mlme_ext_hdl_get_acs_in_progress() - Check if ACS is in progress
849 * @vdev: VDEV object
850 * @acs_in_progress: ACS in progress flag
851 *
852 * Return: QDF_STATUS
853 */
854 QDF_STATUS mlme_ext_hdl_get_acs_in_progress(struct wlan_objmgr_vdev *vdev,
855 bool *acs_in_progress);
856 /**
857 * mlme_cm_osif_connect_complete() - Connect complete resp to osif
858 * @vdev: vdev pointer
859 * @rsp: Connect response
860 *
861 * Return: QDF_STATUS
862 */
863 QDF_STATUS mlme_cm_osif_connect_complete(struct wlan_objmgr_vdev *vdev,
864 struct wlan_cm_connect_resp *rsp);
865
866 /**
867 * mlme_cm_osif_failed_candidate_ind() - Failed Candidate indication to osif
868 * @vdev: vdev pointer
869 * @rsp: Connect response
870 *
871 * Return: QDF_STATUS
872 */
873 QDF_STATUS
874 mlme_cm_osif_failed_candidate_ind(struct wlan_objmgr_vdev *vdev,
875 struct wlan_cm_connect_resp *rsp);
876
877 /**
878 * mlme_cm_osif_update_id_and_src() - Update connection id and source to osif
879 * @vdev: vdev pointer
880 * @source: source of request
881 * @cm_id: connection manager id
882 *
883 * Return: QDF_STATUS
884 */
885 QDF_STATUS mlme_cm_osif_update_id_and_src(struct wlan_objmgr_vdev *vdev,
886 enum wlan_cm_source source,
887 wlan_cm_id cm_id);
888
889 /**
890 * mlme_cm_osif_disconnect_complete() - Disconnect complete osif response
891 * @vdev: vdev pointer
892 * @rsp: Disconnect response
893 *
894 * Return: QDF_STATUS
895 */
896 QDF_STATUS
897 mlme_cm_osif_disconnect_complete(struct wlan_objmgr_vdev *vdev,
898 struct wlan_cm_discon_rsp *rsp);
899
900 /**
901 * mlme_cm_osif_disconnect_start_ind() - osif Disconnect start indication
902 * @vdev: vdev pointer
903 * @source: Source of disconnect
904 *
905 * Return: QDF_STATUS
906 */
907 QDF_STATUS mlme_cm_osif_disconnect_start_ind(struct wlan_objmgr_vdev *vdev,
908 enum wlan_cm_source source);
909
910 #ifdef WLAN_VENDOR_HANDOFF_CONTROL
911 /**
912 * mlme_cm_osif_get_vendor_handoff_params() - osif get vendor handoff params
913 * indication
914 * @psoc: psoc pointer
915 * @vendor_handoff_context: vendor handoff context
916 *
917 * Return: QDF_STATUS
918 */
919 QDF_STATUS mlme_cm_osif_get_vendor_handoff_params(struct wlan_objmgr_psoc *psoc,
920 void *vendor_handoff_context);
921 #endif
922
923 #ifdef CONN_MGR_ADV_FEATURE
924 /**
925 * mlme_cm_osif_roam_sync_ind() - osif Roam sync indication
926 * @vdev: vdev pointer
927 *
928 * Return: QDF_STATUS
929 */
930 QDF_STATUS mlme_cm_osif_roam_sync_ind(struct wlan_objmgr_vdev *vdev);
931
932 /**
933 * mlme_cm_osif_pmksa_candidate_notify() - osif roam pmksa candidate notify
934 * @vdev: vdev pointer
935 * @bssid: bssid
936 * @index: index
937 * @preauth: preauth flag
938 *
939 * Return: QDF_STATUS
940 */
941 QDF_STATUS mlme_cm_osif_pmksa_candidate_notify(struct wlan_objmgr_vdev *vdev,
942 struct qdf_mac_addr *bssid,
943 int index, bool preauth);
944 /**
945 * mlme_cm_osif_send_keys() - send vdev keys
946 * @vdev: vdev pointer
947 * @key_index: key index value
948 * @pairwise: pairwise bool value
949 * @cipher_type: cipher enum value
950 *
951 * Return: QDF_STATUS
952 */
953 QDF_STATUS mlme_cm_osif_send_keys(struct wlan_objmgr_vdev *vdev,
954 uint8_t key_index, bool pairwise,
955 enum wlan_crypto_cipher_type cipher_type);
956
957 /**
958 * mlme_cm_osif_link_reconfig_notify() - notify link reconfig event
959 * @vdev: vdev pointer
960 *
961 * Return: QDF_STATUS
962 */
963 QDF_STATUS mlme_cm_osif_link_reconfig_notify(struct wlan_objmgr_vdev *vdev);
964 #else
965 static inline
mlme_cm_osif_roam_sync_ind(struct wlan_objmgr_vdev * vdev)966 QDF_STATUS mlme_cm_osif_roam_sync_ind(struct wlan_objmgr_vdev *vdev)
967 {
968 return QDF_STATUS_SUCCESS;
969 }
970
971 static inline
mlme_cm_osif_send_keys(struct wlan_objmgr_vdev * vdev,uint8_t key_index,bool pairwise,enum wlan_crypto_cipher_type cipher_type)972 QDF_STATUS mlme_cm_osif_send_keys(struct wlan_objmgr_vdev *vdev,
973 uint8_t key_index, bool pairwise,
974 enum wlan_crypto_cipher_type cipher_type)
975 {
976 return QDF_STATUS_SUCCESS;
977 }
978
979 static inline
mlme_cm_osif_link_reconfig_notify(struct wlan_objmgr_vdev * vdev)980 QDF_STATUS mlme_cm_osif_link_reconfig_notify(struct wlan_objmgr_vdev *vdev)
981 {
982 return QDF_STATUS_SUCCESS;
983 }
984 #endif
985
986 #ifdef WLAN_FEATURE_ROAM_OFFLOAD
987 /**
988 * mlme_cm_osif_roam_start_ind() - osif Roam start indication
989 * @vdev: vdev pointer
990 *
991 * Return: QDF_STATUS
992 */
993 QDF_STATUS mlme_cm_osif_roam_start_ind(struct wlan_objmgr_vdev *vdev);
994
995 /**
996 * mlme_cm_osif_roam_abort_ind() - osif Roam abort indication
997 * @vdev: vdev pointer
998 *
999 * Return: QDF_STATUS
1000 */
1001 QDF_STATUS mlme_cm_osif_roam_abort_ind(struct wlan_objmgr_vdev *vdev);
1002
1003 /**
1004 * mlme_cm_osif_roam_complete() - osif Roam sync complete callback
1005 * @vdev: vdev pointer
1006 *
1007 * Return: QDF_STATUS
1008 */
1009 QDF_STATUS mlme_cm_osif_roam_complete(struct wlan_objmgr_vdev *vdev);
1010
1011 /**
1012 * mlme_cm_osif_roam_rt_stats() - osif Roam stats callback
1013 * @roam_stats: roam_stats_event pointer
1014 * @idx: TLV idx for roam_stats_event
1015 *
1016 * Return: void
1017 */
1018 void mlme_cm_osif_roam_rt_stats(struct roam_stats_event *roam_stats, uint8_t idx);
1019 /**
1020 * mlme_cm_osif_roam_get_scan_params() - osif Roam get scan params callback
1021 * @vdev: vdev pointer
1022 * @scan_ie: Pointer to scan_ie
1023 * @dot11mode_filter: Pointer to dot11mode_filter
1024 *
1025 * Get scan IE params from adapter corresponds to given vdev
1026 *
1027 * Return: QDF_STATUS
1028 */
1029 QDF_STATUS
1030 mlme_cm_osif_roam_get_scan_params(struct wlan_objmgr_vdev *vdev,
1031 struct element_info *scan_ie,
1032 enum dot11_mode_filter *dot11mode_filter);
1033 #endif
1034
1035 #ifdef WLAN_FEATURE_PREAUTH_ENABLE
1036 /**
1037 * mlme_cm_osif_ft_preauth_complete() - osif roam ft preauth complete callback
1038 * @vdev: vdev pointer
1039 * @rsp: preauth response pointer
1040 *
1041 * Return: QDF_STATUS
1042 */
1043 QDF_STATUS
1044 mlme_cm_osif_ft_preauth_complete(struct wlan_objmgr_vdev *vdev,
1045 struct wlan_preauth_rsp *rsp);
1046 #ifdef FEATURE_WLAN_ESE
1047 /**
1048 * mlme_cm_osif_cckm_preauth_complete() - osif cckm preauth complete callback
1049 * @vdev: vdev pointer
1050 * @rsp: preauth response pointer
1051 *
1052 * Return: QDF_STATUS
1053 */
1054 QDF_STATUS
1055 mlme_cm_osif_cckm_preauth_complete(struct wlan_objmgr_vdev *vdev,
1056 struct wlan_preauth_rsp *rsp);
1057 #else
1058 static inline QDF_STATUS
mlme_cm_osif_cckm_preauth_complete(struct wlan_objmgr_vdev * vdev,struct wlan_preauth_rsp * rsp)1059 mlme_cm_osif_cckm_preauth_complete(struct wlan_objmgr_vdev *vdev,
1060 struct wlan_preauth_rsp *rsp)
1061 {
1062 return QDF_STATUS_SUCCESS;
1063 }
1064 #endif /* FEATURE_WLAN_ESE */
1065 #endif /* WLAN_FEATURE_PREAUTH_ENABLE */
1066
1067 /*
1068 * typedef osif_cm_get_global_ops_cb() - Callback to get connection manager
1069 * global ops
1070 *
1071 * NB: kernel-doc Cannot parse typedef
1072 */
1073 typedef struct mlme_cm_ops *(*osif_cm_get_global_ops_cb)(void);
1074
1075 /*
1076 * typedef osif_twt_get_global_ops_cb() - Callback to get twt global ops
1077 *
1078 * NB: kernel-doc Cannot parse typedef
1079 */
1080 typedef struct mlme_twt_ops *(*osif_twt_get_global_ops_cb)(void);
1081
1082 /**
1083 * mlme_set_osif_cm_cb() - Sets ops registration callback
1084 * @cm_osif_ops: Function pointer
1085 *
1086 * API to set ops registration call back
1087 *
1088 * Return: void
1089 */
1090 void mlme_set_osif_cm_cb(osif_cm_get_global_ops_cb cm_osif_ops);
1091
1092 /*
1093 * typedef osif_vdev_mgr_get_global_ops_cb() - Callback to get vdev manager
1094 * global ops
1095 *
1096 * NB: kernel-doc Cannot parse typedef
1097 */
1098 typedef struct mlme_vdev_mgr_ops *(*osif_vdev_mgr_get_global_ops_cb)(void);
1099
1100 /**
1101 * mlme_set_osif_vdev_mgr_cb() - Sets ops registration callback
1102 * @mlme_vdev_mgr_osif_ops: Function pointer
1103 *
1104 * API to set ops registration call back
1105 *
1106 * Return: void
1107 */
1108 void mlme_set_osif_vdev_mgr_cb(
1109 osif_vdev_mgr_get_global_ops_cb mlme_vdev_mgr_osif_ops);
1110
1111 /**
1112 * mlme_set_osif_twt_cb() - Sets twt ops registration callback
1113 * @twt_osif_ops: Function pointer
1114 *
1115 * API to set twt ops registration call back
1116 *
1117 * Return: void
1118 */
1119 void mlme_set_osif_twt_cb(osif_twt_get_global_ops_cb twt_osif_ops);
1120
1121 /**
1122 * mlme_max_chan_switch_is_set() - Get if max chan switch IE is enabled
1123 * @psoc: Object manager psoc pointer
1124 *
1125 * Return: True if max chan switch is enabled else false
1126 */
1127 bool mlme_max_chan_switch_is_set(struct wlan_objmgr_psoc *psoc);
1128
1129 /**
1130 * mlme_send_scan_done_complete_cb() - send scan done indication to upper layer
1131 * @vdev_id: vdev id
1132 *
1133 * Return: none
1134 */
1135 void mlme_send_scan_done_complete_cb(uint8_t vdev_id);
1136
1137 #ifdef WLAN_FEATURE_DYNAMIC_MAC_ADDR_UPDATE
1138 /**
1139 * mlme_vdev_ops_send_set_mac_address() - Send set MAC address request to FW
1140 * @mac_addr: VDEV MAC address
1141 * @mld_addr: VDEV MLD address
1142 * @vdev: vdev pointer
1143 *
1144 * API to send set MAC address request command to FW
1145 *
1146 * Return: QDF_STATUS
1147 */
1148 QDF_STATUS mlme_vdev_ops_send_set_mac_address(struct qdf_mac_addr mac_addr,
1149 struct qdf_mac_addr mld_addr,
1150 struct wlan_objmgr_vdev *vdev);
1151
1152 /**
1153 * mlme_vdev_mgr_notify_set_mac_addr_response() - Notify set MAC address
1154 * response
1155 * @vdev_id: VDEV ID
1156 * @resp_status: FW response for the set MAC address operation
1157 *
1158 * API to notify set MAC address to osif
1159 *
1160 * Return: None
1161 */
1162 void mlme_vdev_mgr_notify_set_mac_addr_response(uint8_t vdev_id,
1163 uint8_t resp_status);
1164 #endif
1165
1166 #if defined(WLAN_SUPPORT_TWT) && defined(WLAN_TWT_CONV_SUPPORTED)
1167 /**
1168 * mlme_twt_osif_enable_complete_ind() - enable complete resp to osif
1169 * @psoc: psoc pointer
1170 * @event: enable complete response
1171 * @context: context registered by OSIF
1172 *
1173 * Return: QDF_STATUS
1174 */
1175 QDF_STATUS
1176 mlme_twt_osif_enable_complete_ind(struct wlan_objmgr_psoc *psoc,
1177 struct twt_enable_complete_event_param *event,
1178 void *context);
1179
1180 /**
1181 * mlme_twt_osif_disable_complete_ind() - disable complete resp to osif
1182 * @psoc: psoc pointer
1183 * @event: disable complete response
1184 * @context: context registered by OSIF
1185 *
1186 * Return: QDF_STATUS
1187 */
1188 QDF_STATUS
1189 mlme_twt_osif_disable_complete_ind(struct wlan_objmgr_psoc *psoc,
1190 struct twt_disable_complete_event_param *event,
1191 void *context);
1192
1193 /**
1194 * mlme_twt_osif_ack_complete_ind() - ack complete resp to osif
1195 * @psoc: psoc pointer
1196 * @event: ack complete response
1197 * @context: context registered by OSIF
1198 *
1199 * Return: QDF_STATUS
1200 */
1201 QDF_STATUS
1202 mlme_twt_osif_ack_complete_ind(struct wlan_objmgr_psoc *psoc,
1203 struct twt_ack_complete_event_param *event,
1204 void *context);
1205
1206 /**
1207 * mlme_twt_osif_setup_complete_ind() - setup complete resp to osif
1208 * @psoc: psoc pointer
1209 * @event: setup complete response
1210 * @renego_fail: flag to indicate if renegotiation failure case
1211 *
1212 * Return: QDF_STATUS
1213 */
1214 QDF_STATUS
1215 mlme_twt_osif_setup_complete_ind(struct wlan_objmgr_psoc *psoc,
1216 struct twt_add_dialog_complete_event *event,
1217 bool renego_fail);
1218
1219 /**
1220 * mlme_twt_osif_teardown_complete_ind() - teardown complete resp to osif
1221 * @psoc: psoc pointer
1222 * @event: teardown complete response
1223 *
1224 * Return: QDF_STATUS
1225 */
1226 QDF_STATUS
1227 mlme_twt_osif_teardown_complete_ind(struct wlan_objmgr_psoc *psoc,
1228 struct twt_del_dialog_complete_event_param *event);
1229
1230 /**
1231 * mlme_twt_osif_pause_complete_ind() - pause complete resp to osif
1232 * @psoc: psoc pointer
1233 * @event: pause complete response
1234 *
1235 * Return: QDF_STATUS
1236 */
1237 QDF_STATUS
1238 mlme_twt_osif_pause_complete_ind(struct wlan_objmgr_psoc *psoc,
1239 struct twt_pause_dialog_complete_event_param *event);
1240
1241 /**
1242 * mlme_twt_osif_resume_complete_ind() - resume complete resp to osif
1243 * @psoc: psoc pointer
1244 * @event: resume complete response
1245 *
1246 * Return: QDF_STATUS
1247 */
1248 QDF_STATUS
1249 mlme_twt_osif_resume_complete_ind(struct wlan_objmgr_psoc *psoc,
1250 struct twt_resume_dialog_complete_event_param *event);
1251
1252 /**
1253 * mlme_twt_osif_nudge_complete_ind() - nudge complete resp to osif
1254 * @psoc: psoc pointer
1255 * @event: nudge complete response
1256 *
1257 * Return: QDF_STATUS
1258 */
1259 QDF_STATUS
1260 mlme_twt_osif_nudge_complete_ind(struct wlan_objmgr_psoc *psoc,
1261 struct twt_nudge_dialog_complete_event_param *event);
1262
1263 /**
1264 * mlme_twt_osif_notify_complete_ind() - notify complete resp to osif
1265 * @psoc: psoc pointer
1266 * @event: notify complete response
1267 *
1268 * Return: QDF_STATUS
1269 */
1270 QDF_STATUS
1271 mlme_twt_osif_notify_complete_ind(struct wlan_objmgr_psoc *psoc,
1272 struct twt_notify_event_param *event);
1273
1274 /**
1275 * mlme_twt_vdev_create_notification() - vdev create notification to osif
1276 * @vdev: vdev pointer
1277 *
1278 * Return: QDF_STATUS
1279 */
1280 QDF_STATUS
1281 mlme_twt_vdev_create_notification(struct wlan_objmgr_vdev *vdev);
1282
1283 /**
1284 * mlme_twt_vdev_destroy_notification() - vdev destroy notification to osif
1285 * @vdev: vdev pointer
1286 *
1287 * Return: QDF_STATUS
1288 */
1289 QDF_STATUS
1290 mlme_twt_vdev_destroy_notification(struct wlan_objmgr_vdev *vdev);
1291 #else
1292 static inline QDF_STATUS
mlme_twt_osif_enable_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_enable_complete_event_param * event,void * context)1293 mlme_twt_osif_enable_complete_ind(struct wlan_objmgr_psoc *psoc,
1294 struct twt_enable_complete_event_param *event,
1295 void *context)
1296 {
1297 return QDF_STATUS_SUCCESS;
1298 }
1299
1300 static inline QDF_STATUS
mlme_twt_osif_disable_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_disable_complete_event_param * event,void * context)1301 mlme_twt_osif_disable_complete_ind(struct wlan_objmgr_psoc *psoc,
1302 struct twt_disable_complete_event_param *event,
1303 void *context)
1304 {
1305 return QDF_STATUS_SUCCESS;
1306 }
1307
1308 static inline QDF_STATUS
mlme_twt_osif_ack_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_ack_complete_event_param * event,void * context)1309 mlme_twt_osif_ack_complete_ind(struct wlan_objmgr_psoc *psoc,
1310 struct twt_ack_complete_event_param *event,
1311 void *context)
1312 {
1313 return QDF_STATUS_SUCCESS;
1314 }
1315
1316 static inline QDF_STATUS
mlme_twt_osif_setup_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_add_dialog_complete_event * event,bool renego_fail)1317 mlme_twt_osif_setup_complete_ind(struct wlan_objmgr_psoc *psoc,
1318 struct twt_add_dialog_complete_event *event,
1319 bool renego_fail)
1320 {
1321 return QDF_STATUS_SUCCESS;
1322 }
1323
1324 static inline QDF_STATUS
mlme_twt_osif_teardown_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_del_dialog_complete_event_param * event)1325 mlme_twt_osif_teardown_complete_ind(struct wlan_objmgr_psoc *psoc,
1326 struct twt_del_dialog_complete_event_param *event)
1327 {
1328 return QDF_STATUS_SUCCESS;
1329 }
1330
1331 static inline QDF_STATUS
mlme_twt_osif_pause_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_pause_dialog_complete_event_param * event)1332 mlme_twt_osif_pause_complete_ind(struct wlan_objmgr_psoc *psoc,
1333 struct twt_pause_dialog_complete_event_param *event)
1334 {
1335 return QDF_STATUS_SUCCESS;
1336 }
1337
1338 static inline QDF_STATUS
mlme_twt_osif_resume_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_resume_dialog_complete_event_param * event)1339 mlme_twt_osif_resume_complete_ind(struct wlan_objmgr_psoc *psoc,
1340 struct twt_resume_dialog_complete_event_param *event)
1341 {
1342 return QDF_STATUS_SUCCESS;
1343 }
1344
1345 static inline QDF_STATUS
mlme_twt_osif_nudge_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_nudge_dialog_complete_event_param * event)1346 mlme_twt_osif_nudge_complete_ind(struct wlan_objmgr_psoc *psoc,
1347 struct twt_nudge_dialog_complete_event_param *event)
1348 {
1349 return QDF_STATUS_SUCCESS;
1350 }
1351
1352 static inline QDF_STATUS
mlme_twt_osif_notify_complete_ind(struct wlan_objmgr_psoc * psoc,struct twt_notify_event_param * event)1353 mlme_twt_osif_notify_complete_ind(struct wlan_objmgr_psoc *psoc,
1354 struct twt_notify_event_param *event)
1355 {
1356 return QDF_STATUS_SUCCESS;
1357 }
1358
1359 static inline QDF_STATUS
mlme_twt_vdev_create_notification(struct wlan_objmgr_vdev * vdev)1360 mlme_twt_vdev_create_notification(struct wlan_objmgr_vdev *vdev)
1361 {
1362 return QDF_STATUS_SUCCESS;
1363 }
1364
1365 static inline QDF_STATUS
mlme_twt_vdev_destroy_notification(struct wlan_objmgr_vdev * vdev)1366 mlme_twt_vdev_destroy_notification(struct wlan_objmgr_vdev *vdev)
1367 {
1368 return QDF_STATUS_SUCCESS;
1369 }
1370
1371 #endif /* WLAN_SUPPORT_TWT && WLAN_TWT_CONV_SUPPORTED */
1372
1373 /**
1374 * mlme_vdev_reconfig_timer_cb() - vdev ml reconfig timer callback
1375 * @arg: timer argument
1376 *
1377 * Return: None
1378 */
1379 void mlme_vdev_reconfig_timer_cb(void *arg);
1380
1381 /**
1382 * mlme_mlo_is_reconfig_reassoc_enable() - Get if reassoc on mlo reconfig link
1383 * add is enable
1384 * @psoc: Object manager psoc pointer
1385 *
1386 * Return: True if reassoc on mlo reconfig link add ie enable
1387 */
1388 bool mlme_mlo_is_reconfig_reassoc_enable(struct wlan_objmgr_psoc *psoc);
1389
1390 #ifdef WLAN_BOOST_CPU_FREQ_IN_ROAM
1391 /**
1392 * mlme_cm_osif_perfd_reset_cpufreq() - Function to reset CPU freq
1393 *
1394 * This function is to reset the CPU freq
1395 *
1396 * Return: None
1397 */
1398 void mlme_cm_osif_perfd_reset_cpufreq(void);
1399 #else
1400 static inline
mlme_cm_osif_perfd_reset_cpufreq(void)1401 void mlme_cm_osif_perfd_reset_cpufreq(void)
1402 {
1403 }
1404 #endif
1405
1406 #endif
1407