log.h (1059B)
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 6#include <syslog.h> 7 8#ifndef __maybe_unused 9#define __maybe_unused __attribute__((__unused__)) 10#endif 11 12#define TO_SYSLOG 0x1 13#define TO_STDOUT 0x2 14#define TO_STDERR 0x4 15 16extern void logit(int level, const char *format, ...); 17 18#define DEBUG(fmt, ...) logit(LOG_DEBUG, "%s:%d: " fmt, __func__, __LINE__, ##__VA_ARGS__) 19#define INFO(fmt, ...) logit(LOG_INFO, fmt, ##__VA_ARGS__) 20#define NOTICE(fmt, ...) logit(LOG_NOTICE, fmt, ##__VA_ARGS__) 21#define WARN(fmt, ...) logit(LOG_WARNING, fmt, ##__VA_ARGS__) 22#define ERROR(fmt, ...) logit(LOG_ERR, fmt, ##__VA_ARGS__) 23#define CRITICAL(fmt, ...) logit(LOG_CRIT, fmt, ##__VA_ARGS__) 24#define ALERT(fmt, ...) logit(LOG_ALERT, fmt, ##__VA_ARGS__) 25#define EMERG(fmt, ...) logit(LOG_EMERG, fmt, ##__VA_ARGS__) 26 27int log_init(int level, const char *ident, int options); 28int log_str2level(const char *lvl); 29void log_exit(void); 30 31#endif