Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0efb3b23 authored by Jan Kara's avatar Jan Kara Committed by Theodore Ts'o
Browse files

ext4: move several mount options to standard handling loop



Several mount option (resuid, resgid, journal_dev, journal_ioprio) are
currently handled before we enter standard option handling loop. I don't
see a reason for this so move them to normal handling loop to make things
more regular.

Signed-off-by: default avatarJan Kara <jack@suse.cz>
Signed-off-by: default avatar"Theodore Ts'o" <tytso@mit.edu>
parent 0e79537d
Loading
Loading
Loading
Loading
+38 −31
Original line number Diff line number Diff line
@@ -1444,6 +1444,10 @@ static const struct mount_opts {
	{Opt_inode_readahead_blks, 0, MOPT_GTE0},
	{Opt_init_itable, 0, MOPT_GTE0},
	{Opt_stripe, 0, MOPT_GTE0},
	{Opt_resuid, 0, MOPT_GTE0},
	{Opt_resgid, 0, MOPT_GTE0},
	{Opt_journal_dev, 0, MOPT_GTE0},
	{Opt_journal_ioprio, 0, MOPT_GTE0},
	{Opt_data_journal, EXT4_MOUNT_JOURNAL_DATA, MOPT_DATAJ},
	{Opt_data_ordered, EXT4_MOUNT_ORDERED_DATA, MOPT_DATAJ},
	{Opt_data_writeback, EXT4_MOUNT_WRITEBACK_DATA, MOPT_DATAJ},
@@ -1496,8 +1500,6 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token,
	else if (token == Opt_offgrpjquota)
		return clear_qf_name(sb, GRPQUOTA);
#endif
	if (args->from && match_int(args, &arg))
		return -1;
	switch (token) {
	case Opt_noacl:
	case Opt_nouser_xattr:
@@ -1509,46 +1511,19 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token,
		ext4_msg(sb, KERN_WARNING,
			 "Ignoring removed %s option", opt);
		return 1;
	case Opt_resuid:
		uid = make_kuid(current_user_ns(), arg);
		if (!uid_valid(uid)) {
			ext4_msg(sb, KERN_ERR, "Invalid uid value %d", arg);
			return -1;
		}
		sbi->s_resuid = uid;
		return 1;
	case Opt_resgid:
		gid = make_kgid(current_user_ns(), arg);
		if (!gid_valid(gid)) {
			ext4_msg(sb, KERN_ERR, "Invalid gid value %d", arg);
			return -1;
		}
		sbi->s_resgid = gid;
		return 1;
	case Opt_abort:
		sbi->s_mount_flags |= EXT4_MF_FS_ABORTED;
		return 1;
	case Opt_i_version:
		sb->s_flags |= MS_I_VERSION;
		return 1;
	case Opt_journal_dev:
		if (is_remount) {
			ext4_msg(sb, KERN_ERR,
				 "Cannot specify journal on remount");
			return -1;
		}
		*journal_devnum = arg;
		return 1;
	case Opt_journal_ioprio:
		if (arg < 0 || arg > 7)
			return -1;
		*journal_ioprio = IOPRIO_PRIO_VALUE(IOPRIO_CLASS_BE, arg);
		return 1;
	}

	for (m = ext4_mount_opts; m->token != Opt_err; m++) {
		if (token != m->token)
			continue;
		if (args->from && match_int(args, &arg))
			return -1;
		if (args->from && (m->flags & MOPT_GTE0) && (arg < 0))
			return -1;
		if (m->flags & MOPT_EXPLICIT)
@@ -1592,6 +1567,38 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token,
			sbi->s_max_dir_size_kb = arg;
		} else if (token == Opt_stripe) {
			sbi->s_stripe = arg;
		} else if (token == Opt_resuid) {
			uid = make_kuid(current_user_ns(), arg);
			if (!uid_valid(uid)) {
				ext4_msg(sb, KERN_ERR,
					 "Invalid uid value %d", arg);
				return -1;
			}
			sbi->s_resuid = uid;
		} else if (token == Opt_resgid) {
			gid = make_kgid(current_user_ns(), arg);
			if (!gid_valid(gid)) {
				ext4_msg(sb, KERN_ERR,
					 "Invalid gid value %d", arg);
				return -1;
			}
			sbi->s_resgid = gid;
		} else if (token == Opt_journal_dev) {
			if (is_remount) {
				ext4_msg(sb, KERN_ERR,
					 "Cannot specify journal on remount");
				return -1;
			}
			*journal_devnum = arg;
		} else if (token == Opt_journal_ioprio) {
			if (arg > 7) {
				ext4_msg(sb, KERN_ERR,
					 "Invalid journal IO priority"
					 " (must be 0-7)");
				return -1;
			}
			*journal_ioprio =
				IOPRIO_PRIO_VALUE(IOPRIO_CLASS_BE, arg);
		} else if (m->flags & MOPT_DATAJ) {
			if (is_remount) {
				if (!sbi->s_journal)