1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

core: log: introduce logging API

This commit is contained in:
Kaspar Schleiser 2015-02-25 16:31:03 +01:00
parent 684a7d5b42
commit c944d54171
12 changed files with 184 additions and 8 deletions

View File

@ -249,3 +249,8 @@ endif
ifneq (,$(filter ng_at86rf2%,$(USEMODULE))) ifneq (,$(filter ng_at86rf2%,$(USEMODULE)))
USEMODULE += ng_at86rf2xx USEMODULE += ng_at86rf2xx
endif endif
# if any log_* is used, also use LOG pseudomodule
ifneq (,$(filter log_%,$(USEMODULE)))
USEMODULE += log
endif

View File

@ -6,6 +6,8 @@ PSEUDOMODULES += ng_ipv6_router_default
PSEUDOMODULES += pktqueue PSEUDOMODULES += pktqueue
PSEUDOMODULES += ng_netbase PSEUDOMODULES += ng_netbase
PSEUDOMODULES += ng_sixlowpan_default PSEUDOMODULES += ng_sixlowpan_default
PSEUDOMODULES += log
PSEUDOMODULES += log_printfnoformat
# include variants of the AT86RF2xx drivers as pseudo modules # include variants of the AT86RF2xx drivers as pseudo modules
PSEUDOMODULES += ng_at86rf23% PSEUDOMODULES += ng_at86rf23%

View File

@ -34,6 +34,8 @@
#define ENABLE_DEBUG (0) #define ENABLE_DEBUG (0)
#include "debug.h" #include "debug.h"
#include "log.h"
#include "hwtimer.h" #include "hwtimer.h"
#include "hwtimer_cpu.h" #include "hwtimer_cpu.h"
#include "arch/hwtimer_arch.h" #include "arch/hwtimer_arch.h"
@ -157,7 +159,7 @@ static int _hwtimer_set(unsigned long offset, void (*callback)(void*), void *ptr
if (n == -1) { if (n == -1) {
restoreIRQ(state); restoreIRQ(state);
puts("No hwtimer left."); LOG_WARNING("No hwtimer left.");
return -1; return -1;
} }

103
core/include/log.h Normal file
View File

@ -0,0 +1,103 @@
/*
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de>
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @addtogroup core_util
* @{
*
* @brief System logging header
*
* This header offers a bunch of "LOG_*" functions that, with the default
* implementation, just use printf, but honour a verbosity level.
*
* If desired, it is possible to implement a log module which then will be used
* instead the default printf-based implementation. In order to do so, the log
* module has to
*
* 1. provide "log_module.h"
* 2. have a name starting with "log_" *or* depend on the pseudo-module LOG,
* 3. implement log_write()
*
* See "sys/log/log_printfnoformat" for an example.
*
* @author Kaspar Schleiser <kaspar@schleiser.de>
*/
#ifndef __LOG_H
#define __LOG_H
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief defined log levels
*
* These are the logging levels a user can choose.
* The idea is to set LOG_LEVEL to one of these values in the application's Makefile.
* That will restrict output of log statements to those with equal or lower log level.
*
* The default log level is LOG_INFO, which will print every message.
*
* The log function calls of filtered messages will be optimized out at compile
* time, so a lower log level might result in smaller code size.
*/
enum {
LOG_NONE, /**< Lowest log level, will output nothing */
LOG_ERROR, /**< Error log level, will print only critical,
non-recoverable errors like hardware initialization
failures */
LOG_WARNING, /**< Warning log level, will print warning messages for
temporary errors */
LOG_INFO, /**< Informational log level, will print purely
informational messages like successful system bootup,
network link state, ...*/
LOG_DEBUG, /**< Debug log level, printing developer stuff considered
too verbose for production use */
LOG_ALL /**< print everything */
};
#ifndef LOG_LEVEL
/**
* @brief Default log level define
*/
#define LOG_LEVEL LOG_INFO
#endif
/**
* @brief Log message if level <= LOG_LEVEL
*/
#define LOG(level, ...) if (level <= LOG_LEVEL) log_write(level, __VA_ARGS__)
/**
* @brief logging convenience defines
* @{
*/
#define LOG_ERROR(...) LOG(LOG_ERROR, __VA_ARGS__)
#define LOG_WARNING(...) LOG(LOG_WARNING, __VA_ARGS__)
#define LOG_INFO(...) LOG(LOG_INFO, __VA_ARGS__)
#define LOG_DEBUG(...) LOG(LOG_DEBUG, __VA_ARGS__)
/** @} */
#ifdef MODULE_LOG
#include "log_module.h"
#else
#include <stdio.h>
/**
* @brief Default log_write function, just maps to printf
*/
#define log_write(level, ...) printf(__VA_ARGS__)
#endif
#ifdef __cplusplus
}
#endif
#endif /* __LOG_H */
/** @} */

View File

