test_shared_stack_printf.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include "unity.h"
  4. #include "freertos/FreeRTOS.h"
  5. #include "freertos/task.h"
  6. #include "freertos/semphr.h"
  7. #include "sdkconfig.h"
  8. #include "test_utils.h"
  9. #include "esp_expression_with_stack.h"
  10. #define SHARED_STACK_SIZE 8192
  11. static StackType_t *shared_stack_sp = NULL;
  12. void external_stack_function(void)
  13. {
  14. printf("Executing this printf from external stack! sp=%p\n", get_sp());
  15. shared_stack_sp = (StackType_t *)get_sp();
  16. char *res = NULL;
  17. /* Test return value from asprintf, this could potentially help catch a misaligned
  18. stack pointer error */
  19. asprintf(&res, "%d %011i %lu %p %x %c %.4f\n", 42, 2147483647, 2147483648UL, (void *) 0x40010000, 0x40020000, 'Q', 1.0f / 137.0f);
  20. TEST_ASSERT_NOT_NULL(res);
  21. TEST_ASSERT_EQUAL_STRING("42 02147483647 2147483648 0x40010000 40020000 Q 0.0073\n", res);
  22. free(res);
  23. }
  24. void another_external_stack_function(void)
  25. {
  26. //We can even use Freertos resources inside of this context.
  27. printf("We can even use FreeRTOS resources... yielding, sp=%p\n", get_sp());
  28. taskYIELD();
  29. shared_stack_sp = (StackType_t *)get_sp();
  30. }
  31. TEST_CASE("test printf using shared buffer stack", "[newlib]")
  32. {
  33. portSTACK_TYPE *shared_stack = malloc(SHARED_STACK_SIZE);
  34. TEST_ASSERT_NOT_NULL(shared_stack);
  35. SemaphoreHandle_t printf_lock = xSemaphoreCreateMutex();
  36. TEST_ASSERT_NOT_NULL(printf_lock);
  37. printf("current task sp: %p\n", get_sp());
  38. printf("shared_stack: %p\n", (void *)shared_stack);
  39. printf("shared_stack expected top: %p\n", (void *)(shared_stack + SHARED_STACK_SIZE));
  40. esp_execute_shared_stack_function(printf_lock,
  41. shared_stack,
  42. SHARED_STACK_SIZE,
  43. external_stack_function);
  44. TEST_ASSERT(((shared_stack_sp >= shared_stack) &&
  45. (shared_stack_sp < (shared_stack + SHARED_STACK_SIZE))));
  46. esp_execute_shared_stack_function(printf_lock,
  47. shared_stack,
  48. SHARED_STACK_SIZE,
  49. another_external_stack_function);
  50. TEST_ASSERT(((shared_stack_sp >= shared_stack) &&
  51. (shared_stack_sp < (shared_stack + SHARED_STACK_SIZE))));
  52. vSemaphoreDelete(printf_lock);
  53. free(shared_stack);
  54. }