Pip
Architecture-dependent parts of Pip: MAL, IAL and boot
armv7/boot/include/debug.h
Go to the documentation of this file.
1 /*******************************************************************************/
2 /* © Université de Lille, The Pip Development Team (2015-2021) */
3 /* */
4 /* This software is a computer program whose purpose is to run a minimal, */
5 /* hypervisor relying on proven properties such as memory isolation. */
6 /* */
7 /* This software is governed by the CeCILL license under French law and */
8 /* abiding by the rules of distribution of free software. You can use, */
9 /* modify and/ or redistribute the software under the terms of the CeCILL */
10 /* license as circulated by CEA, CNRS and INRIA at the following URL */
11 /* "http://www.cecill.info". */
12 /* */
13 /* As a counterpart to the access to the source code and rights to copy, */
14 /* modify and redistribute granted by the license, users are provided only */
15 /* with a limited warranty and the software's author, the holder of the */
16 /* economic rights, and the successive licensors have only limited */
17 /* liability. */
18 /* */
19 /* In this respect, the user's attention is drawn to the risks associated */
20 /* with loading, using, modifying and/or developing or reproducing the */
21 /* software by the user in light of its specific status of free software, */
22 /* that may mean that it is complicated to manipulate, and that also */
23 /* therefore means that it is reserved for developers and experienced */
24 /* professionals having in-depth computer knowledge. Users are therefore */
25 /* encouraged to load and test the software's suitability as regards their */
26 /* requirements in conditions enabling the security of their systems and/or */
27 /* data to be ensured and, more generally, to use and operate it in the */
28 /* same conditions as regards security. */
29 /* */
30 /* The fact that you are presently reading this means that you have had */
31 /* knowledge of the CeCILL license and that you accept its terms. */
32 /*******************************************************************************/
33 
34 #ifndef DEF_DEBUG_H_
35 #define DEF_DEBUG_H_
36 #include <printf.h>
37 
39 
40 static unsigned debug_color[] = {
41  [ERROR] = 31,
42  [WARNING] = 33,
43  [INFO] = 32,
44  [TRACE] = 36,
45 };
46 
47 #ifndef LOGLEVEL
48 #define LOGLEVEL ERROR
49 #endif
50 
51 //#define DEBUG(lvl, fmt, ...) if (LOGLEVEL >= lvl){ printf("[" #lvl "] " fmt, #__VA_ARGS__);}
52 #define DEBUG(lvl, fmt, ...) if (LOGLEVEL >= lvl) { printf("\e[35m%s\e[0m:\e[31m%d\e[0m: " "\e[%dm" fmt "\e[0m", __FILE__, __LINE__, debug_color[lvl], ##__VA_ARGS__);}
53 
54 /* FIXME: MOVE THIS
55  * and also: mask interrupts */
56 #define PANIC(fmt,...) { DEBUG(ERROR,fmt "\n", ##__VA_ARGS__); for(;;); }
57 
58 #endif
Definition: armv7/boot/include/debug.h:38
static unsigned debug_color[]
Definition: armv7/boot/include/debug.h:40
Definition: armv7/boot/include/debug.h:38
loglevel_e
Definition: armv7/boot/include/debug.h:38
Definition: armv7/boot/include/debug.h:38
Definition: armv7/boot/include/debug.h:38