| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | /*-
 | 
					
						
							|  |  |  |  *   BSD LICENSE | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   Copyright (c) Intel Corporation. | 
					
						
							|  |  |  |  *   All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   Redistribution and use in source and binary forms, with or without | 
					
						
							|  |  |  |  *   modification, are permitted provided that the following conditions | 
					
						
							|  |  |  |  *   are met: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *     * Redistributions of source code must retain the above copyright | 
					
						
							|  |  |  |  *       notice, this list of conditions and the following disclaimer. | 
					
						
							|  |  |  |  *     * Redistributions in binary form must reproduce the above copyright | 
					
						
							|  |  |  |  *       notice, this list of conditions and the following disclaimer in | 
					
						
							|  |  |  |  *       the documentation and/or other materials provided with the | 
					
						
							|  |  |  |  *       distribution. | 
					
						
							|  |  |  |  *     * Neither the name of Intel Corporation nor the names of its | 
					
						
							|  |  |  |  *       contributors may be used to endorse or promote products derived | 
					
						
							|  |  |  |  *       from this software without specific prior written permission. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
					
						
							|  |  |  |  *   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
					
						
							|  |  |  |  *   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 
					
						
							|  |  |  |  *   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 
					
						
							|  |  |  |  *   OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 
					
						
							|  |  |  |  *   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 
					
						
							|  |  |  |  *   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
					
						
							|  |  |  |  *   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
					
						
							|  |  |  |  *   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
					
						
							|  |  |  |  *   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
					
						
							|  |  |  |  *   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * \file | 
					
						
							|  |  |  |  * Logging interfaces | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef SPDK_LOG_H
 | 
					
						
							|  |  |  | #define SPDK_LOG_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-01 20:22:48 +00:00
										 |  |  | #include "spdk/stdinc.h"
 | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-13 18:16:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize the logging module. Messages prior | 
					
						
							|  |  |  |  * to this call will be dropped. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_log_open(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Close the currently active log. Messages after this call | 
					
						
							|  |  |  |  * will be dropped. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_log_close(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-13 18:08:48 +00:00
										 |  |  | enum spdk_log_level { | 
					
						
							|  |  |  | 	SPDK_LOG_ERROR, | 
					
						
							|  |  |  | 	SPDK_LOG_WARN, | 
					
						
							|  |  |  | 	SPDK_LOG_NOTICE, | 
					
						
							|  |  |  | 	SPDK_LOG_INFO, | 
					
						
							|  |  |  | 	SPDK_LOG_DEBUG, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  |  * Set the log level threshold to log messages. Messages with a higher | 
					
						
							| 
									
										
										
										
											2017-06-13 18:08:48 +00:00
										 |  |  |  * level than this are ignored. | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \param level Log level threshold to set to log messages. | 
					
						
							| 
									
										
										
										
											2017-06-13 18:08:48 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | void spdk_log_set_level(enum spdk_log_level level); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  |  * Get the current log level threshold. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the current log level threshold. | 
					
						
							| 
									
										
										
										
											2017-06-13 18:08:48 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | enum spdk_log_level spdk_log_get_level(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-13 18:26:21 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Set the current log level threshold for printing to stderr. | 
					
						
							|  |  |  |  * Messages with a level less than or equal to this level | 
					
						
							|  |  |  |  * are also printed to stderr. | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \param level Log level threshold for printing to stderr. | 
					
						
							| 
									
										
										
										
											2017-06-13 18:26:21 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | void spdk_log_set_print_level(enum spdk_log_level level); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the current log level print threshold. | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return the current log level print threshold. | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-06-13 18:26:21 +00:00
										 |  |  | enum spdk_log_level spdk_log_get_print_level(void); | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define SPDK_NOTICELOG(...) \
 | 
					
						
							| 
									
										
										
										
											2017-06-13 18:35:27 +00:00
										 |  |  | 	spdk_log(SPDK_LOG_NOTICE, __FILE__, __LINE__, __func__, __VA_ARGS__) | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | #define SPDK_WARNLOG(...) \
 | 
					
						
							| 
									
										
										
										
											2017-06-13 18:35:27 +00:00
										 |  |  | 	spdk_log(SPDK_LOG_WARN, __FILE__, __LINE__, __func__, __VA_ARGS__) | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | #define SPDK_ERRLOG(...) \
 | 
					
						
							| 
									
										
										
										
											2017-06-13 18:35:27 +00:00
										 |  |  | 	spdk_log(SPDK_LOG_ERROR, __FILE__, __LINE__, __func__, __VA_ARGS__) | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Write messages to the log file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param level Log level threshold. | 
					
						
							|  |  |  |  * \param file Name of the current source file. | 
					
						
							|  |  |  |  * \param line Current source line number. | 
					
						
							|  |  |  |  * \param func Current source function name. | 
					
						
							|  |  |  |  * \param format Format string to the message. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-06-13 18:35:27 +00:00
										 |  |  | void spdk_log(enum spdk_log_level level, const char *file, const int line, const char *func, | 
					
						
							|  |  |  | 	      const char *format, ...) __attribute__((__format__(__printf__, 5, 6))); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Dump the trace to a file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fp File to hold the trace. | 
					
						
							|  |  |  |  * \param label Label to print to the file. | 
					
						
							|  |  |  |  * \param buf Buffer that holds the trace information. | 
					
						
							|  |  |  |  * \param len Length of trace to dump. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-10-17 17:47:25 +00:00
										 |  |  | void spdk_trace_dump(FILE *fp, const char *label, const void *buf, size_t len); | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Check whether the trace flag exists and is enabled. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return true if enabled, or false otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | bool spdk_log_get_trace_flag(const char *flag); | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Enable the trace flag. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param flag Trace flag to be enabled. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | int spdk_log_set_trace_flag(const char *flag); | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Clear a trace flag. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-06-18 14:39:39 +00:00
										 |  |  |  * \param flag Trace flag to clear. | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | int spdk_log_clear_trace_flag(const char *flag); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-30 03:09:28 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Show all the log trace flags and their usage. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param f File to hold all the flags' information. | 
					
						
							|  |  |  |  * \param trace_arg Command line option to set/enable the trace flag. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-08-22 16:15:35 +00:00
										 |  |  | void spdk_tracelog_usage(FILE *f, const char *trace_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-09 22:27:37 +00:00
										 |  |  | #endif /* SPDK_LOG_H */
 |