1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/core/include/debug.h

86 lines
2.2 KiB
C
Raw Normal View History

/*
* Copyright (C) 2014 Freie Universität Berlin
*
2013-11-22 20:47:05 +01:00
* This file is subject to the terms and conditions of the GNU Lesser General
* Public License. See the file LICENSE in the top level directory for more
* details.
*/
/**
* @addtogroup core_util
* @{
*
* @file debug.h
* @brief Debug-header
*
* #define ENABLE_DEBUG, include this and then use DEBUG as printf you can toggle.
*
* @author Freie Universität Berlin, Computer Systems & Telematics
* @author Kaspar Schleiser <kaspar@schleiser.de>
*/
#ifndef __DEBUG_H
#define __DEBUG_H
#include <stdio.h>
2014-03-03 10:37:50 +01:00
#include "sched.h"
/**
* @name Print debug information if the calling thread stack is large enough
*
* Use this macro the same as printf. When DEVHELP is defined inside an
* implementation file, all usages of *DEBUG_PRINTF* will print the given
* information to std-out. If DEVHELP is not set, all occurrences of
* *DEBUG_PRINTF* will be ignored.
*
* @{
*/
2014-03-03 00:25:09 +01:00
#if DEVELHELP
#include "cpu-conf.h"
#define DEBUG_PRINT(...) \
do { \
2014-03-19 14:22:26 +01:00
if ((active_thread == NULL) || (active_thread->stack_size > KERNEL_CONF_STACKSIZE_PRINTF)) { \
2014-03-03 00:25:09 +01:00
printf(__VA_ARGS__); \
} \
else { \
puts("Cannot debug, stack too small"); \
} \
} while (0)
#else
#define DEBUG_PRINT(...) printf(__VA_ARGS__)
#endif
/** @} */
2014-03-03 00:25:09 +01:00
/**
* @brief Print debug information to std-out
*
* If *ENABLE_DEBUG* is defined inside an implementation file, all calls to
* *DEBUG* and *DEBUGF* will work the same as *printf* and output the given
* information to stdout. If *ENABLE_DEBUG* is not defined, all calls to
* *DEBUG* and *DEBUGF* will be ignored.
*
* In addition to just printing the given information *DEBUGF* will further
* print extended debug information about the current thread and function.
*
* @{
*/
#if ENABLE_DEBUG
2014-03-03 10:37:50 +01:00
#include "tcb.h"
2014-03-03 00:25:09 +01:00
#define DEBUG(...) DEBUG_PRINT(__VA_ARGS__)
2014-03-03 10:37:50 +01:00
#define DEBUGF(...) \
do { \
DEBUG_PRINT("DEBUG(%s): %s:%d in %s: ", \
2014-03-19 14:22:26 +01:00
active_thread ? active_thread->name : "NO THREAD", \
__FILE__, __LINE__, __func__); \
2014-03-03 10:37:50 +01:00
DEBUG_PRINT(__VA_ARGS__); \
} while (0)
#undef ENABLE_DEBUG
#else
#define DEBUG(...)
2014-03-03 10:37:50 +01:00
#define DEBUGF(...)
#endif
/** @} */
#endif /* __DEBUG_H */
/** @} */