xref: /wlan-driver/qcacld-3.0/components/p2p/dispatcher/inc/wlan_p2p_ucfg_api.h (revision 5113495b16420b49004c444715d2daae2066e7dc)
1*5113495bSYour Name /*
2*5113495bSYour Name  * Copyright (c) 2017-2018, 2020-2021 The Linux Foundation. All rights reserved.
3*5113495bSYour Name  * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved.
4*5113495bSYour Name  *
5*5113495bSYour Name  * Permission to use, copy, modify, and/or distribute this software for
6*5113495bSYour Name  * any purpose with or without fee is hereby granted, provided that the
7*5113495bSYour Name  * above copyright notice and this permission notice appear in all
8*5113495bSYour Name  * copies.
9*5113495bSYour Name  *
10*5113495bSYour Name  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11*5113495bSYour Name  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12*5113495bSYour Name  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13*5113495bSYour Name  * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
14*5113495bSYour Name  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
15*5113495bSYour Name  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
16*5113495bSYour Name  * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*5113495bSYour Name  * PERFORMANCE OF THIS SOFTWARE.
18*5113495bSYour Name  */
19*5113495bSYour Name 
20*5113495bSYour Name /**
21*5113495bSYour Name  * DOC: Contains p2p north bound interface definitions
22*5113495bSYour Name  */
23*5113495bSYour Name 
24*5113495bSYour Name #ifndef _WLAN_P2P_UCFG_API_H_
25*5113495bSYour Name #define _WLAN_P2P_UCFG_API_H_
26*5113495bSYour Name 
27*5113495bSYour Name #include "wlan_p2p_cfg_api.h"
28*5113495bSYour Name #include <qdf_types.h>
29*5113495bSYour Name 
30*5113495bSYour Name struct wlan_objmgr_psoc;
31*5113495bSYour Name struct p2p_roc_req;
32*5113495bSYour Name struct p2p_event;
33*5113495bSYour Name struct p2p_rx_mgmt_frame;
34*5113495bSYour Name struct p2p_tx_cnf;
35*5113495bSYour Name struct p2p_mgmt_tx;
36*5113495bSYour Name struct p2p_ps_config;
37*5113495bSYour Name struct p2p_lo_start;
38*5113495bSYour Name struct p2p_lo_event;
39*5113495bSYour Name struct p2p_protocol_callbacks;
40*5113495bSYour Name struct mcc_quota_info;
41*5113495bSYour Name 
42*5113495bSYour Name /**
43*5113495bSYour Name  * typedef p2p_rx_callback() - Callback for rx mgmt frame
44*5113495bSYour Name  * @user_data: user data associated to this rx mgmt frame.
45*5113495bSYour Name  * @rx_frame: RX mgmt frame
46*5113495bSYour Name  *
47*5113495bSYour Name  * This callback will be used to give rx frames to hdd.
48*5113495bSYour Name  *
49*5113495bSYour Name  * Return: None
50*5113495bSYour Name  */
51*5113495bSYour Name typedef void (*p2p_rx_callback)(void *user_data,
52*5113495bSYour Name 	struct p2p_rx_mgmt_frame *rx_frame);
53*5113495bSYour Name 
54*5113495bSYour Name /**
55*5113495bSYour Name  * typedef p2p_action_tx_cnf_callback() - Callback for tx confirmation
56*5113495bSYour Name  * @user_data: user data associated to this tx confirmation
57*5113495bSYour Name  * @tx_cnf: tx confirmation information
58*5113495bSYour Name  *
59*5113495bSYour Name  * This callback will be used to give tx mgmt frame confirmation to
60*5113495bSYour Name  * hdd.
61*5113495bSYour Name  *
62*5113495bSYour Name  * Return: None
63*5113495bSYour Name  */
64*5113495bSYour Name typedef void (*p2p_action_tx_cnf_callback)(void *user_data,
65*5113495bSYour Name 	struct p2p_tx_cnf *tx_cnf);
66*5113495bSYour Name 
67*5113495bSYour Name /**
68*5113495bSYour Name  * typedef p2p_lo_event_callback() - Callback for listen offload event
69*5113495bSYour Name  * @user_data: user data associated to this lo event
70*5113495bSYour Name  * @p2p_lo_event: listen offload event information
71*5113495bSYour Name  *
72*5113495bSYour Name  * This callback will be used to give listen offload event to hdd.
73*5113495bSYour Name  *
74*5113495bSYour Name  * Return: None
75*5113495bSYour Name  */
76*5113495bSYour Name typedef void (*p2p_lo_event_callback)(void *user_data,
77*5113495bSYour Name 	struct p2p_lo_event *p2p_lo_event);
78*5113495bSYour Name 
79*5113495bSYour Name /**
80*5113495bSYour Name  * typedef p2p_event_callback() - Callback for P2P event
81*5113495bSYour Name  * @user_data: user data associated to this p2p event
82*5113495bSYour Name  * @p2p_event: p2p event information
83*5113495bSYour Name  *
84*5113495bSYour Name  * This callback will be used to give p2p event to hdd.
85*5113495bSYour Name  *
86*5113495bSYour Name  * Return: None
87*5113495bSYour Name  */
88*5113495bSYour Name typedef void (*p2p_event_callback)(void *user_data,
89*5113495bSYour Name 	struct p2p_event *p2p_event);
90*5113495bSYour Name 
91*5113495bSYour Name /**
92*5113495bSYour Name  * typedef mcc_quota_event_callback() - Callback for mcc quota
93*5113495bSYour Name  * @psoc: psoc object
94*5113495bSYour Name  * @vdev: vdev object
95*5113495bSYour Name  * @mcc_quota: mcc quota event information
96*5113495bSYour Name  *
97*5113495bSYour Name  * Callback to notify mcc quota event.
98*5113495bSYour Name  *
99*5113495bSYour Name  * Return: None
100*5113495bSYour Name  */
101*5113495bSYour Name typedef QDF_STATUS (*mcc_quota_event_callback)(struct wlan_objmgr_psoc *psoc,
102*5113495bSYour Name 					       struct wlan_objmgr_vdev *vdev,
103*5113495bSYour Name 					       struct mcc_quota_info *mcc_quota);
104*5113495bSYour Name 
105*5113495bSYour Name /**
106*5113495bSYour Name  * struct p2p_start_param - p2p soc start parameters. Below callbacks
107*5113495bSYour Name  *                          will be registered by the HDD
108*5113495bSYour Name  * @rx_cb:            Function pointer to hdd rx callback. This
109*5113495bSYour Name  *                    function will be used to give rx frames to hdd
110*5113495bSYour Name  * @rx_cb_data:       RX callback user data
111*5113495bSYour Name  * @event_cb:         Function pointer to hdd p2p event callback.
112*5113495bSYour Name  *                    This function will be used to give p2p event
113*5113495bSYour Name  *                    to hdd
114*5113495bSYour Name  * @event_cb_data:    Pointer to p2p event callback user data
115*5113495bSYour Name  * @tx_cnf_cb:        Function pointer to hdd tx confirm callback.
116*5113495bSYour Name  *                    This function will be used to give tx confirm
117*5113495bSYour Name  *                    to hdd
118*5113495bSYour Name  * @tx_cnf_cb_data:   Pointer to p2p tx confirm callback user data
119*5113495bSYour Name  * @lo_event_cb:      Function pointer to p2p listen offload
120*5113495bSYour Name  *                    callback. This function will be used to give
121*5113495bSYour Name  *                    listen offload stopped event to hdd
122*5113495bSYour Name  * @lo_event_cb_data: Pointer to p2p listen offload callback user data
123*5113495bSYour Name  */
124*5113495bSYour Name struct p2p_start_param {
125*5113495bSYour Name 	p2p_rx_callback rx_cb;
126*5113495bSYour Name 	void *rx_cb_data;
127*5113495bSYour Name 	p2p_event_callback event_cb;
128*5113495bSYour Name 	void *event_cb_data;
129*5113495bSYour Name 	p2p_action_tx_cnf_callback tx_cnf_cb;
130*5113495bSYour Name 	void *tx_cnf_cb_data;
131*5113495bSYour Name #ifdef FEATURE_P2P_LISTEN_OFFLOAD
132*5113495bSYour Name 	p2p_lo_event_callback lo_event_cb;
133*5113495bSYour Name 	void *lo_event_cb_data;
134*5113495bSYour Name #endif
135*5113495bSYour Name };
136*5113495bSYour Name 
137*5113495bSYour Name /**
138*5113495bSYour Name  * ucfg_p2p_init() - P2P component initialization
139*5113495bSYour Name  *
140*5113495bSYour Name  * This function gets called when dispatcher initializing.
141*5113495bSYour Name  *
142*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
143*5113495bSYour Name  */
144*5113495bSYour Name QDF_STATUS ucfg_p2p_init(void);
145*5113495bSYour Name 
146*5113495bSYour Name /**
147*5113495bSYour Name  * ucfg_p2p_deinit() - P2P component de-init
148*5113495bSYour Name  *
149*5113495bSYour Name  * This function gets called when dispatcher de-init.
150*5113495bSYour Name  *
151*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
152*5113495bSYour Name  */
153*5113495bSYour Name QDF_STATUS ucfg_p2p_deinit(void);
154*5113495bSYour Name 
155*5113495bSYour Name /**
156*5113495bSYour Name  * ucfg_p2p_psoc_open() - Open P2P component
157*5113495bSYour Name  * @soc: soc context
158*5113495bSYour Name  *
159*5113495bSYour Name  * This function gets called when dispatcher opening.
160*5113495bSYour Name  *
161*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
162*5113495bSYour Name  */
163*5113495bSYour Name QDF_STATUS ucfg_p2p_psoc_open(struct wlan_objmgr_psoc *soc);
164*5113495bSYour Name 
165*5113495bSYour Name /**
166*5113495bSYour Name  * ucfg_p2p_psoc_close() - Close P2P component
167*5113495bSYour Name  * @soc: soc context
168*5113495bSYour Name  *
169*5113495bSYour Name  * This function gets called when dispatcher closing.
170*5113495bSYour Name  *
171*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
172*5113495bSYour Name  */
173*5113495bSYour Name QDF_STATUS ucfg_p2p_psoc_close(struct wlan_objmgr_psoc *soc);
174*5113495bSYour Name 
175*5113495bSYour Name /**
176*5113495bSYour Name  * ucfg_p2p_psoc_start() - Start P2P component
177*5113495bSYour Name  * @soc: soc context
178*5113495bSYour Name  * @req: P2P start parameters
179*5113495bSYour Name  *
180*5113495bSYour Name  * This function gets called when up layer starting up.
181*5113495bSYour Name  *
182*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
183*5113495bSYour Name  */
184*5113495bSYour Name QDF_STATUS ucfg_p2p_psoc_start(struct wlan_objmgr_psoc *soc,
185*5113495bSYour Name 	struct p2p_start_param *req);
186*5113495bSYour Name 
187*5113495bSYour Name /**
188*5113495bSYour Name  * ucfg_p2p_psoc_stop() - Stop P2P component
189*5113495bSYour Name  * @soc: soc context
190*5113495bSYour Name  *
191*5113495bSYour Name  * This function gets called when up layer exit.
192*5113495bSYour Name  *
193*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
194*5113495bSYour Name  */
195*5113495bSYour Name QDF_STATUS ucfg_p2p_psoc_stop(struct wlan_objmgr_psoc *soc);
196*5113495bSYour Name 
197*5113495bSYour Name /**
198*5113495bSYour Name  * ucfg_p2p_roc_req() - Roc request
199*5113495bSYour Name  * @soc: soc context
200*5113495bSYour Name  * @roc_req: Roc request parameters
201*5113495bSYour Name  * @cookie: return cookie to caller
202*5113495bSYour Name  *
203*5113495bSYour Name  * This function delivers roc request to P2P component.
204*5113495bSYour Name  *
205*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
206*5113495bSYour Name  */
207*5113495bSYour Name QDF_STATUS ucfg_p2p_roc_req(struct wlan_objmgr_psoc *soc,
208*5113495bSYour Name 	struct p2p_roc_req *roc_req, uint64_t *cookie);
209*5113495bSYour Name 
210*5113495bSYour Name /**
211*5113495bSYour Name  * ucfg_p2p_roc_cancel_req() - Cancel roc request
212*5113495bSYour Name  * @soc: soc context
213*5113495bSYour Name  * @cookie: Find out the roc request by cookie
214*5113495bSYour Name  *
215*5113495bSYour Name  * This function delivers cancel roc request to P2P component.
216*5113495bSYour Name  *
217*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
218*5113495bSYour Name  */
219*5113495bSYour Name QDF_STATUS ucfg_p2p_roc_cancel_req(struct wlan_objmgr_psoc *soc,
220*5113495bSYour Name 	uint64_t cookie);
221*5113495bSYour Name 
222*5113495bSYour Name /**
223*5113495bSYour Name  * ucfg_p2p_cleanup_roc_by_vdev() - Cleanup roc request by vdev
224*5113495bSYour Name  * @vdev: pointer to vdev object
225*5113495bSYour Name  *
226*5113495bSYour Name  * This function call P2P API to cleanup roc request by vdev
227*5113495bSYour Name  *
228*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
229*5113495bSYour Name  */
230*5113495bSYour Name QDF_STATUS ucfg_p2p_cleanup_roc_by_vdev(struct wlan_objmgr_vdev *vdev);
231*5113495bSYour Name 
232*5113495bSYour Name /**
233*5113495bSYour Name  * ucfg_p2p_cleanup_roc_by_psoc() - Cleanup roc request by psoc
234*5113495bSYour Name  * @psoc: pointer to psoc object
235*5113495bSYour Name  *
236*5113495bSYour Name  * This function call P2P API to cleanup roc request by psoc
237*5113495bSYour Name  *
238*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
239*5113495bSYour Name  */
240*5113495bSYour Name QDF_STATUS ucfg_p2p_cleanup_roc_by_psoc(struct wlan_objmgr_psoc *psoc);
241*5113495bSYour Name 
242*5113495bSYour Name /**
243*5113495bSYour Name  * ucfg_p2p_cleanup_tx_by_vdev() - Cleanup tx request by vdev
244*5113495bSYour Name  * @vdev: pointer to vdev object
245*5113495bSYour Name  *
246*5113495bSYour Name  * This function call P2P API to cleanup tx action frame request by vdev
247*5113495bSYour Name  *
248*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
249*5113495bSYour Name  */
250*5113495bSYour Name QDF_STATUS ucfg_p2p_cleanup_tx_by_vdev(struct wlan_objmgr_vdev *vdev);
251*5113495bSYour Name 
252*5113495bSYour Name /**
253*5113495bSYour Name  * ucfg_p2p_cleanup_tx_by_psoc() - Cleanup tx request by psoc
254*5113495bSYour Name  * @psoc: pointer to psoc object
255*5113495bSYour Name  *
256*5113495bSYour Name  * This function call P2P API to cleanup tx action frame request by psoc
257*5113495bSYour Name  *
258*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
259*5113495bSYour Name  */
260*5113495bSYour Name QDF_STATUS ucfg_p2p_cleanup_tx_by_psoc(struct wlan_objmgr_psoc *psoc);
261*5113495bSYour Name 
262*5113495bSYour Name /**
263*5113495bSYour Name  * ucfg_p2p_mgmt_tx() - Mgmt frame tx request
264*5113495bSYour Name  * @soc: soc context
265*5113495bSYour Name  * @mgmt_frm: TX mgmt frame parameters
266*5113495bSYour Name  * @cookie: Return the cookie to caller
267*5113495bSYour Name  * @pdev: pdev object
268*5113495bSYour Name  *
269*5113495bSYour Name  * This function delivers mgmt frame tx request to P2P component.
270*5113495bSYour Name  *
271*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
272*5113495bSYour Name  */
273*5113495bSYour Name QDF_STATUS ucfg_p2p_mgmt_tx(struct wlan_objmgr_psoc *soc,
274*5113495bSYour Name 			    struct p2p_mgmt_tx *mgmt_frm,
275*5113495bSYour Name 			    uint64_t *cookie,
276*5113495bSYour Name 			    struct wlan_objmgr_pdev *pdev);
277*5113495bSYour Name 
278*5113495bSYour Name /**
279*5113495bSYour Name  * ucfg_p2p_mgmt_tx_cancel() - Cancel mgmt frame tx request
280*5113495bSYour Name  * @soc: soc context
281*5113495bSYour Name  * @vdev: vdev object
282*5113495bSYour Name  * @cookie: Find out the mgmt tx request by cookie
283*5113495bSYour Name  *
284*5113495bSYour Name  * This function delivers cancel mgmt frame tx request request to P2P
285*5113495bSYour Name  * component.
286*5113495bSYour Name  *
287*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
288*5113495bSYour Name  */
289*5113495bSYour Name QDF_STATUS ucfg_p2p_mgmt_tx_cancel(struct wlan_objmgr_psoc *soc,
290*5113495bSYour Name 	struct wlan_objmgr_vdev *vdev, uint64_t cookie);
291*5113495bSYour Name 
292*5113495bSYour Name /**
293*5113495bSYour Name  * ucfg_p2p_set_ps() - P2P set power save
294*5113495bSYour Name  * @soc: soc context
295*5113495bSYour Name  * @ps_config: power save configure
296*5113495bSYour Name  *
297*5113495bSYour Name  * This function delivers p2p power save request to P2P component.
298*5113495bSYour Name  *
299*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
300*5113495bSYour Name  */
301*5113495bSYour Name QDF_STATUS ucfg_p2p_set_ps(struct wlan_objmgr_psoc *soc,
302*5113495bSYour Name 	struct p2p_ps_config *ps_config);
303*5113495bSYour Name 
304*5113495bSYour Name #ifdef FEATURE_P2P_LISTEN_OFFLOAD
305*5113495bSYour Name /**
306*5113495bSYour Name  * ucfg_p2p_lo_start() - Listen offload start request
307*5113495bSYour Name  * @soc: soc context
308*5113495bSYour Name  * @p2p_lo_start: lo start parameters
309*5113495bSYour Name  *
310*5113495bSYour Name  * This function delivers listen offload start request to P2P
311*5113495bSYour Name  * component.
312*5113495bSYour Name  *
313*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
314*5113495bSYour Name  */
315*5113495bSYour Name QDF_STATUS ucfg_p2p_lo_start(struct wlan_objmgr_psoc *soc,
316*5113495bSYour Name 	struct p2p_lo_start *p2p_lo_start);
317*5113495bSYour Name 
318*5113495bSYour Name /**
319*5113495bSYour Name  * ucfg_p2p_lo_stop() - Listen offload stop request
320*5113495bSYour Name  * @soc: soc context
321*5113495bSYour Name  * @vdev_id: vdev id
322*5113495bSYour Name  *
323*5113495bSYour Name  * This function delivers listen offload stop request to P2P component.
324*5113495bSYour Name  *
325*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
326*5113495bSYour Name  */
327*5113495bSYour Name QDF_STATUS ucfg_p2p_lo_stop(struct wlan_objmgr_psoc *soc,
328*5113495bSYour Name 	uint32_t vdev_id);
329*5113495bSYour Name #endif
330*5113495bSYour Name 
331*5113495bSYour Name /**
332*5113495bSYour Name  * p2p_peer_authorized() - Process peer authorized event
333*5113495bSYour Name  * @vdev: vdev structure to which peer is associated
334*5113495bSYour Name  * @mac_addr: peer mac address
335*5113495bSYour Name  *
336*5113495bSYour Name  * This function handles disables noa whenever a legacy station
337*5113495bSYour Name  * complete 4-way handshake after association.
338*5113495bSYour Name  *
339*5113495bSYour Name  * Return: void
340*5113495bSYour Name  */
341*5113495bSYour Name void p2p_peer_authorized(struct wlan_objmgr_vdev *vdev, uint8_t *mac_addr);
342*5113495bSYour Name 
343*5113495bSYour Name /**
344*5113495bSYour Name  * ucfg_p2p_set_noa() - Disable/Enable NOA
345*5113495bSYour Name  * @soc: soc context
346*5113495bSYour Name  * @vdev_id: vdev id
347*5113495bSYour Name  * @disable_noa: TRUE - Disable NoA, FALSE - Enable NoA
348*5113495bSYour Name  *
349*5113495bSYour Name  * This function send wmi command to enable / disable NoA.
350*5113495bSYour Name  *
351*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
352*5113495bSYour Name  */
353*5113495bSYour Name QDF_STATUS ucfg_p2p_set_noa(struct wlan_objmgr_psoc *soc,
354*5113495bSYour Name 	uint32_t vdev_id, bool disable_noa);
355*5113495bSYour Name 
356*5113495bSYour Name /**
357*5113495bSYour Name  * ucfg_p2p_check_random_mac() - check random mac addr or not
358*5113495bSYour Name  * @soc: soc context
359*5113495bSYour Name  * @vdev_id: vdev id
360*5113495bSYour Name  * @random_mac_addr: mac addr to be checked
361*5113495bSYour Name  *
362*5113495bSYour Name  * This function check the input addr is random mac addr or not for vdev.
363*5113495bSYour Name  *
364*5113495bSYour Name  * Return: true if addr is random mac address else false.
365*5113495bSYour Name  */
366*5113495bSYour Name bool ucfg_p2p_check_random_mac(struct wlan_objmgr_psoc *soc, uint32_t vdev_id,
367*5113495bSYour Name 			       uint8_t *random_mac_addr);
368*5113495bSYour Name 
369*5113495bSYour Name /**
370*5113495bSYour Name  * ucfg_p2p_register_callbacks() - register p2p callbacks
371*5113495bSYour Name  * @soc: soc context
372*5113495bSYour Name  * @cb_obj: p2p_protocol_callbacks struct
373*5113495bSYour Name  *
374*5113495bSYour Name  * This function registers lim callbacks to p2p components to provide
375*5113495bSYour Name  * protocol information.
376*5113495bSYour Name  *
377*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
378*5113495bSYour Name  */
379*5113495bSYour Name QDF_STATUS ucfg_p2p_register_callbacks(struct wlan_objmgr_psoc *soc,
380*5113495bSYour Name 	    struct p2p_protocol_callbacks *cb_obj);
381*5113495bSYour Name 
382*5113495bSYour Name #ifdef WLAN_FEATURE_MCC_QUOTA
383*5113495bSYour Name /**
384*5113495bSYour Name  * ucfg_p2p_register_mcc_quota_event_os_if_cb() - Register OS IF mcc quota
385*5113495bSYour Name  * event callback
386*5113495bSYour Name  * @psoc: soc object
387*5113495bSYour Name  * @cb: os if callback for mcc quota event
388*5113495bSYour Name  *
389*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS for success
390*5113495bSYour Name  */
391*5113495bSYour Name QDF_STATUS
392*5113495bSYour Name ucfg_p2p_register_mcc_quota_event_os_if_cb(struct wlan_objmgr_psoc *psoc,
393*5113495bSYour Name 					   mcc_quota_event_callback cb);
394*5113495bSYour Name #else
395*5113495bSYour Name static inline QDF_STATUS
ucfg_p2p_register_mcc_quota_event_os_if_cb(struct wlan_objmgr_psoc * psoc,mcc_quota_event_callback cb)396*5113495bSYour Name ucfg_p2p_register_mcc_quota_event_os_if_cb(struct wlan_objmgr_psoc *psoc,
397*5113495bSYour Name 					   mcc_quota_event_callback cb)
398*5113495bSYour Name {
399*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
400*5113495bSYour Name }
401*5113495bSYour Name #endif
402*5113495bSYour Name 
403*5113495bSYour Name /**
404*5113495bSYour Name  * ucfg_p2p_status_scan() - Show P2P connection status when scanning
405*5113495bSYour Name  * @vdev: vdev context
406*5113495bSYour Name  *
407*5113495bSYour Name  * This function shows P2P connection status when scanning.
408*5113495bSYour Name  *
409*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
410*5113495bSYour Name  */
411*5113495bSYour Name QDF_STATUS ucfg_p2p_status_scan(struct wlan_objmgr_vdev *vdev);
412*5113495bSYour Name 
413*5113495bSYour Name /**
414*5113495bSYour Name  * ucfg_p2p_status_connect() - Update P2P connection status
415*5113495bSYour Name  * @vdev:        vdev context
416*5113495bSYour Name  *
417*5113495bSYour Name  * Updates P2P connection status by up layer when connecting.
418*5113495bSYour Name  *
419*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
420*5113495bSYour Name  */
421*5113495bSYour Name QDF_STATUS ucfg_p2p_status_connect(struct wlan_objmgr_vdev *vdev);
422*5113495bSYour Name 
423*5113495bSYour Name /**
424*5113495bSYour Name  * ucfg_p2p_status_disconnect() - Update P2P connection status
425*5113495bSYour Name  * @vdev:        vdev context
426*5113495bSYour Name  *
427*5113495bSYour Name  * Updates P2P connection status by up layer when disconnecting.
428*5113495bSYour Name  *
429*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
430*5113495bSYour Name  */
431*5113495bSYour Name QDF_STATUS ucfg_p2p_status_disconnect(struct wlan_objmgr_vdev *vdev);
432*5113495bSYour Name 
433*5113495bSYour Name /**
434*5113495bSYour Name  * ucfg_p2p_status_start_bss() - Update P2P connection status
435*5113495bSYour Name  * @vdev:        vdev context
436*5113495bSYour Name  *
437*5113495bSYour Name  * Updates P2P connection status by up layer when starting bss.
438*5113495bSYour Name  *
439*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
440*5113495bSYour Name  */
441*5113495bSYour Name QDF_STATUS ucfg_p2p_status_start_bss(struct wlan_objmgr_vdev *vdev);
442*5113495bSYour Name 
443*5113495bSYour Name /**
444*5113495bSYour Name  * ucfg_p2p_status_stop_bss() - Update P2P connection status
445*5113495bSYour Name  * @vdev:        vdev context
446*5113495bSYour Name  *
447*5113495bSYour Name  * Updates P2P connection status by up layer when stopping bss.
448*5113495bSYour Name  *
449*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - in case of success
450*5113495bSYour Name  */
451*5113495bSYour Name QDF_STATUS ucfg_p2p_status_stop_bss(struct wlan_objmgr_vdev *vdev);
452*5113495bSYour Name 
453*5113495bSYour Name /**
454*5113495bSYour Name  * ucfg_p2p_is_roam_config_disabled() - Roam disable config during p2p
455*5113495bSYour Name  * connection
456*5113495bSYour Name  * @psoc: psoc context
457*5113495bSYour Name  *
458*5113495bSYour Name  * During P2P connection disable roam on STA interface
459*5113495bSYour Name  *
460*5113495bSYour Name  * Return: p2p disable roam - in case of success else false
461*5113495bSYour Name  */
462*5113495bSYour Name static inline
ucfg_p2p_is_roam_config_disabled(struct wlan_objmgr_psoc * psoc)463*5113495bSYour Name bool ucfg_p2p_is_roam_config_disabled(struct wlan_objmgr_psoc *psoc)
464*5113495bSYour Name {
465*5113495bSYour Name 	return cfg_p2p_is_roam_config_disabled(psoc);
466*5113495bSYour Name }
467*5113495bSYour Name 
468*5113495bSYour Name /**
469*5113495bSYour Name  * ucfg_p2p_get_indoor_ch_support() - Get indoor channel support
470*5113495bSYour Name  * for P2P GO
471*5113495bSYour Name  *
472*5113495bSYour Name  * @psoc: pointer to psoc obj
473*5113495bSYour Name  *
474*5113495bSYour Name  * Get the indoor channel support for P2P GO
475*5113495bSYour Name  *
476*5113495bSYour Name  * Return: p2p go supported on indoor channel
477*5113495bSYour Name  */
478*5113495bSYour Name bool ucfg_p2p_get_indoor_ch_support(struct wlan_objmgr_psoc *psoc);
479*5113495bSYour Name 
480*5113495bSYour Name #ifdef WLAN_FEATURE_DYNAMIC_MAC_ADDR_UPDATE
481*5113495bSYour Name /**
482*5113495bSYour Name  * ucfg_is_p2p_device_dynamic_set_mac_addr_supported() - API to check P2P device
483*5113495bSYour Name  * dynamic MAC address update is supported or not
484*5113495bSYour Name  *
485*5113495bSYour Name  * @psoc: Pointer to psoc
486*5113495bSYour Name  *
487*5113495bSYour Name  * Return: true or false
488*5113495bSYour Name  */
489*5113495bSYour Name bool
490*5113495bSYour Name ucfg_is_p2p_device_dynamic_set_mac_addr_supported(struct wlan_objmgr_psoc *psoc);
491*5113495bSYour Name #else
492*5113495bSYour Name static inline bool
ucfg_is_p2p_device_dynamic_set_mac_addr_supported(struct wlan_objmgr_psoc * psoc)493*5113495bSYour Name ucfg_is_p2p_device_dynamic_set_mac_addr_supported(struct wlan_objmgr_psoc *psoc)
494*5113495bSYour Name {
495*5113495bSYour Name 	return false;
496*5113495bSYour Name }
497*5113495bSYour Name #endif
498*5113495bSYour Name #endif /* _WLAN_P2P_UCFG_API_H_ */
499