qdf_platform.c 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. /*
  2. * Copyright (c) 2018-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. #include "qdf_module.h"
  19. #include "qdf_trace.h"
  20. #include "qdf_platform.h"
  21. /**
  22. * The following callbacks should be defined static to make sure they are
  23. * initialized to NULL
  24. */
  25. static qdf_self_recovery_callback self_recovery_cb;
  26. static qdf_is_fw_down_callback is_fw_down_cb;
  27. static qdf_is_driver_unloading_callback is_driver_unloading_cb;
  28. static qdf_is_driver_state_module_stop_callback is_driver_state_module_stop_cb;
  29. static qdf_is_recovering_callback is_recovering_cb;
  30. static qdf_is_drv_connected_callback is_drv_connected_cb;
  31. static qdf_wmi_send_over_qmi_callback _wmi_send_recv_qmi_cb;
  32. static qdf_is_drv_supported_callback is_drv_supported_cb;
  33. static qdf_recovery_reason_update_callback update_recovery_reason_cb;
  34. static qdf_bus_reg_dump get_bus_reg_dump;
  35. void qdf_register_fw_down_callback(qdf_is_fw_down_callback is_fw_down)
  36. {
  37. is_fw_down_cb = is_fw_down;
  38. }
  39. qdf_export_symbol(qdf_register_fw_down_callback);
  40. bool qdf_is_fw_down(void)
  41. {
  42. if (!is_fw_down_cb) {
  43. QDF_TRACE(QDF_MODULE_ID_QDF, QDF_TRACE_LEVEL_ERROR,
  44. "fw down callback is not registered");
  45. return false;
  46. }
  47. return is_fw_down_cb();
  48. }
  49. qdf_export_symbol(qdf_is_fw_down);
  50. void qdf_register_wmi_send_recv_qmi_callback(qdf_wmi_send_over_qmi_callback
  51. wmi_send_recv_qmi_cb)
  52. {
  53. _wmi_send_recv_qmi_cb = wmi_send_recv_qmi_cb;
  54. }
  55. qdf_export_symbol(qdf_register_wmi_send_recv_qmi_callback);
  56. QDF_STATUS qdf_wmi_send_recv_qmi(void *buf, uint32_t len, void *cb_ctx,
  57. qdf_wmi_recv_qmi_cb wmi_recv_qmi_cb)
  58. {
  59. if (!_wmi_send_recv_qmi_cb) {
  60. QDF_TRACE(QDF_MODULE_ID_QDF, QDF_TRACE_LEVEL_ERROR,
  61. "Platform callback for WMI over QMI not registered");
  62. return QDF_STATUS_E_INVAL;
  63. }
  64. return _wmi_send_recv_qmi_cb(buf, len, cb_ctx, wmi_recv_qmi_cb);
  65. }
  66. qdf_export_symbol(qdf_wmi_send_recv_qmi);
  67. void qdf_register_is_driver_unloading_callback(
  68. qdf_is_driver_unloading_callback callback)
  69. {
  70. is_driver_unloading_cb = callback;
  71. }
  72. qdf_export_symbol(qdf_register_is_driver_unloading_callback);
  73. void qdf_register_is_driver_state_module_stop_callback(
  74. qdf_is_driver_state_module_stop_callback callback)
  75. {
  76. is_driver_state_module_stop_cb = callback;
  77. }
  78. qdf_export_symbol(qdf_register_is_driver_state_module_stop_callback);
  79. void qdf_register_self_recovery_callback(qdf_self_recovery_callback callback)
  80. {
  81. self_recovery_cb = callback;
  82. }
  83. qdf_export_symbol(qdf_register_self_recovery_callback);
  84. void __qdf_trigger_self_recovery(void *psoc, enum qdf_hang_reason reason,
  85. const char *func, const uint32_t line)
  86. {
  87. if (self_recovery_cb)
  88. self_recovery_cb(psoc, reason, func, line);
  89. else
  90. QDF_DEBUG_PANIC_FL(func, line, "");
  91. }
  92. qdf_export_symbol(__qdf_trigger_self_recovery);
  93. void qdf_register_recovering_state_query_callback(
  94. qdf_is_recovering_callback is_recovering)
  95. {
  96. is_recovering_cb = is_recovering;
  97. }
  98. bool qdf_is_driver_unloading(void)
  99. {
  100. if (is_driver_unloading_cb)
  101. return is_driver_unloading_cb();
  102. return false;
  103. }
  104. qdf_export_symbol(qdf_is_driver_unloading);
  105. bool qdf_is_driver_state_module_stop(void)
  106. {
  107. if (is_driver_state_module_stop_cb)
  108. return is_driver_state_module_stop_cb();
  109. return false;
  110. }
  111. qdf_export_symbol(qdf_is_driver_state_module_stop);
  112. bool qdf_is_recovering(void)
  113. {
  114. if (is_recovering_cb)
  115. return is_recovering_cb();
  116. return false;
  117. }
  118. qdf_export_symbol(qdf_is_recovering);
  119. static qdf_op_protect_cb __on_op_protect;
  120. static qdf_op_unprotect_cb __on_op_unprotect;
  121. void qdf_op_callbacks_register(qdf_op_protect_cb on_protect,
  122. qdf_op_unprotect_cb on_unprotect)
  123. {
  124. __on_op_protect = on_protect;
  125. __on_op_unprotect = on_unprotect;
  126. }
  127. qdf_export_symbol(qdf_op_callbacks_register);
  128. int __qdf_op_protect(struct qdf_op_sync **out_sync, const char *func)
  129. {
  130. if (!__on_op_protect)
  131. return 0;
  132. return __on_op_protect((void **)out_sync, func);
  133. }
  134. qdf_export_symbol(__qdf_op_protect);
  135. void __qdf_op_unprotect(struct qdf_op_sync *sync, const char *func)
  136. {
  137. if (__on_op_unprotect)
  138. __on_op_unprotect(sync, func);
  139. }
  140. qdf_export_symbol(__qdf_op_unprotect);
  141. void qdf_register_drv_connected_callback(qdf_is_drv_connected_callback
  142. is_drv_connected)
  143. {
  144. is_drv_connected_cb = is_drv_connected;
  145. }
  146. qdf_export_symbol(qdf_register_drv_connected_callback);
  147. bool qdf_is_drv_connected(void)
  148. {
  149. if (!is_drv_connected_cb) {
  150. qdf_err("drv connected callback is not registered");
  151. return false;
  152. }
  153. return is_drv_connected_cb();
  154. }
  155. qdf_export_symbol(qdf_is_drv_connected);
  156. void qdf_check_state_before_panic(const char *func, const uint32_t line)
  157. {
  158. if (!qdf_is_recovering() && !qdf_is_fw_down())
  159. QDF_DEBUG_PANIC_FL(func, line, "");
  160. }
  161. qdf_export_symbol(qdf_check_state_before_panic);
  162. void qdf_register_drv_supported_callback(qdf_is_drv_supported_callback
  163. is_drv_supported)
  164. {
  165. is_drv_supported_cb = is_drv_supported;
  166. }
  167. qdf_export_symbol(qdf_register_drv_supported_callback);
  168. bool qdf_is_drv_supported(void)
  169. {
  170. if (!is_drv_supported_cb) {
  171. qdf_err("drv supported callback is not registered");
  172. return false;
  173. }
  174. return is_drv_supported_cb();
  175. }
  176. qdf_export_symbol(qdf_is_drv_supported);
  177. void qdf_register_recovery_reason_update(qdf_recovery_reason_update_callback
  178. callback)
  179. {
  180. update_recovery_reason_cb = callback;
  181. }
  182. qdf_export_symbol(qdf_register_recovery_reason_update);
  183. void qdf_recovery_reason_update(enum qdf_hang_reason reason)
  184. {
  185. if (!update_recovery_reason_cb)
  186. return;
  187. update_recovery_reason_cb(reason);
  188. }
  189. qdf_export_symbol(qdf_recovery_reason_update);
  190. void qdf_register_get_bus_reg_dump(qdf_bus_reg_dump callback)
  191. {
  192. get_bus_reg_dump = callback;
  193. }
  194. qdf_export_symbol(qdf_register_get_bus_reg_dump);
  195. void qdf_get_bus_reg_dump(struct device *dev, uint8_t *buf, uint32_t len)
  196. {
  197. if (!get_bus_reg_dump)
  198. return;
  199. get_bus_reg_dump(dev, buf, len);
  200. }
  201. qdf_export_symbol(qdf_get_bus_reg_dump);