Handle both IDE channels in the same driver instance
[helenos.git] / uspace / srv / logger / logger.h
blobc69342f1232040dc8d6f5da96276fb53e199d64a
1 /*
2 * Copyright (c) 2012 Vojtech Horky
3 * All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
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
30 * @{
32 /** @file Common logger service definitions.
35 #ifndef LOGGER_H_
36 #define LOGGER_H_
38 #include <adt/list.h>
39 #include <adt/prodcons.h>
40 #include <io/log.h>
41 #include <async.h>
42 #include <stdbool.h>
43 #include <fibril_synch.h>
44 #include <stdio.h>
46 #define NAME "logger"
47 #define LOG_LEVEL_USE_DEFAULT (LVL_LIMIT + 1)
49 #ifdef LOGGER_LOG
50 #define logger_log(fmt, ...) printf(NAME ": " fmt, ##__VA_ARGS__)
51 #else
52 #define logger_log(fmt, ...) (void)0
53 #endif
55 typedef struct logger_log logger_log_t;
57 typedef struct {
58 fibril_mutex_t guard;
59 char *filename;
60 FILE *logfile;
61 } logger_dest_t;
63 struct logger_log {
64 link_t link;
66 size_t ref_counter;
68 fibril_mutex_t guard;
70 char *name;
71 char *full_name;
72 logger_log_t *parent;
73 log_level_t logged_level;
74 logger_dest_t *dest;
77 #define MAX_REFERENCED_LOGS_PER_CLIENT 100
79 typedef struct {
80 size_t logs_count;
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 *);
105 #endif
107 /** @}