Ingen beskrivning
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

log.h 1.9KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /*
  2. * log.h
  3. *
  4. * Copyright (c) 2022 - 2023 Thomas Buck (thomas@xythobuz.de)
  5. *
  6. * This program is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * See <http://www.gnu.org/licenses/>.
  17. */
  18. #ifndef __LOG_H__
  19. #define __LOG_H__
  20. #include <stdarg.h>
  21. #include <stdbool.h>
  22. // Include sys/types.h before inttypes.h to work around issue with
  23. // certain versions of GCC and newlib which causes omission of PRI_64
  24. #include <sys/types.h>
  25. #include <inttypes.h>
  26. #include "pico/stdlib.h"
  27. // for output that is stored in the debug log.
  28. // will be re-played from buffer when terminal connects
  29. #ifndef PICOWOTA
  30. #define debug(fmt, ...) debug_log(true, \
  31. "%08" PRIu32 " %s:%d: " fmt "\r\n", \
  32. to_ms_since_boot(get_absolute_time()), \
  33. __func__, __LINE__, \
  34. ##__VA_ARGS__)
  35. #else // PICOWOTA
  36. #define debug(fmt, ...) debug_log(true, \
  37. fmt "\r\n", \
  38. ##__VA_ARGS__)
  39. #endif // PICOWOTA
  40. // for interactive output. is not stored or re-played.
  41. #define print(fmt, ...) debug_log(false, fmt, ##__VA_ARGS__)
  42. #define println(fmt, ...) debug_log(false, fmt "\r\n", ##__VA_ARGS__)
  43. void debug_log(bool log, const char *format, ...) __attribute__((format(printf, 2, 3)));
  44. void debug_wait_input(const char *format, ...) __attribute__((format(printf, 1, 2)));
  45. void debug_log_va(bool log, const char *format, va_list args);
  46. void log_dump_to_usb(void);
  47. void debug_handle_input(const void *buff, size_t len);
  48. #include "ring.h"
  49. struct ring_buffer *log_get(void);
  50. #endif // __LOG_H__