123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735 |
- /*
- * Copyright (c) 2016-2018 The Linux Foundation. All rights reserved.
- *
- * Permission to use, copy, modify, and/or distribute this software for
- * any purpose with or without fee is hereby granted, provided that the
- * above copyright notice and this permission notice appear in all
- * copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
- * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
- * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
- * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
- * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
- * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
- * PERFORMANCE OF THIS SOFTWARE.
- */
- /**
- * @file cdp_txrx_ctrl.h
- * @brief Define the host data path control API functions
- * called by the host control SW and the OS interface module
- */
- #ifndef _CDP_TXRX_CTRL_H_
- #define _CDP_TXRX_CTRL_H_
- #include "cdp_txrx_handle.h"
- #include "cdp_txrx_cmn_struct.h"
- #include "cdp_txrx_ops.h"
- static inline int cdp_is_target_ar900b
- (ol_txrx_soc_handle soc, struct cdp_vdev *vdev)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_is_target_ar900b)
- return 0;
- return soc->ops->ctrl_ops->txrx_is_target_ar900b(vdev);
- }
- /* WIN */
- static inline int
- cdp_mempools_attach(ol_txrx_soc_handle soc, void *ctrl_pdev)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_mempools_attach)
- return 0;
- return soc->ops->ctrl_ops->txrx_mempools_attach(ctrl_pdev);
- }
- /**
- * @brief set filter neighbour peers
- * @details
- * This defines interface function to set neighbour peer filtering.
- *
- * @param soc - the pointer to soc object
- * @param pdev - the pointer physical device object
- * @param val - the enable/disable value
- * @return - int
- */
- static inline int
- cdp_set_filter_neighbour_peers(ol_txrx_soc_handle soc,
- struct cdp_pdev *pdev, u_int32_t val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_filter_neighbour_peers)
- return 0;
- return soc->ops->ctrl_ops->txrx_set_filter_neighbour_peers
- (pdev, val);
- }
- /**
- * @brief update the neighbour peer addresses
- * @details
- * This defines interface function to update neighbour peers addresses
- * which needs to be filtered
- *
- * @param soc - the pointer to soc object
- * @param vdev - the pointer to vdev
- * @param cmd - add/del entry into peer table
- * @param macaddr - the address of neighbour peer
- * @return - int
- */
- static inline int
- cdp_update_filter_neighbour_peers(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, uint32_t cmd, uint8_t *macaddr)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_update_filter_neighbour_peers)
- return 0;
- return soc->ops->ctrl_ops->txrx_update_filter_neighbour_peers
- (vdev, cmd, macaddr);
- }
- /**
- * @brief set the safemode of the device
- * @details
- * This flag is used to bypass the encrypt and decrypt processes when send and
- * receive packets. It works like open AUTH mode, HW will treate all packets
- * as non-encrypt frames because no key installed. For rx fragmented frames,
- * it bypasses all the rx defragmentaion.
- *
- * @param vdev - the data virtual device object
- * @param val - the safemode state
- * @return - void
- */
- static inline void
- cdp_set_safemode(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, u_int32_t val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_safemode)
- return;
- soc->ops->ctrl_ops->txrx_set_safemode(vdev, val);
- }
- /**
- * @brief configure the drop unencrypted frame flag
- * @details
- * Rx related. When set this flag, all the unencrypted frames
- * received over a secure connection will be discarded
- *
- * @param vdev - the data virtual device object
- * @param val - flag
- * @return - void
- */
- static inline void
- cdp_set_drop_unenc(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, u_int32_t val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_drop_unenc)
- return;
- soc->ops->ctrl_ops->txrx_set_drop_unenc(vdev, val);
- }
- /**
- * @brief set the Tx encapsulation type of the VDEV
- * @details
- * This will be used to populate the HTT desc packet type field during Tx
- *
- * @param vdev - the data virtual device object
- * @param val - the Tx encap type (htt_cmn_pkt_type)
- * @return - void
- */
- static inline void
- cdp_set_tx_encap_type(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, enum htt_cmn_pkt_type val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_tx_encap_type)
- return;
- soc->ops->ctrl_ops->txrx_set_tx_encap_type(vdev, val);
- }
- /**
- * @brief set the Rx decapsulation type of the VDEV
- * @details
- * This will be used to configure into firmware and hardware which format to
- * decap all Rx packets into, for all peers under the VDEV.
- *
- * @param vdev - the data virtual device object
- * @param val - the Rx decap mode (htt_cmn_pkt_type)
- * @return - void
- */
- static inline void
- cdp_set_vdev_rx_decap_type(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, enum htt_cmn_pkt_type val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_vdev_rx_decap_type)
- return;
- soc->ops->ctrl_ops->txrx_set_vdev_rx_decap_type
- (vdev, val);
- }
- /**
- * @brief get the Rx decapsulation type of the VDEV
- *
- * @param vdev - the data virtual device object
- * @return - the Rx decap type (htt_cmn_pkt_type)
- */
- static inline enum htt_cmn_pkt_type
- cdp_get_vdev_rx_decap_type(ol_txrx_soc_handle soc, struct cdp_vdev *vdev)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_get_vdev_rx_decap_type)
- return 0;
- return soc->ops->ctrl_ops->txrx_get_vdev_rx_decap_type(vdev);
- }
- /**
- * @brief set the Reo Destination ring for the pdev
- * @details
- * This will be used to configure the Reo Destination ring for this pdev.
- *
- * @param soc - pointer to the soc
- * @param pdev - the data physical device object
- * @param val - the Reo destination ring index (1 to 4)
- * @return - void
- */
- static inline void
- cdp_set_pdev_reo_dest(ol_txrx_soc_handle soc,
- struct cdp_pdev *pdev, enum cdp_host_reo_dest_ring val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_pdev_reo_dest)
- return;
- soc->ops->ctrl_ops->txrx_set_pdev_reo_dest
- (pdev, val);
- }
- /**
- * @brief get the Reo Destination ring for the pdev
- *
- * @param soc - pointer to the soc
- * @param pdev - the data physical device object
- * @return - the Reo destination ring index (1 to 4), 0 if not supported.
- */
- static inline enum cdp_host_reo_dest_ring
- cdp_get_pdev_reo_dest(ol_txrx_soc_handle soc, struct cdp_pdev *pdev)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return cdp_host_reo_dest_ring_unknown;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_get_pdev_reo_dest)
- return cdp_host_reo_dest_ring_unknown;
- return soc->ops->ctrl_ops->txrx_get_pdev_reo_dest(pdev);
- }
- /* Is this similar to ol_txrx_peer_state_update() in MCL */
- /**
- * @brief Update the authorize peer object at association time
- * @details
- * For the host-based implementation of rate-control, it
- * updates the peer/node-related parameters within rate-control
- * context of the peer at association.
- *
- * @param peer - pointer to the node's object
- * @authorize - either to authorize or unauthorize peer
- *
- * @return none
- */
- static inline void
- cdp_peer_authorize(ol_txrx_soc_handle soc,
- struct cdp_peer *peer, u_int32_t authorize)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_peer_authorize)
- return;
- soc->ops->ctrl_ops->txrx_peer_authorize
- (peer, authorize);
- }
- /* Should be ol_txrx_ctrl_api.h */
- static inline void cdp_set_mesh_mode
- (ol_txrx_soc_handle soc, struct cdp_vdev *vdev, u_int32_t val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_mesh_mode)
- return;
- soc->ops->ctrl_ops->txrx_set_mesh_mode(vdev, val);
- }
- /**
- * @brief set mesh rx filter
- * @details based on the bits enabled in the filter packets has to be dropped.
- *
- * @param soc - pointer to the soc
- * @param vdev - the data virtual device object
- * @param val - value to be set
- * @return - void
- */
- static inline
- void cdp_set_mesh_rx_filter(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, uint32_t val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_mesh_rx_filter)
- return;
- soc->ops->ctrl_ops->txrx_set_mesh_rx_filter(vdev, val);
- }
- static inline void cdp_tx_flush_buffers
- (ol_txrx_soc_handle soc, struct cdp_vdev *vdev)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->tx_flush_buffers)
- return;
- soc->ops->ctrl_ops->tx_flush_buffers(vdev);
- }
- static inline uint32_t cdp_txrx_get_vdev_param(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev,
- enum cdp_vdev_param_type type)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return -1;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_get_vdev_param) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: callback not registered:", __func__);
- return -1;
- }
- return soc->ops->ctrl_ops->txrx_get_vdev_param(vdev, type);
- }
- static inline void cdp_txrx_set_vdev_param(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, enum cdp_vdev_param_type type,
- uint32_t val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_vdev_param)
- return;
- soc->ops->ctrl_ops->txrx_set_vdev_param(vdev, type, val);
- }
- static inline void
- cdp_peer_set_nawds(ol_txrx_soc_handle soc,
- struct cdp_peer *peer, uint8_t value)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_peer_set_nawds)
- return;
- soc->ops->ctrl_ops->txrx_peer_set_nawds
- (peer, value);
- }
- /**
- * cdp_txrx_set_pdev_param() - set pdev parameter
- * @soc: opaque soc handle
- * @pdev: data path pdev handle
- * @type: param type
- * @val: value of pdev_tx_capture
- *
- * Return: status: 0 - Success, non-zero: Failure
- */
- static inline QDF_STATUS cdp_txrx_set_pdev_param(ol_txrx_soc_handle soc,
- struct cdp_pdev *pdev,
- enum cdp_pdev_param_type type,
- uint8_t val)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return QDF_STATUS_SUCCESS;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_set_pdev_param)
- return QDF_STATUS_SUCCESS;
- return soc->ops->ctrl_ops->txrx_set_pdev_param
- (pdev, type, val);
- }
- /**
- * cdp_enable_peer_based_pktlog()- Set flag in peer structure
- *
- * @soc: pointer to the soc
- * @pdev: the data physical device object
- * @enable: enable or disable peer based filter based pktlog
- * @peer_macaddr: Mac address of peer which needs to be
- * filtered
- *
- * This function will set flag in peer structure if peer based filtering
- * is enabled for pktlog
- *
- * Return: int
- */
- static inline int
- cdp_enable_peer_based_pktlog(ol_txrx_soc_handle soc,
- struct cdp_pdev *pdev, char *peer_macaddr,
- uint8_t enable)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE_ERROR(QDF_MODULE_ID_DP,
- "%s invalid instance", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->enable_peer_based_pktlog)
- return 0;
- return soc->ops->ctrl_ops->enable_peer_based_pktlog
- (pdev, peer_macaddr, enable);
- }
- /**
- * @brief Subscribe to a specified WDI event.
- * @details
- * This function adds the provided wdi_event_subscribe object to a list of
- * subscribers for the specified WDI event.
- * When the event in question happens, each subscriber for the event will
- * have their callback function invoked.
- * The order in which callback functions from multiple subscribers are
- * invoked is unspecified.
- *
- * @param soc - pointer to the soc
- * @param pdev - the data physical device object
- * @param event_cb_sub - the callback and context for the event subscriber
- * @param event - which event's notifications are being subscribed to
- * @return - int
- */
- static inline int
- cdp_wdi_event_sub(ol_txrx_soc_handle soc,
- struct cdp_pdev *pdev, void *event_cb_sub, uint32_t event)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_DEBUG,
- "%s invalid instance", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_wdi_event_sub)
- return 0;
- return soc->ops->ctrl_ops->txrx_wdi_event_sub
- (pdev, event_cb_sub, event);
- }
- /**
- * @brief Unsubscribe from a specified WDI event.
- * @details
- * This function removes the provided event subscription object from the
- * list of subscribers for its event.
- * This function shall only be called if there was a successful prior call
- * to event_sub() on the same wdi_event_subscribe object.
- *
- * @param soc - pointer to the soc
- * @param pdev - the data physical device object
- * @param event_cb_sub - the callback and context for the event subscriber
- * @param event - which event's notifications are being subscribed to
- * @return - int
- */
- static inline int
- cdp_wdi_event_unsub(ol_txrx_soc_handle soc,
- struct cdp_pdev *pdev, void *event_cb_sub, uint32_t event)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_DEBUG,
- "%s invalid instance", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_wdi_event_unsub)
- return 0;
- return soc->ops->ctrl_ops->txrx_wdi_event_unsub
- (pdev, event_cb_sub, event);
- }
- /**
- * @brief Get security type from the from peer.
- * @details
- * This function gets the Security information from the peer handler.
- * The security information is got from the rx descriptor and filled in
- * to the peer handler.
- *
- * @param soc - pointer to the soc
- * @param peer - peer handler
- * @param sec_idx - mcast or ucast frame type.
- * @return - int
- */
- static inline int
- cdp_get_sec_type(ol_txrx_soc_handle soc, struct cdp_peer *peer, uint8_t sec_idx)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_DEBUG,
- "%s invalid instance", __func__);
- QDF_BUG(0);
- return A_ERROR;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_get_sec_type)
- return A_ERROR;
- return soc->ops->ctrl_ops->txrx_get_sec_type
- (peer, sec_idx);
- }
- /**
- * cdp_set_mgmt_tx_power(): function to set tx power for mgmt frames
- * @vdev_handle: vdev handle
- * @subtype_index: subtype
- * @tx_power: Tx power
- * Return: None
- */
- static inline int cdp_set_mgmt_tx_power(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, uint8_t subtype, uint8_t tx_power)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_CDP, QDF_TRACE_LEVEL_DEBUG,
- "%s: Invalid Instance:", __func__);
- QDF_BUG(0);
- return 0;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_update_mgmt_txpow_vdev)
- return 0;
- soc->ops->ctrl_ops->txrx_update_mgmt_txpow_vdev(vdev,
- subtype, tx_power);
- return 0;
- }
- static inline void *
- cdp_get_pldev(ol_txrx_soc_handle soc,
- struct cdp_pdev *pdev)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_FATAL,
- "%s invalid instance", __func__);
- QDF_BUG(0);
- return NULL;
- }
- if (!soc->ops->ctrl_ops || !soc->ops->ctrl_ops->txrx_get_pldev)
- return NULL;
- return soc->ops->ctrl_ops->txrx_get_pldev(pdev);
- }
- #ifdef ATH_SUPPORT_NAC_RSSI
- /**
- * cdp_vdev_config_for_nac_rssi(): To invoke dp callback for nac rssi config
- * @soc: soc pointer
- * @vdev: vdev pointer
- * @nac_cmd: specfies nac_rss config action add, del, list
- * @bssid: Neighbour bssid
- * @client_macaddr: Non-Associated client MAC
- * @chan_num: channel number to scan
- *
- * Return: QDF_STATUS
- */
- static inline QDF_STATUS cdp_vdev_config_for_nac_rssi(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev, enum cdp_nac_param_cmd nac_cmd,
- char *bssid, char *client_macaddr, uint8_t chan_num)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_FATAL,
- "%s invalid instance", __func__);
- QDF_BUG(0);
- return QDF_STATUS_E_FAILURE;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_vdev_config_for_nac_rssi)
- return QDF_STATUS_E_FAILURE;
- return soc->ops->ctrl_ops->txrx_vdev_config_for_nac_rssi(vdev,
- nac_cmd, bssid, client_macaddr, chan_num);
- }
- /*
- * cdp_vdev_get_neighbour_rssi(): To invoke dp callback to get rssi value of nac
- * @soc: soc pointer
- * @vdev: vdev pointer
- * @macaddr: Non-Associated client MAC
- * @rssi: rssi
- *
- * Return: QDF_STATUS
- */
- static inline QDF_STATUS cdp_vdev_get_neighbour_rssi(ol_txrx_soc_handle soc,
- struct cdp_vdev *vdev,
- char *macaddr,
- uint8_t *rssi)
- {
- if (!soc || !soc->ops) {
- QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_FATAL,
- "%s invalid instance", __func__);
- QDF_BUG(0);
- return QDF_STATUS_E_FAILURE;
- }
- if (!soc->ops->ctrl_ops ||
- !soc->ops->ctrl_ops->txrx_vdev_get_neighbour_rssi)
- return QDF_STATUS_E_FAILURE;
- return soc->ops->ctrl_ops->txrx_vdev_get_neighbour_rssi(vdev, macaddr,
- rssi);
- }
- #endif
- #endif
|