cdp_txrx_mscs.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2020-2021 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. /**
  19. * @file cdp_txrx_mscs.h
  20. * @brief Define the host data path MSCS API functions
  21. * called by the host control SW and the OS interface module
  22. */
  23. #ifndef _CDP_TXRX_MSCS_H_
  24. #define _CDP_TXRX_MSCS_H_
  25. #include "cdp_txrx_handle.h"
  26. #ifdef WLAN_SUPPORT_MSCS
  27. /**
  28. * @brief find MSCS enabled peer for this mac address and validate priority
  29. * @details
  30. * This function checks if there is a peer for this mac adress with MSCS
  31. * enabled flag set and nbuf priority is valid from user priority bitmap.
  32. *
  33. * @param src_mac - source mac address of peer
  34. * @param dst_mac - destination mac address of peer
  35. * @param nbuf - nbuf pointer
  36. * @return - 0 for non error case, 1 for failure
  37. */
  38. static inline int
  39. cdp_mscs_peer_lookup_n_get_priority(ol_txrx_soc_handle soc,
  40. uint8_t *src_mac, uint8_t *dst_mac,
  41. qdf_nbuf_t nbuf)
  42. {
  43. if (!soc || !soc->ops || !soc->ops->mscs_ops) {
  44. QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_FATAL,
  45. "%s invalid instance", __func__);
  46. return 1;
  47. }
  48. if (soc->ops->mscs_ops->mscs_peer_lookup_n_get_priority)
  49. return soc->ops->mscs_ops->mscs_peer_lookup_n_get_priority(soc,
  50. src_mac, dst_mac, nbuf);
  51. return 0;
  52. }
  53. #endif
  54. #endif