2 * Copyright (c) 2012 Vojtech Horky
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 /** @addtogroup logger
32 /** @file Common logger service definitions.
39 #include <adt/prodcons.h>
43 #include <fibril_synch.h>
47 #define LOG_LEVEL_USE_DEFAULT (LVL_LIMIT + 1)
50 #define logger_log(fmt, ...) printf(NAME ": " fmt, ##__VA_ARGS__)
52 #define logger_log(fmt, ...) (void)0
55 typedef struct logger_log logger_log_t
;
73 log_level_t logged_level
;
77 #define MAX_REFERENCED_LOGS_PER_CLIENT 100
81 logger_log_t
*logs
[MAX_REFERENCED_LOGS_PER_CLIENT
];
82 } logger_registered_logs_t
;
84 logger_log_t
*find_log_by_name_and_lock(const char *name
);
85 logger_log_t
*find_or_create_log_and_lock(const char *, sysarg_t
);
86 logger_log_t
*find_log_by_id_and_lock(sysarg_t
);
87 bool shall_log_message(logger_log_t
*, log_level_t
);
88 void log_unlock(logger_log_t
*);
89 void write_to_log(logger_log_t
*, log_level_t
, const char *);
90 void log_release(logger_log_t
*);
92 void registered_logs_init(logger_registered_logs_t
*);
93 bool register_log(logger_registered_logs_t
*, logger_log_t
*);
94 void unregister_logs(logger_registered_logs_t
*);
96 log_level_t
get_default_logging_level(void);
97 errno_t
set_default_logging_level(log_level_t
);
99 void logger_connection_handler_control(ipc_call_t
*);
100 void logger_connection_handler_writer(ipc_call_t
*);
102 void parse_initial_settings(void);
103 void parse_level_settings(char *);