aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/mrlock.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/mrlock.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/mrlock.h')
-rw-r--r--fs/xfs/mrlock.h12
1 files changed, 6 insertions, 6 deletions
diff --git a/fs/xfs/mrlock.h b/fs/xfs/mrlock.h
index ff6a19873e5c..e3c92d19e540 100644
--- a/fs/xfs/mrlock.h
+++ b/fs/xfs/mrlock.h
@@ -22,12 +22,12 @@
22 22
23typedef struct { 23typedef struct {
24 struct rw_semaphore mr_lock; 24 struct rw_semaphore mr_lock;
25#ifdef DEBUG 25#if defined(DEBUG) || defined(XFS_WARN)
26 int mr_writer; 26 int mr_writer;
27#endif 27#endif
28} mrlock_t; 28} mrlock_t;
29 29
30#ifdef DEBUG 30#if defined(DEBUG) || defined(XFS_WARN)
31#define mrinit(mrp, name) \ 31#define mrinit(mrp, name) \
32 do { (mrp)->mr_writer = 0; init_rwsem(&(mrp)->mr_lock); } while (0) 32 do { (mrp)->mr_writer = 0; init_rwsem(&(mrp)->mr_lock); } while (0)
33#else 33#else
@@ -46,7 +46,7 @@ static inline void mraccess_nested(mrlock_t *mrp, int subclass)
46static inline void mrupdate_nested(mrlock_t *mrp, int subclass) 46static inline void mrupdate_nested(mrlock_t *mrp, int subclass)
47{ 47{
48 down_write_nested(&mrp->mr_lock, subclass); 48 down_write_nested(&mrp->mr_lock, subclass);
49#ifdef DEBUG 49#if defined(DEBUG) || defined(XFS_WARN)
50 mrp->mr_writer = 1; 50 mrp->mr_writer = 1;
51#endif 51#endif
52} 52}
@@ -60,7 +60,7 @@ static inline int mrtryupdate(mrlock_t *mrp)
60{ 60{
61 if (!down_write_trylock(&mrp->mr_lock)) 61 if (!down_write_trylock(&mrp->mr_lock))
62 return 0; 62 return 0;
63#ifdef DEBUG 63#if defined(DEBUG) || defined(XFS_WARN)
64 mrp->mr_writer = 1; 64 mrp->mr_writer = 1;
65#endif 65#endif
66 return 1; 66 return 1;
@@ -68,7 +68,7 @@ static inline int mrtryupdate(mrlock_t *mrp)
68 68
69static inline void mrunlock_excl(mrlock_t *mrp) 69static inline void mrunlock_excl(mrlock_t *mrp)
70{ 70{
71#ifdef DEBUG 71#if defined(DEBUG) || defined(XFS_WARN)
72 mrp->mr_writer = 0; 72 mrp->mr_writer = 0;
73#endif 73#endif
74 up_write(&mrp->mr_lock); 74 up_write(&mrp->mr_lock);
@@ -81,7 +81,7 @@ static inline void mrunlock_shared(mrlock_t *mrp)
81 81
82static inline void mrdemote(mrlock_t *mrp) 82static inline void mrdemote(mrlock_t *mrp)
83{ 83{
84#ifdef DEBUG 84#if defined(DEBUG) || defined(XFS_WARN)
85 mrp->mr_writer = 0; 85 mrp->mr_writer = 0;
86#endif 86#endif
87 downgrade_write(&mrp->mr_lock); 87 downgrade_write(&mrp->mr_lock);