1*5113495bSYour Name /*
2*5113495bSYour Name * Copyright (c) 2016-2017, 2019 The Linux Foundation. All rights reserved.
3*5113495bSYour Name * Copyright (c) 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 #ifndef _CDP_TXRX_OCB_H_
21*5113495bSYour Name #define _CDP_TXRX_OCB_H_
22*5113495bSYour Name #include <cdp_txrx_mob_def.h>
23*5113495bSYour Name #include "cdp_txrx_handle.h"
24*5113495bSYour Name /**
25*5113495bSYour Name * cdp_set_ocb_chan_info() - set OCB channel info to vdev.
26*5113495bSYour Name * @soc: data path soc handle
27*5113495bSYour Name * @vdev_id: vdev_id corresponding to vdev start
28*5113495bSYour Name * @ocb_set_chan: OCB channel information to be set in vdev.
29*5113495bSYour Name *
30*5113495bSYour Name * Return: NONE
31*5113495bSYour Name */
32*5113495bSYour Name static inline void
cdp_set_ocb_chan_info(ol_txrx_soc_handle soc,uint8_t vdev_id,struct ol_txrx_ocb_set_chan ocb_set_chan)33*5113495bSYour Name cdp_set_ocb_chan_info(ol_txrx_soc_handle soc, uint8_t vdev_id,
34*5113495bSYour Name struct ol_txrx_ocb_set_chan ocb_set_chan)
35*5113495bSYour Name {
36*5113495bSYour Name if (!soc || !soc->ops || !soc->ops->ocb_ops) {
37*5113495bSYour Name QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_FATAL,
38*5113495bSYour Name "%s invalid instance", __func__);
39*5113495bSYour Name return;
40*5113495bSYour Name }
41*5113495bSYour Name
42*5113495bSYour Name if (soc->ops->ocb_ops->set_ocb_chan_info)
43*5113495bSYour Name soc->ops->ocb_ops->set_ocb_chan_info(soc, vdev_id,
44*5113495bSYour Name ocb_set_chan);
45*5113495bSYour Name
46*5113495bSYour Name }
47*5113495bSYour Name /**
48*5113495bSYour Name * cdp_get_ocb_chan_info() - return handle to vdev ocb_channel_info
49*5113495bSYour Name * @soc: data path soc handle
50*5113495bSYour Name * @vdev_id: vdev_id corresponding to vdev start
51*5113495bSYour Name *
52*5113495bSYour Name * Return: handle to struct ol_txrx_ocb_chan_info
53*5113495bSYour Name */
54*5113495bSYour Name static inline struct ol_txrx_ocb_chan_info *
cdp_get_ocb_chan_info(ol_txrx_soc_handle soc,uint8_t vdev_id)55*5113495bSYour Name cdp_get_ocb_chan_info(ol_txrx_soc_handle soc, uint8_t vdev_id)
56*5113495bSYour Name {
57*5113495bSYour Name if (!soc || !soc->ops || !soc->ops->ocb_ops) {
58*5113495bSYour Name QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_FATAL,
59*5113495bSYour Name "%s invalid instance", __func__);
60*5113495bSYour Name return NULL;
61*5113495bSYour Name }
62*5113495bSYour Name
63*5113495bSYour Name if (soc->ops->ocb_ops->get_ocb_chan_info)
64*5113495bSYour Name return soc->ops->ocb_ops->get_ocb_chan_info(soc, vdev_id);
65*5113495bSYour Name
66*5113495bSYour Name return NULL;
67*5113495bSYour Name }
68*5113495bSYour Name #endif /* _CDP_TXRX_OCB_H_ */
69