test_shared_stack_printf.c 1.3 KB

1234567891011121314151617181920212223242526272829303132
  1. #include <stdio.h>
  2. #include "unity.h"
  3. #include "freertos/FreeRTOS.h"
  4. #include "freertos/task.h"
  5. #include "freertos/semphr.h"
  6. #include "sdkconfig.h"
  7. #include "test_utils.h"
  8. #include "esp_expression_with_stack.h"
  9. //makes sure this is not the task stack...
  10. void check_stack(portSTACK_TYPE *sp, portSTACK_TYPE *base_sp)
  11. {
  12. StaticTask_t *hacked_task = (StaticTask_t *)xTaskGetCurrentTaskHandle();
  13. portSTACK_TYPE *task_sp = (portSTACK_TYPE *)hacked_task->pxDummy1;
  14. TEST_ASSERT((intptr_t)task_sp < (intptr_t)base_sp ||
  15. (intptr_t)task_sp >= (intptr_t)sp);
  16. }
  17. TEST_CASE("test printf using shared buffer stack", "[newlib]")
  18. {
  19. portSTACK_TYPE *shared_stack = malloc(8192 * sizeof(portSTACK_TYPE));
  20. portSTACK_TYPE *ext_stack_top = (portSTACK_TYPE *)&shared_stack[0] +
  21. ((sizeof(8192 * sizeof(portSTACK_TYPE))) /
  22. sizeof(portSTACK_TYPE));
  23. TEST_ASSERT(shared_stack != NULL);
  24. SemaphoreHandle_t printf_lock = xSemaphoreCreateMutex();
  25. ESP_EXECUTE_EXPRESSION_WITH_STACK(printf_lock, shared_stack,8192,printf("Executing printf from external stack! \n"));
  26. ESP_EXECUTE_EXPRESSION_WITH_STACK(printf_lock, shared_stack,8192,check_stack(ext_stack_top, shared_stack));
  27. free(shared_stack);
  28. }