57#if NETSTACK_CONF_WITH_IPV6
62#define LOG_LEVEL_NONE 0
63#define LOG_LEVEL_ERR 1
64#define LOG_LEVEL_WARN 2
65#define LOG_LEVEL_INFO 3
66#define LOG_LEVEL_DBG 4
69#define TC_RESET "\033[0m"
70#define TC_BLACK "\033[0;30m"
71#define TC_RED "\033[0;31m"
72#define TC_GREEN "\033[0;32m"
73#define TC_YELLOW "\033[0;33m"
74#define TC_BLUE "\033[0;34m"
75#define TC_MAGENTA "\033[0;35m"
76#define TC_CYAN "\033[0;36m"
77#define TC_WHITE "\033[0;37m"
79#define LOG_COLOR_RESET TC_RESET
82#define LOG_COLOR_ERR TC_RED
86#define LOG_COLOR_WARN TC_YELLOW
90#define LOG_COLOR_INFO TC_BLUE
94#define LOG_COLOR_DBG TC_WHITE
98#define LOG_COLOR_PRI TC_CYAN
109extern int curr_log_level_rpl;
110extern int curr_log_level_tcpip;
111extern int curr_log_level_ipv6;
112extern int curr_log_level_6lowpan;
113extern int curr_log_level_nullnet;
114extern int curr_log_level_mac;
115extern int curr_log_level_framer;
116extern int curr_log_level_6top;
117extern int curr_log_level_coap;
118extern int curr_log_level_snmp;
119extern int curr_log_level_lwm2m;
120extern int curr_log_level_sys;
121extern int curr_log_level_main;
123extern struct log_module all_modules[];
125#define LOG_LEVEL_RPL MIN((LOG_CONF_LEVEL_RPL), curr_log_level_rpl)
126#define LOG_LEVEL_TCPIP MIN((LOG_CONF_LEVEL_TCPIP), curr_log_level_tcpip)
127#define LOG_LEVEL_IPV6 MIN((LOG_CONF_LEVEL_IPV6), curr_log_level_ipv6)
128#define LOG_LEVEL_6LOWPAN MIN((LOG_CONF_LEVEL_6LOWPAN), curr_log_level_6lowpan)
129#define LOG_LEVEL_NULLNET MIN((LOG_CONF_LEVEL_NULLNET), curr_log_level_nullnet)
130#define LOG_LEVEL_MAC MIN((LOG_CONF_LEVEL_MAC), curr_log_level_mac)
131#define LOG_LEVEL_FRAMER MIN((LOG_CONF_LEVEL_FRAMER), curr_log_level_framer)
132#define LOG_LEVEL_6TOP MIN((LOG_CONF_LEVEL_6TOP), curr_log_level_6top)
133#define LOG_LEVEL_COAP MIN((LOG_CONF_LEVEL_COAP), curr_log_level_coap)
134#define LOG_LEVEL_SNMP MIN((LOG_CONF_LEVEL_SNMP), curr_log_level_snmp)
135#define LOG_LEVEL_LWM2M MIN((LOG_CONF_LEVEL_LWM2M), curr_log_level_lwm2m)
136#define LOG_LEVEL_SYS MIN((LOG_CONF_LEVEL_SYS), curr_log_level_sys)
137#define LOG_LEVEL_MAIN MIN((LOG_CONF_LEVEL_MAIN), curr_log_level_main)
141#define LOG(newline, level, levelstr, levelcolor, ...) do { \
142 if(level <= (LOG_LEVEL)) { \
144 if(LOG_WITH_COLOR) { \
145 LOG_OUTPUT(levelcolor); \
147 if(LOG_WITH_MODULE_PREFIX) { \
148 LOG_OUTPUT_PREFIX(level, levelstr, LOG_MODULE); \
151 LOG_OUTPUT("[%s: %d] ", __FILE__, __LINE__); \
153 if(LOG_WITH_COLOR) { \
154 LOG_OUTPUT(LOG_COLOR_RESET); \
157 LOG_OUTPUT(__VA_ARGS__); \
162#define LOG_ANNOTATE(...) do { \
163 if(LOG_WITH_ANNOTATE) { \
164 LOG_OUTPUT(__VA_ARGS__); \
169#define LOG_LLADDR(level, lladdr) do { \
170 if(level <= (LOG_LEVEL)) { \
171 if(LOG_WITH_COMPACT_ADDR) { \
172 log_lladdr_compact(lladdr); \
174 log_lladdr(lladdr); \
180#define LOG_6ADDR(level, ipaddr) do { \
181 if(level <= (LOG_LEVEL)) { \
182 if(LOG_WITH_COMPACT_ADDR) { \
183 log_6addr_compact(ipaddr); \
190#define LOG_BYTES(level, data, length) do { \
191 if(level <= (LOG_LEVEL)) { \
192 log_bytes(data, length); \
197#define LOG_PRINT(...) LOG(1, 0, "PRI", LOG_COLOR_PRI, __VA_ARGS__)
198#define LOG_ERR(...) LOG(1, LOG_LEVEL_ERR, "ERR", LOG_COLOR_ERR, __VA_ARGS__)
199#define LOG_WARN(...) LOG(1, LOG_LEVEL_WARN, "WARN", LOG_COLOR_WARN, __VA_ARGS__)
200#define LOG_INFO(...) LOG(1, LOG_LEVEL_INFO, "INFO", LOG_COLOR_INFO, __VA_ARGS__)
201#define LOG_DBG(...) LOG(1, LOG_LEVEL_DBG, "DBG", LOG_COLOR_DBG, __VA_ARGS__)
203#define LOG_PRINT_(...) LOG(0, 0, "PRI", LOG_COLOR_PRI, __VA_ARGS__)
204#define LOG_ERR_(...) LOG(0, LOG_LEVEL_ERR, "ERR", LOG_COLOR_ERR, __VA_ARGS__)
205#define LOG_WARN_(...) LOG(0, LOG_LEVEL_WARN, "WARN", LOG_COLOR_WARN, __VA_ARGS__)
206#define LOG_INFO_(...) LOG(0, LOG_LEVEL_INFO, "INFO", LOG_COLOR_INFO, __VA_ARGS__)
207#define LOG_DBG_(...) LOG(0, LOG_LEVEL_DBG, "DBG", LOG_COLOR_DBG, __VA_ARGS__)
209#define LOG_PRINT_LLADDR(...) LOG_LLADDR(0, __VA_ARGS__)
210#define LOG_ERR_LLADDR(...) LOG_LLADDR(LOG_LEVEL_ERR, __VA_ARGS__)
211#define LOG_WARN_LLADDR(...) LOG_LLADDR(LOG_LEVEL_WARN, __VA_ARGS__)
212#define LOG_INFO_LLADDR(...) LOG_LLADDR(LOG_LEVEL_INFO, __VA_ARGS__)
213#define LOG_DBG_LLADDR(...) LOG_LLADDR(LOG_LEVEL_DBG, __VA_ARGS__)
215#define LOG_PRINT_6ADDR(...) LOG_6ADDR(0, __VA_ARGS__)
216#define LOG_ERR_6ADDR(...) LOG_6ADDR(LOG_LEVEL_ERR, __VA_ARGS__)
217#define LOG_WARN_6ADDR(...) LOG_6ADDR(LOG_LEVEL_WARN, __VA_ARGS__)
218#define LOG_INFO_6ADDR(...) LOG_6ADDR(LOG_LEVEL_INFO, __VA_ARGS__)
219#define LOG_DBG_6ADDR(...) LOG_6ADDR(LOG_LEVEL_DBG, __VA_ARGS__)
221#define LOG_PRINT_BYTES(data, length) LOG_BYTES(0, data, length)
222#define LOG_ERR_BYTES(data, length) LOG_BYTES(LOG_LEVEL_ERR, data, length)
223#define LOG_WARN_BYTES(data, length) LOG_BYTES(LOG_LEVEL_WARN, data, length)
224#define LOG_INFO_BYTES(data, length) LOG_BYTES(LOG_LEVEL_INFO, data, length)
225#define LOG_DBG_BYTES(data, length) LOG_BYTES(LOG_LEVEL_DBG, data, length)
233#define LOG_ERR_ENABLED ((LOG_LEVEL) >= LOG_LEVEL_ERR)
234#define LOG_WARN_ENABLED ((LOG_LEVEL) >= LOG_LEVEL_WARN)
235#define LOG_INFO_ENABLED ((LOG_LEVEL) >= LOG_LEVEL_INFO)
236#define LOG_DBG_ENABLED ((LOG_LEVEL) >= LOG_LEVEL_DBG)
238#if NETSTACK_CONF_WITH_IPV6
282void log_bytes(
const void *data,
size_t length);
void log_set_level(const char *module, int level)
Sets a log level at run-time.
int log_6addr_compact_snprint(char *buf, size_t size, const uip_ipaddr_t *ipaddr)
Write at most size - 1 characters of the IP address to the output string, in a compact representation...
void log_6addr_compact(const uip_ipaddr_t *ipaddr)
Logs an IPv6 address with a compact format.
void log_lladdr(const linkaddr_t *lladdr)
Logs a link-layer address.
const char * log_level_to_str(int level)
Returns a textual description of a log level.
void log_lladdr_compact(const linkaddr_t *lladdr)
Logs a link-layer address with a compact format.
void log_6addr(const uip_ipaddr_t *ipaddr)
Logs an IPv6 address.
int log_get_level(const char *module)
Returns the current log level.
void log_bytes(const void *data, size_t length)
Logs a byte array as hex characters.
Header file for the link-layer address representation.
Default log levels for a number of modules.
static uip_ipaddr_t ipaddr
Pointer to prefix information option in uip_buf.
Header file for the uIP TCP/IP stack.