unity_port_linux.c 805 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. /*
  2. * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include <string.h>
  7. #include <stdbool.h>
  8. #include <unistd.h>
  9. #include <stdio.h>
  10. #include <sys/time.h>
  11. #include "unity.h"
  12. #include "sdkconfig.h"
  13. static struct timeval s_test_start, s_test_stop;
  14. void unity_putc(int c)
  15. {
  16. putc(c, stdout);
  17. }
  18. void unity_flush(void)
  19. {
  20. fflush(stdout);
  21. fsync(fileno(stdout));
  22. }
  23. void unity_exec_time_start(void)
  24. {
  25. gettimeofday(&s_test_start, NULL);
  26. }
  27. void unity_exec_time_stop(void)
  28. {
  29. gettimeofday(&s_test_stop, NULL);
  30. }
  31. uint32_t unity_exec_time_get_ms(void)
  32. {
  33. return (uint32_t) (((s_test_stop.tv_sec * 1000000ULL + s_test_stop.tv_usec) -
  34. (s_test_start.tv_sec * 1000000ULL + s_test_start.tv_usec)) / 1000);
  35. }