Skip to content

Commit

Permalink
ext2: create ext2_msg_fc for use during parsing
Browse files Browse the repository at this point in the history
Rather than send a NULL sb to ext2_msg, which omits the s_id from
messages, create a new ext2_msg_fc which is able to provide this
information from the filesystem context *fc when parsing.

Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: Jan Kara <jack@suse.cz>
Link: https://patch.msgid.link/20250223201014.7541-3-sandeen@redhat.com
  • Loading branch information
Eric Sandeen authored and Jan Kara committed Feb 24, 2025
1 parent eab61d3 commit 98f18c7
Showing 1 changed file with 37 additions and 13 deletions.
50 changes: 37 additions & 13 deletions fs/ext2/super.c
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,33 @@ void ext2_error(struct super_block *sb, const char *function,
}
}

static void ext2_msg_fc(struct fs_context *fc, const char *prefix,
const char *fmt, ...)
{
struct va_format vaf;
va_list args;
const char *s_id;

if (fc->purpose == FS_CONTEXT_FOR_RECONFIGURE) {
s_id = fc->root->d_sb->s_id;
} else {
/* get last path component of source */
s_id = strrchr(fc->source, '/');
if (s_id)
s_id++;
else
s_id = fc->source;
}
va_start(args, fmt);

vaf.fmt = fmt;
vaf.va = &args;

printk("%sEXT2-fs (%s): %pV\n", prefix, s_id, &vaf);

va_end(args);
}

void ext2_msg(struct super_block *sb, const char *prefix,
const char *fmt, ...)
{
Expand All @@ -92,10 +119,7 @@ void ext2_msg(struct super_block *sb, const char *prefix,
vaf.fmt = fmt;
vaf.va = &args;

if (sb)
printk("%sEXT2-fs (%s): %pV\n", prefix, sb->s_id, &vaf);
else
printk("%sEXT2-fs: %pV\n", prefix, &vaf);
printk("%sEXT2-fs (%s): %pV\n", prefix, sb->s_id, &vaf);

va_end(args);
}
Expand Down Expand Up @@ -544,7 +568,7 @@ static int ext2_parse_param(struct fs_context *fc, struct fs_parameter *param)
ctx_clear_mount_opt(ctx, EXT2_MOUNT_OLDALLOC);
break;
case Opt_nobh:
ext2_msg(NULL, KERN_INFO, "nobh option not supported\n");
ext2_msg_fc(fc, KERN_INFO, "nobh option not supported\n");
break;
#ifdef CONFIG_EXT2_FS_XATTR
case Opt_user_xattr:
Expand All @@ -555,7 +579,7 @@ static int ext2_parse_param(struct fs_context *fc, struct fs_parameter *param)
break;
#else
case Opt_user_xattr:
ext2_msg(NULL, KERN_INFO, "(no)user_xattr options not supported");
ext2_msg_fc(fc, KERN_INFO, "(no)user_xattr options not supported");
break;
#endif
#ifdef CONFIG_EXT2_FS_POSIX_ACL
Expand All @@ -567,20 +591,20 @@ static int ext2_parse_param(struct fs_context *fc, struct fs_parameter *param)
break;
#else
case Opt_acl:
ext2_msg(NULL, KERN_INFO, "(no)acl options not supported");
ext2_msg_fc(fc, KERN_INFO, "(no)acl options not supported");
break;
#endif
case Opt_xip:
ext2_msg(NULL, KERN_INFO, "use dax instead of xip");
ext2_msg_fc(fc, KERN_INFO, "use dax instead of xip");
ctx_set_mount_opt(ctx, EXT2_MOUNT_XIP);
fallthrough;
case Opt_dax:
#ifdef CONFIG_FS_DAX
ext2_msg(NULL, KERN_WARNING,
ext2_msg_fc(fc, KERN_WARNING,
"DAX enabled. Warning: EXPERIMENTAL, use at your own risk");
ctx_set_mount_opt(ctx, EXT2_MOUNT_DAX);
#else
ext2_msg(NULL, KERN_INFO, "dax option not supported");
ext2_msg_fc(fc, KERN_INFO, "dax option not supported");
#endif
break;

Expand All @@ -597,16 +621,16 @@ static int ext2_parse_param(struct fs_context *fc, struct fs_parameter *param)
case Opt_quota:
case Opt_usrquota:
case Opt_grpquota:
ext2_msg(NULL, KERN_INFO, "quota operations not supported");
ext2_msg_fc(fc, KERN_INFO, "quota operations not supported");
break;
#endif
case Opt_reservation:
if (!result.negated) {
ctx_set_mount_opt(ctx, EXT2_MOUNT_RESERVATION);
ext2_msg(NULL, KERN_INFO, "reservations ON");
ext2_msg_fc(fc, KERN_INFO, "reservations ON");
} else {
ctx_clear_mount_opt(ctx, EXT2_MOUNT_RESERVATION);
ext2_msg(NULL, KERN_INFO, "reservations OFF");
ext2_msg_fc(fc, KERN_INFO, "reservations OFF");
}
break;
case Opt_ignore:
Expand Down

0 comments on commit 98f18c7

Please sign in to comment.