source: mainline/kernel/generic/include/debug.h@ b5382d4f

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since b5382d4f was da52547, checked in by Martin Decky <martin@…>, 15 years ago

add early_putchar() which can be used to do early kernel console output for debugging purposes
(the availability of this feature depends on each platform and specific configuration, currently it works only on ia32/amd64 with EGA and no framebuffer)
instrument more kernel functions
mark some functions as no_instrument (context_restore(), overlaps(), main_bsp())

  • Property mode set to 100644
File size: 3.1 KB
Line 
1/*
2 * Copyright (c) 2005 Martin Decky
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup genericdebug
30 * @{
31 */
32/** @file
33 */
34
35#ifndef KERN_DEBUG_H_
36#define KERN_DEBUG_H_
37
38#include <panic.h>
39#include <symtab.h>
40
41#define CALLER ((uintptr_t) __builtin_return_address(0))
42
43#ifdef CONFIG_DEBUG
44
45/** Debugging ASSERT macro
46 *
47 * If CONFIG_DEBUG is set, the ASSERT() macro
48 * evaluates expr and if it is false raises
49 * kernel panic.
50 *
51 * @param expr Expression which is expected to be true.
52 *
53 */
54#define ASSERT(expr) \
55 do { \
56 if (!(expr)) \
57 panic_assert("%s", #expr); \
58 } while (0)
59
60/** Debugging verbose ASSERT macro
61 *
62 * If CONFIG_DEBUG is set, the ASSERT() macro
63 * evaluates expr and if it is false raises
64 * kernel panic. The panic message contains also
65 * the supplied message.
66 *
67 * @param expr Expression which is expected to be true.
68 * @param msg Additional message to show (string).
69 *
70 */
71#define ASSERT_VERBOSE(expr, msg) \
72 do { \
73 if (!(expr)) \
74 panic_assert("%s, %s", #expr, msg); \
75 } while (0)
76
77#else /* CONFIG_DEBUG */
78
79#define ASSERT(expr)
80#define ASSERT_VERBOSE(expr, msg)
81
82#endif /* CONFIG_DEBUG */
83
84#ifdef CONFIG_LOG
85
86/** Extensive logging output macro
87 *
88 * If CONFIG_LOG is set, the LOG() macro
89 * will print whatever message is indicated plus
90 * an information about the location.
91 *
92 */
93#define LOG(format, ...) \
94 do { \
95 printf("%s() from %s at %s:%u: " format "\n", __func__, \
96 symtab_fmt_name_lookup(CALLER), __FILE__, __LINE__, \
97 ##__VA_ARGS__); \
98 } while (0)
99
100#else /* CONFIG_LOG */
101
102#define LOG(format, ...)
103
104#endif /* CONFIG_LOG */
105
106#ifdef CONFIG_TRACE
107
108extern void __cyg_profile_func_enter(void *, void *);
109extern void __cyg_profile_func_exit(void *, void *);
110
111#endif /* CONFIG_TRACE */
112
113#endif
114
115/** @}
116 */
Note: See TracBrowser for help on using the repository browser.