blob: 6f4fd37c67af41e684d8371353bb2915a6f62294 [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 cmn_err(int, char *, ...)
31 __attribute__ ((format (printf, 2, 3)));
Nathan Scott3762ec62006-01-12 10:29:53 +110032extern void assfail(char *expr, char *f, int l);
33
Nathan Scott3762ec62006-01-12 10:29:53 +110034#define ASSERT_ALWAYS(expr) \
Christoph Hellwigee5c8022007-08-16 15:38:08 +100035 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__))
Nathan Scott3762ec62006-01-12 10:29:53 +110036
37#ifndef DEBUG
Christoph Hellwigee5c8022007-08-16 15:38:08 +100038#define ASSERT(expr) ((void)0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
40#ifndef STATIC
David Chinner7989cb82007-02-10 18:34:56 +110041# define STATIC static noinline
Linus Torvalds1da177e2005-04-16 15:20:36 -070042#endif
43
David Chinner7989cb82007-02-10 18:34:56 +110044#ifndef STATIC_INLINE
45# define STATIC_INLINE static inline
46#endif
47
48#else /* DEBUG */
49
Christoph Hellwigee5c8022007-08-16 15:38:08 +100050#define ASSERT(expr) \
51 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__))
David Chinner7989cb82007-02-10 18:34:56 +110052
53#ifndef STATIC
54# define STATIC noinline
55#endif
56
57/*
58 * We stop inlining of inline functions in debug mode.
59 * Unfortunately, this means static inline in header files
60 * get multiple definitions, so they need to remain static.
61 * This then gives tonnes of warnings about unused but defined
62 * functions, so we need to add the unused attribute to prevent
63 * these spurious warnings.
64 */
65#ifndef STATIC_INLINE
66# define STATIC_INLINE static __attribute__ ((unused)) noinline
67#endif
68
69#endif /* DEBUG */
70
71
Linus Torvalds1da177e2005-04-16 15:20:36 -070072#endif /* __XFS_SUPPORT_DEBUG_H__ */