luat_timer_freertos.c 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. #include "luat_base.h"
  2. #include "luat_malloc.h"
  3. #include "luat_timer.h"
  4. #include "luat_msgbus.h"
  5. #include "FreeRTOS.h"
  6. #include "task.h"
  7. #include "timers.h"
  8. #define LUAT_LOG_TAG "luat.timer"
  9. #include "luat_log.h"
  10. #define FREERTOS_TIMER_COUNT 32
  11. static luat_timer_t* timers[FREERTOS_TIMER_COUNT] = {0};
  12. static void luat_timer_callback(TimerHandle_t xTimer) {
  13. //LLOGD("timer callback");
  14. rtos_msg_t msg;
  15. luat_timer_t *timer = (luat_timer_t*) pvTimerGetTimerID(xTimer);
  16. msg.handler = timer->func;
  17. msg.ptr = timer;
  18. msg.arg1 = 0;
  19. msg.arg2 = 0;
  20. int re = luat_msgbus_put(&msg, 0);
  21. //LLOGD("timer msgbus re=%ld", re);
  22. }
  23. static int nextTimerSlot() {
  24. for (size_t i = 0; i < FREERTOS_TIMER_COUNT; i++)
  25. {
  26. if (timers[i] == NULL) {
  27. return i;
  28. }
  29. }
  30. return -1;
  31. }
  32. int luat_timer_start(luat_timer_t* timer) {
  33. TimerHandle_t os_timer;
  34. int timerIndex;
  35. //LLOGD(">>luat_timer_start timeout=%ld", timer->timeout);
  36. timerIndex = nextTimerSlot();
  37. //LLOGD("timer id=%ld", timerIndex);
  38. if (timerIndex < 0) {
  39. return 1; // too many timer!!
  40. }
  41. os_timer = xTimerCreate("luat_timer", timer->timeout / portTICK_RATE_MS, timer->repeat, timer, luat_timer_callback);
  42. //LLOGD("timer id=%ld, osTimerNew=%p", timerIndex, os_timer);
  43. if (!os_timer) {
  44. return -1;
  45. }
  46. timers[timerIndex] = timer;
  47. timer->os_timer = os_timer;
  48. int re = xTimerStart(os_timer, 0);
  49. //LLOGD("timer id=%ld timeout=%ld start=%ld", timerIndex, timer->timeout, re);
  50. if (re != pdPASS) {
  51. xTimerDelete(os_timer, 0);
  52. timers[timerIndex] = 0;
  53. }
  54. return re == pdPASS ? 0 : -1;
  55. }
  56. int luat_timer_stop(luat_timer_t* timer) {
  57. if (!timer)
  58. return 1;
  59. for (size_t i = 0; i < FREERTOS_TIMER_COUNT; i++)
  60. {
  61. if (timers[i] == timer) {
  62. timers[i] = NULL;
  63. break;
  64. }
  65. }
  66. xTimerStop((TimerHandle_t)timer->os_timer, 10);
  67. xTimerDelete((TimerHandle_t)timer->os_timer, 10);
  68. return 0;
  69. };
  70. luat_timer_t* luat_timer_get(size_t timer_id) {
  71. for (size_t i = 0; i < FREERTOS_TIMER_COUNT; i++)
  72. {
  73. if (timers[i] && timers[i]->id == timer_id) {
  74. return timers[i];
  75. }
  76. }
  77. return NULL;
  78. }
  79. int luat_timer_mdelay(size_t ms) {
  80. if (ms > 0) {
  81. vTaskDelay(ms / portTICK_RATE_MS);
  82. }
  83. return 0;
  84. }