wmi_unified_p2p_api.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /*
  2. * Copyright (c) 2013-2019 The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for
  6. * any purpose with or without fee is hereby granted, provided that the
  7. * above copyright notice and this permission notice appear in all
  8. * copies.
  9. *
  10. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  11. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  12. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  13. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  14. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  15. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  16. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  17. * PERFORMANCE OF THIS SOFTWARE.
  18. */
  19. /**
  20. * DOC: Implement API's specific to P2P component.
  21. */
  22. #ifndef _WMI_UNIFIED_P2P_API_H_
  23. #define _WMI_UNIFIED_P2P_API_H_
  24. #include <wlan_p2p_public_struct.h>
  25. /**
  26. * wmi_unified_set_p2pgo_oppps_req() - send p2p go opp power save request to fw
  27. * @wmi_handle: wmi handle
  28. * @oppps: p2p opp power save parameters
  29. *
  30. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  31. */
  32. QDF_STATUS wmi_unified_set_p2pgo_oppps_req(wmi_unified_t wmi_handle,
  33. struct p2p_ps_params *oppps);
  34. /**
  35. * wmi_unified_set_p2pgo_noa_req_cmd() - send p2p go noa request to fw
  36. * @wmi_handle: wmi handle
  37. * @noa: p2p power save parameters
  38. *
  39. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  40. */
  41. QDF_STATUS wmi_unified_set_p2pgo_noa_req_cmd(wmi_unified_t wmi_handle,
  42. struct p2p_ps_params *noa);
  43. /**
  44. * wmi_extract_p2p_noa_ev_param() - extract p2p noa param from event
  45. * @wmi_handle: wmi handle
  46. * @evt_buf: pointer to event buffer
  47. * @param: Pointer to hold p2p noa param
  48. *
  49. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  50. */
  51. QDF_STATUS wmi_extract_p2p_noa_ev_param(wmi_unified_t wmi_handle,
  52. void *evt_buf,
  53. struct p2p_noa_info *param);
  54. /**
  55. * wmi_extract_mac_addr_rx_filter_evt_param() - extract mac addr rx filter evt
  56. * @wmi_handle: wmi handle
  57. * @evt_buf: pointer to event buffer
  58. * @param: Pointer to extracted evt info
  59. *
  60. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  61. */
  62. QDF_STATUS
  63. wmi_extract_mac_addr_rx_filter_evt_param(wmi_unified_t wmi_handle,
  64. void *evt_buf,
  65. struct p2p_set_mac_filter_evt *param);
  66. #ifdef FEATURE_P2P_LISTEN_OFFLOAD
  67. /**
  68. * wmi_unified_p2p_lo_start_cmd() - send p2p lo start request to fw
  69. * @wmi_handle: wmi handle
  70. * @param: p2p listen offload start parameters
  71. *
  72. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  73. */
  74. QDF_STATUS wmi_unified_p2p_lo_start_cmd(wmi_unified_t wmi_handle,
  75. struct p2p_lo_start *param);
  76. /**
  77. * wmi_unified_p2p_lo_stop_cmd() - send p2p lo stop request to fw
  78. * @wmi_handle: wmi handle
  79. * @vdev_id: vdev id
  80. *
  81. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  82. */
  83. QDF_STATUS wmi_unified_p2p_lo_stop_cmd(wmi_unified_t wmi_handle,
  84. uint8_t vdev_id);
  85. /**
  86. * wmi_extract_p2p_lo_stop_ev_param() - extract p2p lo stop param from event
  87. * @wmi_handle: wmi handle
  88. * @evt_buf: pointer to event buffer
  89. * @param: Pointer to hold listen offload stop param
  90. *
  91. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  92. */
  93. QDF_STATUS wmi_extract_p2p_lo_stop_ev_param(wmi_unified_t wmi_handle,
  94. void *evt_buf,
  95. struct p2p_lo_event *param);
  96. #endif /* FEATURE_P2P_LISTEN_OFFLOAD */
  97. #endif /* _WMI_UNIFIED_P2P_API_H_ */