| /* ---------------------------------------------------------------------------- | |
| * ATMEL Microcontroller Software Support | |
| * ---------------------------------------------------------------------------- | |
| * Copyright (c) 2008, Atmel Corporation | |
| * | |
| * All rights reserved. | |
| * | |
| * Redistribution and use in source and binary forms, with or without | |
| * modification, are permitted provided that the following conditions are met: | |
| * | |
| * - Redistributions of source code must retain the above copyright notice, | |
| * this list of conditions and the disclaimer below. | |
| * | |
| * Atmel's name may not be used to endorse or promote products derived from | |
| * this software without specific prior written permission. | |
| * | |
| * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR | |
| * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
| * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE | |
| * DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, | |
| * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, | |
| * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF | |
| * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | |
| * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, | |
| * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
| * ---------------------------------------------------------------------------- | |
| */ | |
| /** | |
| * \file | |
| * | |
| * \par Purpose | |
| * | |
| * Standard output methods for reporting debug information, warnings and | |
| * errors, which can be easily be turned on/off. | |
| * | |
| * \par Usage | |
| * -# Initialize the debug message port in application, for stdio printf(). | |
| * -# Uses the TRACE_DEBUG(), TRACE_INFO(), TRACE_WARNING(), TRACE_ERROR() | |
| * TRACE_FATAL() macros to output traces throughout the program. | |
| * -# Each type of trace has a level : Debug 5, Info 4, Warning 3, Error 2 | |
| * and Fatal 1. Disable a group of traces by changing the value of | |
| * TRACE_LEVEL during compilation; traces with a level bigger than TRACE_LEVEL | |
| * are not generated. To generate no trace, use the reserved value 0. | |
| * -# Trace disabling can be static or dynamic. If dynamic disabling is selected | |
| * the trace level can be modified in runtime. If static disabling is selected | |
| * the disabled traces are not compiled. | |
| * | |
| * \par traceLevels Trace level description | |
| * -# TRACE_DEBUG (5): Traces whose only purpose is for debugging the program, | |
| * and which do not produce meaningful information otherwise. | |
| * -# TRACE_INFO (4): Informational trace about the program execution. Should | |
| * enable the user to see the execution flow. | |
| * -# TRACE_WARNING (3): Indicates that a minor error has happened. In most case | |
| * it can be discarded safely; it may even be expected. | |
| * -# TRACE_ERROR (2): Indicates an error which may not stop the program execution, | |
| * but which indicates there is a problem with the code. | |
| * -# TRACE_FATAL (1): Indicates a major error which prevents the program from going | |
| * any further. | |
| */ | |
| #ifndef _USBLIB_TRACE_H | |
| #define _USBLIB_TRACE_H | |
| /* | |
| * Headers | |
| */ | |
| #include <stdio.h> | |
| /* | |
| * Global Definitions | |
| */ | |
| /** Softpack Version */ | |
| #define USBLIB_VERSION "0.1" | |
| #define TRACE_LEVEL_DEBUG 5 | |
| #define TRACE_LEVEL_INFO 4 | |
| #define TRACE_LEVEL_WARNING 3 | |
| #define TRACE_LEVEL_ERROR 2 | |
| #define TRACE_LEVEL_FATAL 1 | |
| #define TRACE_LEVEL_NO_TRACE 0 | |
| /* By default, all traces are output except the debug one. */ | |
| #if !defined(TRACE_LEVEL) | |
| #define TRACE_LEVEL TRACE_LEVEL_INFO | |
| #endif | |
| /* By default, trace level is static (not dynamic) */ | |
| #if !defined(DYN_TRACES) | |
| #define DYN_TRACES 0 | |
| #endif | |
| #if defined(NOTRACE) | |
| #error "Error: NOTRACE has to be not defined !" | |
| #endif | |
| #undef NOTRACE | |
| #if (DYN_TRACES==0) | |
| #if (TRACE_LEVEL == TRACE_LEVEL_NO_TRACE) | |
| #define NOTRACE | |
| #endif | |
| #endif | |
| /* ------------------------------------------------------------------------------ | |
| * Global Macros | |
| * ------------------------------------------------------------------------------ | |
| */ | |
| #ifndef DYNTRACE | |
| #define DYNTRACE 0 | |
| #endif | |
| /** | |
| * Outputs a formatted string using 'printf' if the log level is high | |
| * enough. Can be disabled by defining TRACE_LEVEL=0 during compilation. | |
| * \param ... Additional parameters depending on formatted string. | |
| */ | |
| #if defined(NOTRACE) | |
| /* Empty macro */ | |
| #define TRACE_DEBUG(...) { } | |
| #define TRACE_INFO(...) { } | |
| #define TRACE_WARNING(...) { } | |
| #define TRACE_ERROR(...) { } | |
| #define TRACE_FATAL(...) { while(1); } | |
| #define TRACE_DEBUG_WP(...) { } | |
| #define TRACE_INFO_WP(...) { } | |
| #define TRACE_WARNING_WP(...) { } | |
| #define TRACE_ERROR_WP(...) { } | |
| #define TRACE_FATAL_WP(...) { while(1); } | |
| #elif (DYN_TRACES == 1) | |
| /* Trace output depends on dwTraceLevel value */ | |
| #define TRACE_DEBUG(...) { if (dwTraceLevel >= TRACE_LEVEL_DEBUG) { printf("-D- " __VA_ARGS__); } } | |
| #define TRACE_INFO(...) { if (dwTraceLevel >= TRACE_LEVEL_INFO) { printf("-I- " __VA_ARGS__); } } | |
| #define TRACE_WARNING(...) { if (dwTraceLevel >= TRACE_LEVEL_WARNING) { printf("-W- " __VA_ARGS__); } } | |
| #define TRACE_ERROR(...) { if (dwTraceLevel >= TRACE_LEVEL_ERROR) { printf("-E- " __VA_ARGS__); } } | |
| #define TRACE_FATAL(...) { if (dwTraceLevel >= TRACE_LEVEL_FATAL) { printf("-F- " __VA_ARGS__); while(1); } } | |
| #define TRACE_DEBUG_WP(...) { if (dwTraceLevel >= TRACE_LEVEL_DEBUG) { printf(__VA_ARGS__); } } | |
| #define TRACE_INFO_WP(...) { if (dwTraceLevel >= TRACE_LEVEL_INFO) { printf(__VA_ARGS__); } } | |
| #define TRACE_WARNING_WP(...) { if (dwTraceLevel >= TRACE_LEVEL_WARNING) { printf(__VA_ARGS__); } } | |
| #define TRACE_ERROR_WP(...) { if (dwTraceLevel >= TRACE_LEVEL_ERROR) { printf(__VA_ARGS__); } } | |
| #define TRACE_FATAL_WP(...) { if (dwTraceLevel >= TRACE_LEVEL_FATAL) { printf(__VA_ARGS__); while(1); } } | |
| #else | |
| /* Trace compilation depends on TRACE_LEVEL value */ | |
| #if (TRACE_LEVEL >= TRACE_LEVEL_DEBUG) | |
| #define TRACE_DEBUG(...) { printf("-D- " __VA_ARGS__); } | |
| #define TRACE_DEBUG_WP(...) { printf(__VA_ARGS__); } | |
| #else | |
| #define TRACE_DEBUG(...) { } | |
| #define TRACE_DEBUG_WP(...) { } | |
| #endif | |
| #if (TRACE_LEVEL >= TRACE_LEVEL_INFO) | |
| #define TRACE_INFO(...) { printf("-I- " __VA_ARGS__); } | |
| #define TRACE_INFO_WP(...) { printf(__VA_ARGS__); } | |
| #else | |
| #define TRACE_INFO(...) { } | |
| #define TRACE_INFO_WP(...) { } | |
| #endif | |
| #if (TRACE_LEVEL >= TRACE_LEVEL_WARNING) | |
| #define TRACE_WARNING(...) { printf("-W- " __VA_ARGS__); } | |
| #define TRACE_WARNING_WP(...) { printf(__VA_ARGS__); } | |
| #else | |
| #define TRACE_WARNING(...) { } | |
| #define TRACE_WARNING_WP(...) { } | |
| #endif | |
| #if (TRACE_LEVEL >= TRACE_LEVEL_ERROR) | |
| #define TRACE_ERROR(...) { printf("-E- " __VA_ARGS__); } | |
| #define TRACE_ERROR_WP(...) { printf(__VA_ARGS__); } | |
| #else | |
| #define TRACE_ERROR(...) { } | |
| #define TRACE_ERROR_WP(...) { } | |
| #endif | |
| #if (TRACE_LEVEL >= TRACE_LEVEL_FATAL) | |
| #define TRACE_FATAL(...) { printf("-F- " __VA_ARGS__); while(1); } | |
| #define TRACE_FATAL_WP(...) { printf(__VA_ARGS__); while(1); } | |
| #else | |
| #define TRACE_FATAL(...) { while(1); } | |
| #define TRACE_FATAL_WP(...) { while(1); } | |
| #endif | |
| #endif | |
| /** | |
| * Exported variables | |
| */ | |
| /** Depending on DYN_TRACES, dwTraceLevel is a modifable runtime variable or a define */ | |
| #if !defined(NOTRACE) && (DYN_TRACES == 1) | |
| extern uint32_t dwTraceLevel ; | |
| #endif | |
| #endif /* #ifndef _USBLIB_TRACE_H */ | |