Developer World
Spresense SDK Library v3.2.0-ebc0364
al_debug.h
1/****************************************************************************
2 * modules/include/audiolite/al_debug.h
3 *
4 * Copyright 2023 Sony Semiconductor Solutions Corporation
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in
14 * the documentation and/or other materials provided with the
15 * distribution.
16 * 3. Neither the name of Sony Semiconductor Solutions Corporation nor
17 * the names of its contributors may be used to endorse or promote
18 * products derived from this software without specific prior written
19 * permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
28 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
29 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 * POSSIBILITY OF SUCH DAMAGE.
33 *
34 ****************************************************************************/
35
36#ifndef __INCLUDE_AUDIOLITE_DEBUG_H
37#define __INCLUDE_AUDIOLITE_DEBUG_H
38
39/****************************************************************************
40 * Included Files
41 ****************************************************************************/
42
43#include <nuttx/config.h>
44
45#include <stdio.h>
46#include <unistd.h>
47
48/****************************************************************************
49 * Pre-processor Definitions
50 ****************************************************************************/
51
52#define al_debugmessage(T,...) \
53 do { \
54 printf("\n" T " %s:%s(%d) : \n" T " ", \
55 __FILE__, __PRETTY_FUNCTION__, __LINE__); \
56 printf(__VA_ARGS__); \
57 } while(0)
58
59#ifdef CONFIG_AL_DEBUG_ERR
60#define al_derror(...) al_debugmessage("ALD[ERR]", __VA_ARGS__)
61#else
62#define al_derror(...)
63#endif
64
65#ifdef CONFIG_AL_DEBUG_WRN
66#define al_dwarn(...) al_debugmessage("ALD[WRN]", __VA_ARGS__)
67#else
68#define al_dwarn(...)
69#endif
70
71#ifdef CONFIG_AL_DEBUG_DBG
72#define al_ddebug(...) al_debugmessage("ALD[DBG]", __VA_ARGS__)
73#else
74#define al_ddebug(...)
75#endif
76
77#ifdef CONFIG_AL_DEBUG_INF
78#define al_dinfo(...) al_debugmessage("ALD[INF]", __VA_ARGS__)
79#else
80#define al_dinfo(...)
81#endif
82
83#endif /* __INCLUDE_AUDIOLITE_DEBUG_H */