wlan_workqueue.c 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright (c) 2006-2018, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-08-19 tyx the first version
  9. */
  10. #include <rthw.h>
  11. #include <rtthread.h>
  12. #include <wlan_workqueue.h>
  13. #include <ipc/workqueue.h>
  14. #define DBG_TAG "WLAN.work"
  15. #define DBG_LVL DBG_INFO
  16. #include <rtdbg.h>
  17. struct rt_wlan_work
  18. {
  19. struct rt_work work;
  20. void (*fun)(void *parameter);
  21. void *parameter;
  22. };
  23. static struct rt_workqueue *wlan_workqueue;
  24. static void rt_wlan_workqueue_fun(struct rt_work *work, void *work_data)
  25. {
  26. struct rt_wlan_work *wlan_work = work_data;
  27. wlan_work->fun(wlan_work->parameter);
  28. rt_free(wlan_work);
  29. }
  30. struct rt_workqueue *rt_wlan_get_workqueue(void)
  31. {
  32. return wlan_workqueue;
  33. }
  34. rt_err_t rt_wlan_workqueue_dowork(void (*func)(void *parameter), void *parameter)
  35. {
  36. struct rt_wlan_work *wlan_work;
  37. rt_err_t err = RT_EOK;
  38. LOG_D("F:%s is run", __FUNCTION__);
  39. if (func == RT_NULL)
  40. {
  41. LOG_E("F:%s L:%d func is null", __FUNCTION__, __LINE__);
  42. return -RT_EINVAL;
  43. }
  44. if (wlan_workqueue == RT_NULL)
  45. {
  46. LOG_E("F:%s L:%d not init wlan work queue", __FUNCTION__, __LINE__);
  47. return -RT_ERROR;
  48. }
  49. wlan_work = rt_malloc(sizeof(struct rt_wlan_work));
  50. if (wlan_work == RT_NULL)
  51. {
  52. LOG_E("F:%s L:%d create work failed", __FUNCTION__, __LINE__);
  53. return -RT_ENOMEM;
  54. }
  55. wlan_work->fun = func;
  56. wlan_work->parameter = parameter;
  57. rt_work_init(&wlan_work->work, rt_wlan_workqueue_fun, wlan_work);
  58. err = rt_workqueue_dowork(wlan_workqueue, &wlan_work->work);
  59. if (err != RT_EOK)
  60. {
  61. LOG_E("F:%s L:%d do work failed", __FUNCTION__, __LINE__);
  62. rt_free(wlan_work);
  63. return err;
  64. }
  65. return err;
  66. }
  67. int rt_wlan_workqueue_init(void)
  68. {
  69. static rt_int8_t _init_flag = 0;
  70. if (_init_flag == 0)
  71. {
  72. wlan_workqueue = rt_workqueue_create(RT_WLAN_WORKQUEUE_THREAD_NAME, RT_WLAN_WORKQUEUE_THREAD_SIZE,
  73. RT_WLAN_WORKQUEUE_THREAD_PRIO);
  74. if (wlan_workqueue == RT_NULL)
  75. {
  76. LOG_E("F:%s L:%d wlan work queue create failed", __FUNCTION__, __LINE__);
  77. return -1;
  78. }
  79. _init_flag = 1;
  80. return 0;
  81. }
  82. return 0;
  83. }
  84. INIT_PREV_EXPORT(rt_wlan_workqueue_init);