Commit 8e28ef1f authored by Andreas Gruenbacher's avatar Andreas Gruenbacher Committed by Bob Peterson

gfs2: Return bool from gfs2_assert functions

The gfs2_assert functions only print messages when the filesystem hasn't been
withdrawn yet, and they indicate whether or not they've printed something in
their return value.  However, none of the callers use that information, so
simply return whether or not the assert has failed.

(The gfs2_assert functions are still backwards; they return false when an
assertion is true.)
Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
parent a5ca2f1c
...@@ -84,37 +84,30 @@ int gfs2_withdraw(struct gfs2_sbd *sdp) ...@@ -84,37 +84,30 @@ int gfs2_withdraw(struct gfs2_sbd *sdp)
/** /**
* gfs2_assert_withdraw_i - Cause the machine to withdraw if @assertion is false * gfs2_assert_withdraw_i - Cause the machine to withdraw if @assertion is false
* Returns: -1 if this call withdrew the machine,
* -2 if it was already withdrawn
*/ */
int gfs2_assert_withdraw_i(struct gfs2_sbd *sdp, char *assertion, void gfs2_assert_withdraw_i(struct gfs2_sbd *sdp, char *assertion,
const char *function, char *file, unsigned int line) const char *function, char *file, unsigned int line)
{ {
int me;
gfs2_lm(sdp, gfs2_lm(sdp,
"fatal: assertion \"%s\" failed\n" "fatal: assertion \"%s\" failed\n"
" function = %s, file = %s, line = %u\n", " function = %s, file = %s, line = %u\n",
assertion, function, file, line); assertion, function, file, line);
me = gfs2_withdraw(sdp); gfs2_withdraw(sdp);
dump_stack(); dump_stack();
return (me) ? -1 : -2;
} }
/** /**
* gfs2_assert_warn_i - Print a message to the console if @assertion is false * gfs2_assert_warn_i - Print a message to the console if @assertion is false
* Returns: -1 if we printed something
* -2 if we didn't
*/ */
int gfs2_assert_warn_i(struct gfs2_sbd *sdp, char *assertion, void gfs2_assert_warn_i(struct gfs2_sbd *sdp, char *assertion,
const char *function, char *file, unsigned int line) const char *function, char *file, unsigned int line)
{ {
if (time_before(jiffies, if (time_before(jiffies,
sdp->sd_last_warning + sdp->sd_last_warning +
gfs2_tune_get(sdp, gt_complain_secs) * HZ)) gfs2_tune_get(sdp, gt_complain_secs) * HZ))
return -2; return;
if (sdp->sd_args.ar_errors == GFS2_ERRORS_WITHDRAW) if (sdp->sd_args.ar_errors == GFS2_ERRORS_WITHDRAW)
fs_warn(sdp, "warning: assertion \"%s\" failed at function = %s, file = %s, line = %u\n", fs_warn(sdp, "warning: assertion \"%s\" failed at function = %s, file = %s, line = %u\n",
...@@ -132,8 +125,6 @@ int gfs2_assert_warn_i(struct gfs2_sbd *sdp, char *assertion, ...@@ -132,8 +125,6 @@ int gfs2_assert_warn_i(struct gfs2_sbd *sdp, char *assertion,
sdp->sd_fsname, function, file, line); sdp->sd_fsname, function, file, line);
sdp->sd_last_warning = jiffies; sdp->sd_last_warning = jiffies;
return -1;
} }
/** /**
......
...@@ -36,21 +36,29 @@ do { \ ...@@ -36,21 +36,29 @@ do { \
} while (0) } while (0)
int gfs2_assert_withdraw_i(struct gfs2_sbd *sdp, char *assertion, void gfs2_assert_withdraw_i(struct gfs2_sbd *sdp, char *assertion,
const char *function, char *file, unsigned int line); const char *function, char *file, unsigned int line);
#define gfs2_assert_withdraw(sdp, assertion) \ #define gfs2_assert_withdraw(sdp, assertion) \
((likely(assertion)) ? 0 : gfs2_assert_withdraw_i((sdp), #assertion, \ ({ \
__func__, __FILE__, __LINE__)) bool _bool = (assertion); \
if (unlikely(!_bool)) \
gfs2_assert_withdraw_i((sdp), #assertion, \
int gfs2_assert_warn_i(struct gfs2_sbd *sdp, char *assertion, __func__, __FILE__, __LINE__); \
!_bool; \
})
void gfs2_assert_warn_i(struct gfs2_sbd *sdp, char *assertion,
const char *function, char *file, unsigned int line); const char *function, char *file, unsigned int line);
#define gfs2_assert_warn(sdp, assertion) \ #define gfs2_assert_warn(sdp, assertion) \
((likely(assertion)) ? 0 : gfs2_assert_warn_i((sdp), #assertion, \ ({ \
__func__, __FILE__, __LINE__)) bool _bool = (assertion); \
if (unlikely(!_bool)) \
gfs2_assert_warn_i((sdp), #assertion, \
__func__, __FILE__, __LINE__); \
!_bool; \
})
void gfs2_consist_i(struct gfs2_sbd *sdp, void gfs2_consist_i(struct gfs2_sbd *sdp,
const char *function, char *file, unsigned int line); const char *function, char *file, unsigned int line);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment