blob: 75845f950814ca8beac0bf2941eea886d8446271 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Nathan Scott7b718762005-11-02 14:58:39 +11002 * Copyright (c) 2000-2005 Silicon Graphics, Inc.
3 * All Rights Reserved.
Linus Torvalds1da177e2005-04-16 15:20:36 -07004 *
Nathan Scott7b718762005-11-02 14:58:39 +11005 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public License as
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 * published by the Free Software Foundation.
8 *
Nathan Scott7b718762005-11-02 14:58:39 +11009 * This program is distributed in the hope that it would be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
Linus Torvalds1da177e2005-04-16 15:20:36 -070013 *
Nathan Scott7b718762005-11-02 14:58:39 +110014 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write the Free Software Foundation,
16 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Linus Torvalds1da177e2005-04-16 15:20:36 -070017 */
18#ifndef __XFS_SUPPORT_DEBUG_H__
19#define __XFS_SUPPORT_DEBUG_H__
20
21#include <stdarg.h>
22
23#define CE_DEBUG 7 /* debug */
24#define CE_CONT 6 /* continuation */
25#define CE_NOTE 5 /* notice */
26#define CE_WARN 4 /* warning */
27#define CE_ALERT 1 /* alert */
28#define CE_PANIC 0 /* panic */
29
Christoph Hellwigda1650a2005-11-02 10:21:35 +110030extern void icmn_err(int, char *, va_list)
31 __attribute__ ((format (printf, 2, 0)));
32extern void cmn_err(int, char *, ...)
33 __attribute__ ((format (printf, 2, 3)));
Nathan Scott3762ec62006-01-12 10:29:53 +110034extern void assfail(char *expr, char *f, int l);
35
Nathan Scott3762ec62006-01-12 10:29:53 +110036#define ASSERT_ALWAYS(expr) \
Christoph Hellwigee5c8022007-08-16 15:38:08 +100037 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__))
Nathan Scott3762ec62006-01-12 10:29:53 +110038
39#ifndef DEBUG
Christoph Hellwigee5c8022007-08-16 15:38:08 +100040#define ASSERT(expr) ((void)0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
42#ifndef STATIC
David Chinner7989cb82007-02-10 18:34:56 +110043# define STATIC static noinline
Linus Torvalds1da177e2005-04-16 15:20:36 -070044#endif
45
David Chinner7989cb82007-02-10 18:34:56 +110046#ifndef STATIC_INLINE
47# define STATIC_INLINE static inline
48#endif
49
50#else /* DEBUG */
51
Christoph Hellwigee5c8022007-08-16 15:38:08 +100052#define ASSERT(expr) \
53 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__))
David Chinner7989cb82007-02-10 18:34:56 +110054
55#ifndef STATIC
56# define STATIC noinline
57#endif
58
59/*
60 * We stop inlining of inline functions in debug mode.
61 * Unfortunately, this means static inline in header files
62 * get multiple definitions, so they need to remain static.
63 * This then gives tonnes of warnings about unused but defined
64 * functions, so we need to add the unused attribute to prevent
65 * these spurious warnings.
66 */
67#ifndef STATIC_INLINE
68# define STATIC_INLINE static __attribute__ ((unused)) noinline
69#endif
70
71#endif /* DEBUG */
72
73
Linus Torvalds1da177e2005-04-16 15:20:36 -070074#endif /* __XFS_SUPPORT_DEBUG_H__ */