int                     linenum,
        xfs_failaddr_t          failaddr)
 {
-       if (level <= xfs_error_level)
+       if (buf && level <= xfs_error_level)
                xfs_hex_dump(buf, bufsize);
        xfs_error_report(tag, level, mp, filename, linenum, failaddr);
        xfs_alert(mp, "Corruption detected. Unmount and run xfs_repair");
 
 #define ASSERT(expr)   \
        (likely(expr) ? (void)0 : assfail(NULL, #expr, __FILE__, __LINE__))
 
-#define XFS_IS_CORRUPT(mp, expr)       \
-       (unlikely(expr) ? assfail((mp), #expr, __FILE__, __LINE__), \
-                         true : false)
-
 #else  /* !DEBUG */
 
 #ifdef XFS_WARN
 #define ASSERT(expr)   \
        (likely(expr) ? (void)0 : asswarn(NULL, #expr, __FILE__, __LINE__))
 
-#define XFS_IS_CORRUPT(mp, expr)       \
-       (unlikely(expr) ? asswarn((mp), #expr, __FILE__, __LINE__), \
-                         true : false)
-
 #else  /* !DEBUG && !XFS_WARN */
 
 #define ASSERT(expr)           ((void)0)
-#define XFS_IS_CORRUPT(mp, expr)       \
-       (unlikely(expr) ? XFS_ERROR_REPORT(#expr, XFS_ERRLEVEL_LOW, (mp)), \
-                         true : false)
 
 #endif /* XFS_WARN */
 #endif /* DEBUG */
 
+#define XFS_IS_CORRUPT(mp, expr)       \
+       (unlikely(expr) ? xfs_corruption_error(#expr, XFS_ERRLEVEL_LOW, (mp), \
+                                              NULL, 0, __FILE__, __LINE__, \
+                                              __this_address), \
+                         true : false)
+
 #define STATIC static noinline
 
 #ifdef CONFIG_XFS_RT