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