@ -18,7 +18,6 @@
* @} * @}
*/ */
#include <stdio.h>
#include <stdint.h> #include <stdint.h>
#include <stdbool.h> #include <stdbool.h>
#include <errno.h> #include <errno.h>
@ -32,6 +31,7 @@
#include "thread.h" #include "thread.h"
#include "hwtimer.h" #include "hwtimer.h"
#include "irq.h" #include "irq.h"
#include "log.h"
#define ENABLE_DEBUG (0) #define ENABLE_DEBUG (0)
#include "debug.h" #include "debug.h"
@ -82,19 +82,19 @@ static char idle_stack[KERNEL_CONF_STACKSIZE_IDLE];
void kernel_init(void) void kernel_init(void)
{ {
(void) disableIRQ(); (void) disableIRQ();
printf("kernel_init(): This is RIOT! (Version: %s)\n", RIOT_VERSION); LOG_INFO("kernel_init(): This is RIOT! (Version: %s)\n", RIOT_VERSION);
hwtimer_init(); hwtimer_init();
if (thread_create(idle_stack, sizeof(idle_stack), PRIORITY_IDLE, CREATE_WOUT_YIELD | CREATE_STACKTEST, idle_thread, NULL, idle_name) < 0) { if (thread_create(idle_stack, sizeof(idle_stack), PRIORITY_IDLE, CREATE_WOUT_YIELD | CREATE_STACKTEST, idle_thread, NULL, idle_name) < 0) {
printf("kernel_init(): error creating idle task.\n"); LOG_ERROR("kernel_init(): error creating idle task.\n");
} }
if (thread_create(main_stack, sizeof(main_stack), PRIORITY_MAIN, CREATE_WOUT_YIELD | CREATE_STACKTEST, main_trampoline, NULL, main_name) < 0) { if (thread_create(main_stack, sizeof(main_stack), PRIORITY_MAIN, CREATE_WOUT_YIELD | CREATE_STACKTEST, main_trampoline, NULL, main_name) < 0) {
printf("kernel_init(): error creating main task.\n"); LOG_ERROR("kernel_init(): error creating main task.\n");
} }
printf("kernel_init(): jumping into first task...\n"); LOG_INFO("kernel_init(): jumping into first task...\n");
cpu_switch_context_exit(); cpu_switch_context_exit();
} }

View File

@ -17,6 +17,7 @@
*/ */
#include "lifo.h" #include "lifo.h"
#include "log.h"
#define ENABLE_DEBUG (0) #define ENABLE_DEBUG (0)
#include "debug.h" #include "debug.h"
@ -42,7 +43,7 @@ void lifo_insert(int *array, int i)
#if DEVELHELP #if DEVELHELP
if ((array[index] != -1) && (array[0] != -1)) { if ((array[index] != -1) && (array[0] != -1)) {
printf("lifo_insert: overwriting array[%i] == %i with %i\n\n\n\t\tThe lifo is broken now.\n\n\n", index, array[index], array[0]); LOG_WARNING("lifo_insert: overwriting array[%i] == %i with %i\n\n\n\t\tThe lifo is broken now.\n\n\n", index, array[index], array[0]);
} }
#endif #endif

View File

@ -29,6 +29,7 @@
#include "irq.h" #include "irq.h"
#include "thread.h" #include "thread.h"
#include "irq.h" #include "irq.h"
#include "log.h"
#if SCHEDSTATISTICS #if SCHEDSTATISTICS
#include "hwtimer.h" #include "hwtimer.h"
@ -86,7 +87,7 @@ int sched_run(void)
#ifdef SCHED_TEST_STACK #ifdef SCHED_TEST_STACK
if (*((uintptr_t *) active_thread->stack_start) != (uintptr_t) active_thread->stack_start) { if (*((uintptr_t *) active_thread->stack_start) != (uintptr_t) active_thread->stack_start) {
printf("scheduler(): stack overflow detected, pid=%" PRIkernel_pid "\n", active_thread->pid); LOG_WARNING("scheduler(): stack overflow detected, pid=%" PRIkernel_pid "\n", active_thread->pid);
} }
#endif #endif

View File

@ -143,6 +143,9 @@ endif
ifneq (,$(filter hwtimer_compat,$(USEMODULE))) ifneq (,$(filter hwtimer_compat,$(USEMODULE)))
DIRS += compat/hwtimer DIRS += compat/hwtimer
endif endif
ifneq (,$(filter log_%,$(USEMODULE)))
DIRS += log
endif
DIRS += $(dir $(wildcard $(addsuffix /Makefile, ${USEMODULE}))) DIRS += $(dir $(wildcard $(addsuffix /Makefile, ${USEMODULE})))

View File

@ -90,3 +90,6 @@ ifneq (,$(filter embunit,$(USEMODULE)))
CFLAGS += -DOUTPUT=OUTPUT_COMPILER CFLAGS += -DOUTPUT=OUTPUT_COMPILER
endif endif
endif endif
ifneq (,$(filter log_%,$(USEMODULE)))
include $(RIOTBASE)/sys/log/Makefile.include
endif

3
sys/log/Makefile Normal file
View File

@ -0,0 +1,3 @@
DIRS += $(dir $(wildcard $(addsuffix /Makefile, ${USEMODULE})))
include $(RIOTBASE)/Makefile.base

3
sys/log/Makefile.include Normal file
View File

@ -0,0 +1,3 @@
ifneq (,$(filter log_printfnoformat,$(USEMODULE)))
USEMODULE_INCLUDES += $(RIOTBASE)/sys/log/log_printfnoformat
endif

View File

@ -0,0 +1,50 @@
/*
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de>
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup sys_log_printfnoformat puts log module
* @ingroup sys
* @brief This module implements an example logging module
* @{
*
* @file log_module.h
* @brief log_module header
*
* @author Jason Linehan <patientulysses@gmail.com>
* @author Christian Mehlis <mehlis@inf.fu-berlin.de>
* @author Kaspar Schleiser <kaspar@schleiser.de>
*/
#ifndef __LOG_FORMAT_H
#define __LOG_FORMAT_H
#include <stdio.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief log_write overridden function
*
* This example function will only print the log's format string.
* Use it where printf might be too heavy.
*
* @param[in] level (unused)
* @param[in] format String that the function will print
*/
static inline void log_write(unsigned level, const char *format, ...) {
(void)level;
puts(format);
}
#ifdef __cplusplus
}
#endif
/**@}*/
#endif /* __LOG_FORMAT_H */