target_if_dp.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /*
  2. * Copyright (c) 2018-2019 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. * DOC: This target interface shall be used by DP
  20. * to communicate with target using WMI.
  21. */
  22. #ifndef _WLAN_TARGET_IF_DP_H_
  23. #define _WLAN_TARGET_IF_DP_H_
  24. #include <qdf_types.h>
  25. #include <qdf_status.h>
  26. #include <wmi_unified_priv.h>
  27. #include <wlan_objmgr_psoc_obj.h>
  28. #include <target_if.h>
  29. #include <cdp_txrx_ops.h>
  30. /**
  31. * struct reorder_q_setup - reorder queue setup params
  32. * @psoc: psoc
  33. * @vdev_id: vdev id
  34. * @pdev_id: pdev id
  35. * @peer_macaddr: peer mac address
  36. * @hw_qdesc: hw queue descriptor
  37. * @tid: tid number
  38. * @queue_no: queue number
  39. * @ba_window_size_valid: BA window size validity flag
  40. * @ba_window_size: BA window size
  41. */
  42. struct reorder_q_setup {
  43. struct cdp_ctrl_objmgr_psoc *psoc;
  44. uint8_t vdev_id;
  45. uint8_t pdev_id;
  46. uint8_t peer_mac[QDF_MAC_ADDR_SIZE];
  47. qdf_dma_addr_t hw_qdesc_paddr;
  48. uint8_t tid;
  49. uint16_t queue_no;
  50. uint8_t ba_window_size_valid;
  51. uint16_t ba_window_size;
  52. };
  53. /**
  54. * target_if_peer_set_default_routing() - set peer default routing
  55. * @psoc: psoc pointer
  56. * @pdev_id: pdev id
  57. * @peer_macaddr: peer mac address
  58. * @vdev_id: vdev id
  59. * @hash_based: hash based routing
  60. * @ring_num: ring number
  61. *
  62. * return: void
  63. */
  64. void
  65. target_if_peer_set_default_routing(struct cdp_ctrl_objmgr_psoc *psoc,
  66. uint8_t pdev_id,
  67. uint8_t *peer_macaddr, uint8_t vdev_id,
  68. bool hash_based, uint8_t ring_num);
  69. /**
  70. * target_if_peer_rx_reorder_queue_setup() - setup rx reorder queue
  71. * @pdev: pdev pointer
  72. * @pdev_id: pdev id
  73. * @vdev_id: vdev id
  74. * @peer_macaddr: peer mac address
  75. * @hw_qdesc: hw queue descriptor
  76. * @tid: tid number
  77. * @queue_no: queue number
  78. * @ba_window_size_valid: BA window size validity flag
  79. * @ba_window_size: BA window size
  80. *
  81. * return: QDF_STATUS_SUCCESS for success or error code
  82. */
  83. QDF_STATUS
  84. target_if_peer_rx_reorder_queue_setup(struct cdp_ctrl_objmgr_psoc *psoc,
  85. uint8_t pdev_id,
  86. uint8_t vdev_id, uint8_t *peer_macaddr,
  87. qdf_dma_addr_t hw_qdesc, int tid,
  88. uint16_t queue_no,
  89. uint8_t ba_window_size_valid,
  90. uint16_t ba_window_size);
  91. /**
  92. * target_if_peer_rx_reorder_queue_remove() - remove rx reorder queue
  93. * @psoc: psoc pointer
  94. * @pdev_id: pdev id
  95. * @vdev_id: vdev id
  96. * @peer_macaddr: peer mac address
  97. * @peer_tid_bitmap: peer tid bitmap
  98. *
  99. * return: QDF_STATUS_SUCCESS for success or error code
  100. */
  101. QDF_STATUS
  102. target_if_peer_rx_reorder_queue_remove(struct cdp_ctrl_objmgr_psoc *psoc,
  103. uint8_t pdev_id,
  104. uint8_t vdev_id, uint8_t *peer_macaddr,
  105. uint32_t peer_tid_bitmap);
  106. /**
  107. * target_if_lro_hash_config() - send LRO hash config to FW
  108. * @psoc_handle: psoc handle pointer
  109. * @lro_hash_cfg: LRO hash config parameters
  110. *
  111. * return: QDF_STATUS_SUCCESS for success or error code
  112. */
  113. QDF_STATUS
  114. target_if_lro_hash_config(struct cdp_ctrl_objmgr_psoc *psoc, uint8_t pdev_id,
  115. struct cdp_lro_hash_config *lro_hash_cfg);
  116. #endif