log.h 1.0 KB

12345678910111213141516171819202122232425262728293031
  1. /* SPDX-License-Identifier: LGPL-2.1+ */
  2. /* Copyright (C) 2022, Linaro Ltd - Daniel Lezcano <daniel.lezcano@linaro.org> */
  3. #ifndef __THERMAL_TOOLS_LOG_H
  4. #define __THERMAL_TOOLS_LOG_H
  5. #include <syslog.h>
  6. #ifndef __maybe_unused
  7. #define __maybe_unused __attribute__((__unused__))
  8. #endif
  9. #define TO_SYSLOG 0x1
  10. #define TO_STDOUT 0x2
  11. #define TO_STDERR 0x4
  12. extern void logit(int level, const char *format, ...);
  13. #define DEBUG(fmt, ...) logit(LOG_DEBUG, "%s:%d: " fmt, __func__, __LINE__, ##__VA_ARGS__)
  14. #define INFO(fmt, ...) logit(LOG_INFO, fmt, ##__VA_ARGS__)
  15. #define NOTICE(fmt, ...) logit(LOG_NOTICE, fmt, ##__VA_ARGS__)
  16. #define WARN(fmt, ...) logit(LOG_WARNING, fmt, ##__VA_ARGS__)
  17. #define ERROR(fmt, ...) logit(LOG_ERR, fmt, ##__VA_ARGS__)
  18. #define CRITICAL(fmt, ...) logit(LOG_CRIT, fmt, ##__VA_ARGS__)
  19. #define ALERT(fmt, ...) logit(LOG_ALERT, fmt, ##__VA_ARGS__)
  20. #define EMERG(fmt, ...) logit(LOG_EMERG, fmt, ##__VA_ARGS__)
  21. int log_init(int level, const char *ident, int options);
  22. int log_str2level(const char *lvl);
  23. void log_exit(void);
  24. #endif