Fork us on GitHub Follow us on Facebook Follow us on Twitter

Changeset 669f5cae in mainline


Ignore:
Timestamp:
2012-08-16T08:44:34Z (9 years ago)
Author:
Vojtech Horky <vojtechhorky@…>
Branches:
lfn, master
Children:
6e9e12b
Parents:
cddcc4a3
Message:

Allow setting default log level

Currently, it does not affect existing clients.

Files:
4 added
8 edited

Legend:

Unmodified
Added
Removed
  • boot/Makefile.common

    rcddcc4a3 r669f5cae  
    166166        $(USPACE_PATH)/app/loc/loc \
    167167        $(USPACE_PATH)/app/logview/logview \
     168        $(USPACE_PATH)/app/logset/logset \
    168169        $(USPACE_PATH)/app/mkfat/mkfat \
    169170        $(USPACE_PATH)/app/mkexfat/mkexfat \
  • uspace/Makefile

    rcddcc4a3 r669f5cae  
    4747        app/klog \
    4848        app/loc \
     49        app/logset \
    4950        app/logview \
    5051        app/mkfat \
  • uspace/lib/c/Makefile

    rcddcc4a3 r669f5cae  
    9797        generic/io/printf.c \
    9898        generic/io/log.c \
     99        generic/io/logctl.c \
    99100        generic/io/klog.c \
    100101        generic/io/snprintf.c \
  • uspace/lib/c/include/ipc/logger.h

    rcddcc4a3 r669f5cae  
    3737
    3838typedef enum {
     39        LOGGER_CTL_GET_DEFAULT_LEVEL = IPC_FIRST_USER_METHOD,
     40        LOGGER_CTL_SET_DEFAULT_LEVEL
     41} logger_control_request_t;
     42
     43typedef enum {
    3944        LOGGER_REGISTER = IPC_FIRST_USER_METHOD,
    4045        LOGGER_MESSAGE,
     
    4853
    4954typedef enum {
     55        /** Interface for controlling logger behavior. */
     56        LOGGER_INTERFACE_CONTROL,
    5057        /** Interface for servers writing to the log. */
    5158        LOGGER_INTERFACE_SINK,
  • uspace/srv/logger/Makefile

    rcddcc4a3 r669f5cae  
    3232
    3333SOURCES = \
     34        level.c \
    3435        main.c \
    3536        namespace.c
  • uspace/srv/logger/logger.h

    rcddcc4a3 r669f5cae  
    4242#include <fibril_synch.h>
    4343
    44 #define DEFAULT_LOGGING_LEVEL LVL_NOTE
    45 
    4644#define NAME "logger"
    4745#define MAX_NAMESPACE_LENGTH 256
     
    7169log_message_t *namespace_get_next_message(logging_namespace_t *);
    7270
     71log_level_t get_default_logging_level(void);
     72int set_default_logging_level(log_level_t);
     73
    7374#endif
    7475
  • uspace/srv/logger/main.c

    rcddcc4a3 r669f5cae  
    4747#include "logger.h"
    4848
     49static void connection_handler_control(void)
     50{
     51        printf(NAME "/control: new client.\n");
     52
     53        while (true) {
     54                ipc_call_t call;
     55                ipc_callid_t callid = async_get_call(&call);
     56
     57                if (!IPC_GET_IMETHOD(call))
     58                        break;
     59
     60                int rc;
     61
     62                switch (IPC_GET_IMETHOD(call)) {
     63                case LOGGER_CTL_GET_DEFAULT_LEVEL:
     64                        async_answer_1(callid, EOK, get_default_logging_level());
     65                        break;
     66                case LOGGER_CTL_SET_DEFAULT_LEVEL:
     67                        rc = set_default_logging_level(IPC_GET_ARG1(call));
     68                        async_answer_0(callid, rc);
     69                        break;
     70                default:
     71                        async_answer_0(callid, EINVAL);
     72                        break;
     73                }
     74        }
     75
     76        printf(NAME "/control: client terminated.\n");
     77}
     78
    4979static logging_namespace_t *find_namespace_and_attach_writer(void)
    5080{
     
    74104static int handle_receive_message(logging_namespace_t *namespace, int level)
    75105{
    76         bool skip_message = (level > DEFAULT_LOGGING_LEVEL) && !namespace_has_reader(namespace, level);
     106        bool skip_message = (level > (int)get_default_logging_level()) && !namespace_has_reader(namespace, level);
    77107        if (skip_message) {
    78108                /* Abort the actual message buffer transfer. */
     
    221251
    222252        switch (iface) {
     253        case LOGGER_INTERFACE_CONTROL:
     254                async_answer_0(iid, EOK);
     255                connection_handler_control();
     256                break;
    223257        case LOGGER_INTERFACE_SINK:
    224258                /* First call has to be the registration. */
  • uspace/srv/logger/namespace.c

    rcddcc4a3 r669f5cae  
    126126        }
    127127
    128         namespace->logfile_level = DEFAULT_LOGGING_LEVEL;
     128        namespace->logfile_level = get_default_logging_level();
    129129
    130130        fibril_mutex_initialize(&namespace->guard);
     
    267267void namespace_add_message(logging_namespace_t *namespace, const char *message, log_level_t level)
    268268{
    269         if (level <= DEFAULT_LOGGING_LEVEL) {
     269        if (level <= get_default_logging_level()) {
    270270                printf("[%s %d]: %s\n", namespace->name, level, message);
    271271        }
Note: See TracChangeset for help on using the changeset viewer.