1 /*
2  * Copyright (c) 2018 Nordic Semiconductor ASA
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #ifndef ZEPHYR_INCLUDE_LOGGING_LOG_H_
8 #define ZEPHYR_INCLUDE_LOGGING_LOG_H_
9 
10 #include <zephyr/logging/log_instance.h>
11 #include <zephyr/logging/log_core.h>
12 #include <zephyr/sys/iterable_sections.h>
13 
14 #ifdef __cplusplus
15 extern "C" {
16 #endif
17 
18 /**
19  * @brief Logging
20  * @defgroup logging Logging
21  * @since 1.13
22  * @version 1.0.0
23  * @ingroup os_services
24  * @{
25  * @}
26  */
27 
28 /**
29  * @brief Logger API
30  * @defgroup log_api Logging API
31  * @ingroup logger
32  * @{
33  */
34 
35 /**
36  * @brief Writes an ERROR level message to the log.
37  *
38  * @details It's meant to report severe errors, such as those from which it's
39  * not possible to recover.
40  *
41  * @param ... A string optionally containing printk valid conversion specifier,
42  * followed by as many values as specifiers.
43  */
44 #define LOG_ERR(...)    Z_LOG(LOG_LEVEL_ERR, __VA_ARGS__)
45 
46 /**
47  * @brief Writes a WARNING level message to the log.
48  *
49  * @details It's meant to register messages related to unusual situations that
50  * are not necessarily errors.
51  *
52  * @param ... A string optionally containing printk valid conversion specifier,
53  * followed by as many values as specifiers.
54  */
55 #define LOG_WRN(...)   Z_LOG(LOG_LEVEL_WRN, __VA_ARGS__)
56 
57 /**
58  * @brief Writes an INFO level message to the log.
59  *
60  * @details It's meant to write generic user oriented messages.
61  *
62  * @param ... A string optionally containing printk valid conversion specifier,
63  * followed by as many values as specifiers.
64  */
65 #define LOG_INF(...)   Z_LOG(LOG_LEVEL_INF, __VA_ARGS__)
66 
67 /**
68  * @brief Writes a DEBUG level message to the log.
69  *
70  * @details It's meant to write developer oriented information.
71  *
72  * @param ... A string optionally containing printk valid conversion specifier,
73  * followed by as many values as specifiers.
74  */
75 #define LOG_DBG(...)    Z_LOG(LOG_LEVEL_DBG, __VA_ARGS__)
76 
77 /**
78  * @brief Writes a WARNING level message to the log on the first execution only.
79  *
80  * @details It's meant for situations that warrant investigation but could clutter
81  * the logs if output on every execution.
82  *
83  * @param ... A string optionally containing printk valid conversion specifier,
84  * followed by as many values as specifiers.
85  */
86 #define LOG_WRN_ONCE(...)					\
87 	do {							\
88 		static uint8_t __warned;			\
89 		if (unlikely(__warned == 0)) {			\
90 			Z_LOG(LOG_LEVEL_WRN, __VA_ARGS__);	\
91 			__warned = 1;				\
92 		}						\
93 	} while (0)
94 
95 /**
96  * @brief Unconditionally print raw log message.
97  *
98  * The result is same as if printk was used but it goes through logging
99  * infrastructure thus utilizes logging mode, e.g. deferred mode.
100  *
101  * @param ... A string optionally containing printk valid conversion specifier,
102  * followed by as many values as specifiers.
103  */
104 #define LOG_PRINTK(...) Z_LOG_PRINTK(0, __VA_ARGS__)
105 
106 /**
107  * @brief Unconditionally print raw log message.
108  *
109  * Provided string is printed as is without appending any characters (e.g., color or newline).
110  *
111  * @param ... A string optionally containing printk valid conversion specifier,
112  * followed by as many values as specifiers.
113  */
114 #define LOG_RAW(...) Z_LOG_PRINTK(1, __VA_ARGS__)
115 
116 /**
117  * @brief Writes an ERROR level message associated with the instance to the log.
118  *
119  * Message is associated with specific instance of the module which has
120  * independent filtering settings (if runtime filtering is enabled) and
121  * message prefix (\<module_name\>.\<instance_name\>). It's meant to report
122  * severe errors, such as those from which it's not possible to recover.
123  *
124  * @param _log_inst Pointer to the log structure associated with the instance.
125  * @param ... A string optionally containing printk valid conversion specifier,
126  * followed by as many values as specifiers.
127  */
128 #define LOG_INST_ERR(_log_inst, ...) \
129 	Z_LOG_INSTANCE(LOG_LEVEL_ERR, _log_inst, __VA_ARGS__)
130 
131 /**
132  * @brief Writes a WARNING level message associated with the instance to the
133  *        log.
134  *
135  * Message is associated with specific instance of the module which has
136  * independent filtering settings (if runtime filtering is enabled) and
137  * message prefix (\<module_name\>.\<instance_name\>). It's meant to register
138  * messages related to unusual situations that are not necessarily errors.
139  *
140  * @param _log_inst Pointer to the log structure associated with the instance.
141  * @param ...       A string optionally containing printk valid conversion
142  *                  specifier, followed by as many values as specifiers.
143  */
144 #define LOG_INST_WRN(_log_inst, ...) \
145 	Z_LOG_INSTANCE(LOG_LEVEL_WRN, _log_inst, __VA_ARGS__)
146 
147 /**
148  * @brief Writes an INFO level message associated with the instance to the log.
149  *
150  * Message is associated with specific instance of the module which has
151  * independent filtering settings (if runtime filtering is enabled) and
152  * message prefix (\<module_name\>.\<instance_name\>). It's meant to write
153  * generic user oriented messages.
154  *
155  * @param _log_inst Pointer to the log structure associated with the instance.
156  * @param ... A string optionally containing printk valid conversion specifier,
157  * followed by as many values as specifiers.
158  */
159 #define LOG_INST_INF(_log_inst, ...) \
160 	Z_LOG_INSTANCE(LOG_LEVEL_INF, _log_inst, __VA_ARGS__)
161 
162 /**
163  * @brief Writes a DEBUG level message associated with the instance to the log.
164  *
165  * Message is associated with specific instance of the module which has
166  * independent filtering settings (if runtime filtering is enabled) and
167  * message prefix (\<module_name\>.\<instance_name\>). It's meant to write
168  * developer oriented information.
169  *
170  * @param _log_inst Pointer to the log structure associated with the instance.
171  * @param ... A string optionally containing printk valid conversion specifier,
172  * followed by as many values as specifiers.
173  */
174 #define LOG_INST_DBG(_log_inst, ...) \
175 	Z_LOG_INSTANCE(LOG_LEVEL_DBG, _log_inst, __VA_ARGS__)
176 
177 /**
178  * @brief Writes an ERROR level hexdump message to the log.
179  *
180  * @details It's meant to report severe errors, such as those from which it's
181  * not possible to recover.
182  *
183  * @param _data   Pointer to the data to be logged.
184  * @param _length Length of data (in bytes).
185  * @param _str    Persistent, raw string.
186  */
187 #define LOG_HEXDUMP_ERR(_data, _length, _str) \
188 	Z_LOG_HEXDUMP(LOG_LEVEL_ERR, _data, _length, (_str))
189 
190 /**
191  * @brief Writes a WARNING level message to the log.
192  *
193  * @details It's meant to register messages related to unusual situations that
194  * are not necessarily errors.
195  *
196  * @param _data   Pointer to the data to be logged.
197  * @param _length Length of data (in bytes).
198  * @param _str    Persistent, raw string.
199  */
200 #define LOG_HEXDUMP_WRN(_data, _length, _str) \
201 	Z_LOG_HEXDUMP(LOG_LEVEL_WRN, _data, _length, (_str))
202 
203 /**
204  * @brief Writes an INFO level message to the log.
205  *
206  * @details It's meant to write generic user oriented messages.
207  *
208  * @param _data   Pointer to the data to be logged.
209  * @param _length Length of data (in bytes).
210  * @param _str    Persistent, raw string.
211  */
212 #define LOG_HEXDUMP_INF(_data, _length, _str) \
213 	Z_LOG_HEXDUMP(LOG_LEVEL_INF, _data, _length, (_str))
214 
215 /**
216  * @brief Writes a DEBUG level message to the log.
217  *
218  * @details It's meant to write developer oriented information.
219  *
220  * @param _data   Pointer to the data to be logged.
221  * @param _length Length of data (in bytes).
222  * @param _str    Persistent, raw string.
223  */
224 #define LOG_HEXDUMP_DBG(_data, _length, _str) \
225 	Z_LOG_HEXDUMP(LOG_LEVEL_DBG, _data, _length, (_str))
226 
227 /**
228  * @brief Writes an ERROR hexdump message associated with the instance to the
229  *        log.
230  *
231  * Message is associated with specific instance of the module which has
232  * independent filtering settings (if runtime filtering is enabled) and
233  * message prefix (\<module_name\>.\<instance_name\>). It's meant to report
234  * severe errors, such as those from which it's not possible to recover.
235  *
236  * @param _log_inst   Pointer to the log structure associated with the instance.
237  * @param _data       Pointer to the data to be logged.
238  * @param _length     Length of data (in bytes).
239  * @param _str        Persistent, raw string.
240  */
241 #define LOG_INST_HEXDUMP_ERR(_log_inst, _data, _length, _str) \
242 	Z_LOG_HEXDUMP_INSTANCE(LOG_LEVEL_ERR, _log_inst, _data, _length, _str)
243 
244 /**
245  * @brief Writes a WARNING level hexdump message associated with the instance to
246  *        the log.
247  *
248  * @details It's meant to register messages related to unusual situations that
249  * are not necessarily errors.
250  *
251  * @param _log_inst   Pointer to the log structure associated with the instance.
252  * @param _data       Pointer to the data to be logged.
253  * @param _length     Length of data (in bytes).
254  * @param _str        Persistent, raw string.
255  */
256 #define LOG_INST_HEXDUMP_WRN(_log_inst, _data, _length, _str) \
257 	Z_LOG_HEXDUMP_INSTANCE(LOG_LEVEL_WRN, _log_inst, _data, _length, _str)
258 
259 /**
260  * @brief Writes an INFO level hexdump message associated with the instance to
261  *        the log.
262  *
263  * @details It's meant to write generic user oriented messages.
264  *
265  * @param _log_inst   Pointer to the log structure associated with the instance.
266  * @param _data       Pointer to the data to be logged.
267  * @param _length     Length of data (in bytes).
268  * @param _str        Persistent, raw string.
269  */
270 #define LOG_INST_HEXDUMP_INF(_log_inst, _data, _length, _str) \
271 	Z_LOG_HEXDUMP_INSTANCE(LOG_LEVEL_INF, _log_inst, _data, _length, _str)
272 
273 /**
274  * @brief Writes a DEBUG level hexdump message associated with the instance to
275  *        the log.
276  *
277  * @details It's meant to write developer oriented information.
278  *
279  * @param _log_inst   Pointer to the log structure associated with the instance.
280  * @param _data       Pointer to the data to be logged.
281  * @param _length     Length of data (in bytes).
282  * @param _str        Persistent, raw string.
283  */
284 #define LOG_INST_HEXDUMP_DBG(_log_inst, _data, _length, _str)	\
285 	Z_LOG_HEXDUMP_INSTANCE(LOG_LEVEL_DBG, _log_inst, _data, _length, _str)
286 
287 /**
288  * @brief Writes an formatted string to the log.
289  *
290  * @details Conditionally compiled (see CONFIG_LOG_PRINTK). Function provides
291  * printk functionality.
292  *
293  * It is less efficient compared to standard logging because static packaging
294  * cannot be used.
295  *
296  * @param fmt Formatted string to output.
297  * @param ap  Variable parameters.
298  */
299 void z_log_vprintk(const char *fmt, va_list ap);
300 
301 #ifdef __cplusplus
302 }
303 #define LOG_IN_CPLUSPLUS 1
304 #endif
305 /* Macro expects that optionally on second argument local log level is provided.
306  * If provided it is returned, otherwise default log level is returned or
307  * LOG_LEVEL, if it was locally defined.
308  */
309 #if !defined(CONFIG_LOG)
310 #define _LOG_LEVEL_RESOLVE(...) LOG_LEVEL_NONE
311 #else
312 #define _LOG_LEVEL_RESOLVE(...) \
313 	Z_LOG_EVAL(COND_CODE_0(LOG_LEVEL, (1), (LOG_LEVEL)), \
314 		  (GET_ARG_N(2, __VA_ARGS__, LOG_LEVEL)), \
315 		  (GET_ARG_N(2, __VA_ARGS__, CONFIG_LOG_DEFAULT_LEVEL)))
316 #endif
317 
318 /* Return first argument */
319 #define _LOG_ARG1(arg1, ...) arg1
320 
321 #define _LOG_MODULE_CONST_DATA_CREATE(_name, _level)						\
322 	IF_ENABLED(CONFIG_LOG_FMT_SECTION, (							\
323 		static const char UTIL_CAT(_name, _str)[]					\
324 		     __in_section(_log_strings, static, _CONCAT(_name, _)) __used __noasan =	\
325 		     STRINGIFY(_name);))							\
326 	IF_ENABLED(LOG_IN_CPLUSPLUS, (extern))							\
327 	const STRUCT_SECTION_ITERABLE_ALTERNATE(log_const,					\
328 		log_source_const_data,								\
329 		Z_LOG_ITEM_CONST_DATA(_name)) =							\
330 	{											\
331 		.name = COND_CODE_1(CONFIG_LOG_FMT_SECTION,					\
332 				(UTIL_CAT(_name, _str)), (STRINGIFY(_name))),			\
333 		.level = (_level)								\
334 	}
335 
336 #define _LOG_MODULE_DYNAMIC_DATA_CREATE(_name)					\
337 	STRUCT_SECTION_ITERABLE_ALTERNATE(log_dynamic, log_source_dynamic_data, \
338 			LOG_ITEM_DYNAMIC_DATA(_name))
339 
340 #define _LOG_MODULE_DYNAMIC_DATA_COND_CREATE(_name)		\
341 	IF_ENABLED(CONFIG_LOG_RUNTIME_FILTERING,		\
342 		  (_LOG_MODULE_DYNAMIC_DATA_CREATE(_name);))
343 
344 #define _LOG_MODULE_DATA_CREATE(_name, _level)			\
345 	_LOG_MODULE_CONST_DATA_CREATE(_name, _level);		\
346 	_LOG_MODULE_DYNAMIC_DATA_COND_CREATE(_name)
347 
348 /* Determine if data for the module shall be created. It is created if logging
349  * is enabled, override level is set or module specific level is set (not off).
350  */
351 #define Z_DO_LOG_MODULE_REGISTER(...) \
352 	COND_CODE_1(CONFIG_LOG, \
353 		(Z_LOG_EVAL(CONFIG_LOG_OVERRIDE_LEVEL, \
354 		   (1), \
355 		   (Z_LOG_EVAL(_LOG_LEVEL_RESOLVE(__VA_ARGS__), (1), (0))) \
356 		  )), (0))
357 
358 /**
359  * @brief Create module-specific state and register the module with Logger.
360  *
361  * This macro normally must be used after including <zephyr/logging/log.h> to
362  * complete the initialization of the module.
363  *
364  * Module registration can be skipped in two cases:
365  *
366  * - The module consists of more than one file, and another file
367  *   invokes this macro. (LOG_MODULE_DECLARE() should be used instead
368  *   in all of the module's other files.)
369  * - Instance logging is used and there is no need to create module entry. In
370  *   that case LOG_LEVEL_SET() should be used to set log level used within the
371  *   file.
372  *
373  * Macro accepts one or two parameters:
374  * - module name
375  * - optional log level. If not provided then default log level is used in
376  *  the file.
377  *
378  * Example usage:
379  * - LOG_MODULE_REGISTER(foo, CONFIG_FOO_LOG_LEVEL)
380  * - LOG_MODULE_REGISTER(foo)
381  *
382  *
383  * @note The module's state is defined, and the module is registered,
384  *       only if LOG_LEVEL for the current source file is non-zero or
385  *       it is not defined and CONFIG_LOG_DEFAULT_LEVEL is non-zero.
386  *       In other cases, this macro has no effect.
387  * @see LOG_MODULE_DECLARE
388  */
389 #define LOG_MODULE_REGISTER(...)					\
390 	COND_CODE_1(							\
391 		Z_DO_LOG_MODULE_REGISTER(__VA_ARGS__),			\
392 		(_LOG_MODULE_DATA_CREATE(GET_ARG_N(1, __VA_ARGS__),	\
393 				      _LOG_LEVEL_RESOLVE(__VA_ARGS__))),\
394 		() \
395 	)								\
396 	LOG_MODULE_DECLARE(__VA_ARGS__)
397 
398 /**
399  * @brief Macro for declaring a log module (not registering it).
400  *
401  * Modules which are split up over multiple files must have exactly
402  * one file use LOG_MODULE_REGISTER() to create module-specific state
403  * and register the module with the logger core.
404  *
405  * The other files in the module should use this macro instead to
406  * declare that same state. (Otherwise, LOG_INF() etc. will not be
407  * able to refer to module-specific state variables.)
408  *
409  * Macro accepts one or two parameters:
410  * - module name
411  * - optional log level. If not provided then default log level is used in
412  *  the file.
413  *
414  * Example usage:
415  * - LOG_MODULE_DECLARE(foo, CONFIG_FOO_LOG_LEVEL)
416  * - LOG_MODULE_DECLARE(foo)
417  *
418  * @note The module's state is declared only if LOG_LEVEL for the
419  *       current source file is non-zero or it is not defined and
420  *       CONFIG_LOG_DEFAULT_LEVEL is non-zero.  In other cases,
421  *       this macro has no effect.
422  * @see LOG_MODULE_REGISTER
423  */
424 #define LOG_MODULE_DECLARE(...)						      \
425 	extern const struct log_source_const_data			      \
426 			Z_LOG_ITEM_CONST_DATA(GET_ARG_N(1, __VA_ARGS__));     \
427 	extern struct log_source_dynamic_data				      \
428 			LOG_ITEM_DYNAMIC_DATA(GET_ARG_N(1, __VA_ARGS__));     \
429 									      \
430 	static const struct log_source_const_data *			      \
431 		__log_current_const_data __unused =			      \
432 			Z_DO_LOG_MODULE_REGISTER(__VA_ARGS__) ?		      \
433 			&Z_LOG_ITEM_CONST_DATA(GET_ARG_N(1, __VA_ARGS__)) :   \
434 			NULL;						      \
435 									      \
436 	static struct log_source_dynamic_data *				      \
437 		__log_current_dynamic_data __unused =			      \
438 			(Z_DO_LOG_MODULE_REGISTER(__VA_ARGS__) &&	      \
439 			IS_ENABLED(CONFIG_LOG_RUNTIME_FILTERING)) ?	      \
440 			&LOG_ITEM_DYNAMIC_DATA(GET_ARG_N(1, __VA_ARGS__)) :   \
441 			NULL;						      \
442 									      \
443 	static const uint32_t __log_level __unused =			      \
444 					_LOG_LEVEL_RESOLVE(__VA_ARGS__)
445 
446 /**
447  * @brief Macro for setting log level in the file or function where instance
448  * logging API is used.
449  *
450  * @param level Level used in file or in function.
451  *
452  */
453 #define LOG_LEVEL_SET(level) static const uint32_t __log_level __unused = \
454 				Z_LOG_RESOLVED_LEVEL(level, 0)
455 
456 #ifdef CONFIG_LOG_CUSTOM_HEADER
457 /* This include must always be at the end of log.h */
458 #include <zephyr_custom_log.h>
459 #endif
460 
461 /*
462  * Eclipse CDT or JetBrains Clion parser is sometimes confused by logging API
463  * code and freezes the whole IDE. Following lines hides LOG_x macros from them.
464  */
465 #if defined(__CDT_PARSER__) || defined(__JETBRAINS_IDE__)
466 #undef LOG_ERR
467 #undef LOG_WRN
468 #undef LOG_INF
469 #undef LOG_DBG
470 
471 #undef LOG_HEXDUMP_ERR
472 #undef LOG_HEXDUMP_WRN
473 #undef LOG_HEXDUMP_INF
474 #undef LOG_HEXDUMP_DBG
475 
476 #define LOG_ERR(...) (void) 0
477 #define LOG_WRN(...) (void) 0
478 #define LOG_DBG(...) (void) 0
479 #define LOG_INF(...) (void) 0
480 
481 #define LOG_HEXDUMP_ERR(...) (void) 0
482 #define LOG_HEXDUMP_WRN(...) (void) 0
483 #define LOG_HEXDUMP_DBG(...) (void) 0
484 #define LOG_HEXDUMP_INF(...) (void) 0
485 #endif
486 
487 /**
488  * @}
489  */
490 
491 #endif /* ZEPHYR_INCLUDE_LOGGING_LOG_H_ */
492