xfs: pretty print metadata file types in error messages
authorDarrick J. Wong <djwong@kernel.org>
Thu, 21 Nov 2024 00:20:26 +0000 (16:20 -0800)
committerDarrick J. Wong <djwong@kernel.org>
Mon, 23 Dec 2024 21:06:05 +0000 (13:06 -0800)
Create a helper function to turn a metadata file type code into a
printable string, and use this to complain about lockdep problems with
rtgroup inodes.  We'll use this more in the next patch.

Signed-off-by: "Darrick J. Wong" <djwong@kernel.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
fs/xfs/libxfs/xfs_metafile.c
fs/xfs/libxfs/xfs_metafile.h
fs/xfs/libxfs/xfs_rtgroup.c

index e151663cc9efd6e348e776e7602d1d5278041879..2f5f554a36d4c9e08e71174af7182fd3f8ff10f6 100644 (file)
 #include "xfs_error.h"
 #include "xfs_alloc.h"
 
+static const struct {
+       enum xfs_metafile_type  mtype;
+       const char              *name;
+} xfs_metafile_type_strs[] = { XFS_METAFILE_TYPE_STR };
+
+const char *
+xfs_metafile_type_str(enum xfs_metafile_type metatype)
+{
+       unsigned int    i;
+
+       for (i = 0; i < ARRAY_SIZE(xfs_metafile_type_strs); i++) {
+               if (xfs_metafile_type_strs[i].mtype == metatype)
+                       return xfs_metafile_type_strs[i].name;
+       }
+
+       return NULL;
+}
+
 /* Set up an inode to be recognized as a metadata directory inode. */
 void
 xfs_metafile_set_iflag(
index 8d8f08a6071c2333176efa853734263bbabbbab9..95af4b52e5a75f8f2b6c228141e53f21f91cf4e2 100644 (file)
@@ -6,6 +6,8 @@
 #ifndef __XFS_METAFILE_H__
 #define __XFS_METAFILE_H__
 
+const char *xfs_metafile_type_str(enum xfs_metafile_type metatype);
+
 /* All metadata files must have these flags set. */
 #define XFS_METAFILE_DIFLAGS   (XFS_DIFLAG_IMMUTABLE | \
                                 XFS_DIFLAG_SYNC | \
index a79b734e70440dc3b58f8eb4b6574b7103632131..9e5fdc0dc55cef1c7ff33d0bcb76ffdaa45b5398 100644 (file)
@@ -282,7 +282,8 @@ xfs_rtginode_ilock_print_fn(
        const struct xfs_inode *ip =
                container_of(m, struct xfs_inode, i_lock.dep_map);
 
-       printk(KERN_CONT " rgno=%u", ip->i_projid);
+       printk(KERN_CONT " rgno=%u metatype=%s", ip->i_projid,
+                       xfs_metafile_type_str(ip->i_metatype));
 }
 
 /*