aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_linux.h
diff options
context:
space:
mode:
authorDave Chinner <dchinner@redhat.com>2013-04-30 07:39:34 -0400
committerBen Myers <bpm@sgi.com>2013-05-07 19:45:36 -0400
commit742ae1e35b038ed65ddd86182723441ea74db765 (patch)
tree3bc54c369e01383cab6abe1426ed9d50f4016d78 /fs/xfs/xfs_linux.h
parentcab09a81fbefcb21db5213a84461d421946f6eb8 (diff)
xfs: introduce CONFIG_XFS_WARN
Running a CONFIG_XFS_DEBUG kernel in production environments is not the best idea as it introduces significant overhead, can change the behaviour of algorithms (such as allocation) to improve test coverage, and (most importantly) panic the machine on non-fatal errors. There are many cases where all we want to do is run a kernel with more bounds checking enabled, such as is provided by the ASSERT() statements throughout the code, but without all the potential overhead and drawbacks. This patch converts all the ASSERT statements to evaluate as WARN_ON(1) statements and hence if they fail dump a warning and a stack trace to the log. This has minimal overhead and does not change any algorithms, and will allow us to find strange "out of bounds" problems more easily on production machines. There are a few places where assert statements contain debug only code. These are converted to be debug-or-warn only code so that we still get all the assert checks in the code. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Brian Foster <bfoster@redhat.com> Signed-off-by: Ben Myers <bpm@sgi.com>
Diffstat (limited to 'fs/xfs/xfs_linux.h')
-rw-r--r--fs/xfs/xfs_linux.h24
1 files changed, 18 insertions, 6 deletions
diff --git a/fs/xfs/xfs_linux.h b/fs/xfs/xfs_linux.h
index 14e59d953b7b..800f896a6cc4 100644
--- a/fs/xfs/xfs_linux.h
+++ b/fs/xfs/xfs_linux.h
@@ -293,22 +293,34 @@ static inline __uint64_t howmany_64(__uint64_t x, __uint32_t y)
293#define ASSERT_ALWAYS(expr) \ 293#define ASSERT_ALWAYS(expr) \
294 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__)) 294 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__))
295 295
296#ifndef DEBUG 296#ifdef DEBUG
297#define ASSERT(expr) ((void)0) 297#define ASSERT(expr) \
298 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__))
298 299
299#ifndef STATIC 300#ifndef STATIC
300# define STATIC static noinline 301# define STATIC noinline
301#endif 302#endif
302 303
303#else /* DEBUG */ 304#else /* !DEBUG */
305
306#ifdef XFS_WARN
304 307
305#define ASSERT(expr) \ 308#define ASSERT(expr) \
306 (unlikely(expr) ? (void)0 : assfail(#expr, __FILE__, __LINE__)) 309 (unlikely(expr) ? (void)0 : asswarn(#expr, __FILE__, __LINE__))
307 310
308#ifndef STATIC 311#ifndef STATIC
309# define STATIC noinline 312# define STATIC static noinline
313#endif
314
315#else /* !DEBUG && !XFS_WARN */
316
317#define ASSERT(expr) ((void)0)
318
319#ifndef STATIC
320# define STATIC static noinline
310#endif 321#endif
311 322
323#endif /* XFS_WARN */
312#endif /* DEBUG */ 324#endif /* DEBUG */
313 325
314#endif /* __XFS_LINUX__ */ 326#endif /* __XFS_LINUX__ */