test_freertos_task_delay_until.c 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. /*
  7. Test for FreeRTOS vTaskDelayUntil() function by comparing the delay period of
  8. the function to comparing it to ref clock.
  9. */
  10. #include <stdio.h>
  11. #include <stdlib.h>
  12. #include "freertos/FreeRTOS.h"
  13. #include "freertos/task.h"
  14. #include "freertos/semphr.h"
  15. #include "unity.h"
  16. #include "test_utils.h"
  17. #define TSK_PRIORITY (UNITY_FREERTOS_PRIORITY + 1)
  18. #define NO_OF_CYCLES 5
  19. #define NO_OF_TASKS_PER_CORE 2
  20. #define TICKS_TO_DELAY 10
  21. #define TICK_RATE configTICK_RATE_HZ
  22. #define TICK_PERIOD_US (1000000/TICK_RATE)
  23. #define IDEAL_DELAY_PERIOD_MS ((1000*TICKS_TO_DELAY)/TICK_RATE)
  24. #define IDEAL_DELAY_PERIOD_US (IDEAL_DELAY_PERIOD_MS*1000)
  25. #define TICKS_TO_MS(x) (((x)*1000)/TICK_RATE)
  26. #define REF_TO_ROUND_MS(x) (((x)+500)/1000)
  27. static SemaphoreHandle_t task_delete_semphr;
  28. static void delaying_task(void* arg)
  29. {
  30. uint64_t ref_prev, ref_current;
  31. TickType_t last_wake_time;
  32. TickType_t ticks_before_delay;
  33. vTaskDelay(1); //Delay until next tick to synchronize operations to tick boundaries
  34. last_wake_time = xTaskGetTickCount();
  35. ticks_before_delay = last_wake_time;
  36. ref_prev = ref_clock_get();
  37. for(int i = 0; i < NO_OF_CYCLES; i++){
  38. //Delay of TICKS_TO_DELAY
  39. vTaskDelayUntil(&last_wake_time, TICKS_TO_DELAY);
  40. //Get current ref clock
  41. TEST_ASSERT_EQUAL(IDEAL_DELAY_PERIOD_MS, TICKS_TO_MS(xTaskGetTickCount() - ticks_before_delay));
  42. ref_current = ref_clock_get();
  43. TEST_ASSERT_UINT32_WITHIN(TICK_PERIOD_US, IDEAL_DELAY_PERIOD_US, (uint32_t)(ref_current - ref_prev));
  44. ref_prev = ref_current;
  45. ticks_before_delay = last_wake_time;
  46. }
  47. //Delete Task after prescribed number of cycles
  48. xSemaphoreGive(task_delete_semphr);
  49. vTaskDelete(NULL);
  50. }
  51. TEST_CASE("Test vTaskDelayUntil", "[freertos]")
  52. {
  53. task_delete_semphr = xQueueCreateCountingSemaphore(NO_OF_TASKS_PER_CORE*portNUM_PROCESSORS, 0);
  54. ref_clock_init();
  55. for(int i = 0; i < portNUM_PROCESSORS; i++){
  56. xTaskCreatePinnedToCore(delaying_task, "delay_pinned", 1024, NULL, TSK_PRIORITY, NULL, i);
  57. xTaskCreatePinnedToCore(delaying_task, "delay_no_aff", 1024, NULL, TSK_PRIORITY, NULL, tskNO_AFFINITY);
  58. }
  59. for(int i = 0; i < NO_OF_TASKS_PER_CORE*portNUM_PROCESSORS; i++){
  60. xSemaphoreTake(task_delete_semphr, portMAX_DELAY);
  61. }
  62. //Cleanup
  63. vSemaphoreDelete(task_delete_semphr);
  64. ref_clock_deinit();
  65. }