diff options
-rw-r--r-- | fs/ext4/super.c | 69 |
1 files changed, 38 insertions, 31 deletions
diff --git a/fs/ext4/super.c b/fs/ext4/super.c index aac52738eb60..69e5e70cfdee 100644 --- a/fs/ext4/super.c +++ b/fs/ext4/super.c | |||
@@ -1444,6 +1444,10 @@ static const struct mount_opts { | |||
1444 | {Opt_inode_readahead_blks, 0, MOPT_GTE0}, | 1444 | {Opt_inode_readahead_blks, 0, MOPT_GTE0}, |
1445 | {Opt_init_itable, 0, MOPT_GTE0}, | 1445 | {Opt_init_itable, 0, MOPT_GTE0}, |
1446 | {Opt_stripe, 0, MOPT_GTE0}, | 1446 | {Opt_stripe, 0, MOPT_GTE0}, |
1447 | {Opt_resuid, 0, MOPT_GTE0}, | ||
1448 | {Opt_resgid, 0, MOPT_GTE0}, | ||
1449 | {Opt_journal_dev, 0, MOPT_GTE0}, | ||
1450 | {Opt_journal_ioprio, 0, MOPT_GTE0}, | ||
1447 | {Opt_data_journal, EXT4_MOUNT_JOURNAL_DATA, MOPT_DATAJ}, | 1451 | {Opt_data_journal, EXT4_MOUNT_JOURNAL_DATA, MOPT_DATAJ}, |
1448 | {Opt_data_ordered, EXT4_MOUNT_ORDERED_DATA, MOPT_DATAJ}, | 1452 | {Opt_data_ordered, EXT4_MOUNT_ORDERED_DATA, MOPT_DATAJ}, |
1449 | {Opt_data_writeback, EXT4_MOUNT_WRITEBACK_DATA, MOPT_DATAJ}, | 1453 | {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, | |||
1496 | else if (token == Opt_offgrpjquota) | 1500 | else if (token == Opt_offgrpjquota) |
1497 | return clear_qf_name(sb, GRPQUOTA); | 1501 | return clear_qf_name(sb, GRPQUOTA); |
1498 | #endif | 1502 | #endif |
1499 | if (args->from && match_int(args, &arg)) | ||
1500 | return -1; | ||
1501 | switch (token) { | 1503 | switch (token) { |
1502 | case Opt_noacl: | 1504 | case Opt_noacl: |
1503 | case Opt_nouser_xattr: | 1505 | case Opt_nouser_xattr: |
@@ -1509,46 +1511,19 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token, | |||
1509 | ext4_msg(sb, KERN_WARNING, | 1511 | ext4_msg(sb, KERN_WARNING, |
1510 | "Ignoring removed %s option", opt); | 1512 | "Ignoring removed %s option", opt); |
1511 | return 1; | 1513 | return 1; |
1512 | case Opt_resuid: | ||
1513 | uid = make_kuid(current_user_ns(), arg); | ||
1514 | if (!uid_valid(uid)) { | ||
1515 | ext4_msg(sb, KERN_ERR, "Invalid uid value %d", arg); | ||
1516 | return -1; | ||
1517 | } | ||
1518 | sbi->s_resuid = uid; | ||
1519 | return 1; | ||
1520 | case Opt_resgid: | ||
1521 | gid = make_kgid(current_user_ns(), arg); | ||
1522 | if (!gid_valid(gid)) { | ||
1523 | ext4_msg(sb, KERN_ERR, "Invalid gid value %d", arg); | ||
1524 | return -1; | ||
1525 | } | ||
1526 | sbi->s_resgid = gid; | ||
1527 | return 1; | ||
1528 | case Opt_abort: | 1514 | case Opt_abort: |
1529 | sbi->s_mount_flags |= EXT4_MF_FS_ABORTED; | 1515 | sbi->s_mount_flags |= EXT4_MF_FS_ABORTED; |
1530 | return 1; | 1516 | return 1; |
1531 | case Opt_i_version: | 1517 | case Opt_i_version: |
1532 | sb->s_flags |= MS_I_VERSION; | 1518 | sb->s_flags |= MS_I_VERSION; |
1533 | return 1; | 1519 | return 1; |
1534 | case Opt_journal_dev: | ||
1535 | if (is_remount) { | ||
1536 | ext4_msg(sb, KERN_ERR, | ||
1537 | "Cannot specify journal on remount"); | ||
1538 | return -1; | ||
1539 | } | ||
1540 | *journal_devnum = arg; | ||
1541 | return 1; | ||
1542 | case Opt_journal_ioprio: | ||
1543 | if (arg < 0 || arg > 7) | ||
1544 | return -1; | ||
1545 | *journal_ioprio = IOPRIO_PRIO_VALUE(IOPRIO_CLASS_BE, arg); | ||
1546 | return 1; | ||
1547 | } | 1520 | } |
1548 | 1521 | ||
1549 | for (m = ext4_mount_opts; m->token != Opt_err; m++) { | 1522 | for (m = ext4_mount_opts; m->token != Opt_err; m++) { |
1550 | if (token != m->token) | 1523 | if (token != m->token) |
1551 | continue; | 1524 | continue; |
1525 | if (args->from && match_int(args, &arg)) | ||
1526 | return -1; | ||
1552 | if (args->from && (m->flags & MOPT_GTE0) && (arg < 0)) | 1527 | if (args->from && (m->flags & MOPT_GTE0) && (arg < 0)) |
1553 | return -1; | 1528 | return -1; |
1554 | if (m->flags & MOPT_EXPLICIT) | 1529 | if (m->flags & MOPT_EXPLICIT) |
@@ -1592,6 +1567,38 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token, | |||
1592 | sbi->s_max_dir_size_kb = arg; | 1567 | sbi->s_max_dir_size_kb = arg; |
1593 | } else if (token == Opt_stripe) { | 1568 | } else if (token == Opt_stripe) { |
1594 | sbi->s_stripe = arg; | 1569 | sbi->s_stripe = arg; |
1570 | } else if (token == Opt_resuid) { | ||
1571 | uid = make_kuid(current_user_ns(), arg); | ||
1572 | if (!uid_valid(uid)) { | ||
1573 | ext4_msg(sb, KERN_ERR, | ||
1574 | "Invalid uid value %d", arg); | ||
1575 | return -1; | ||
1576 | } | ||
1577 | sbi->s_resuid = uid; | ||
1578 | } else if (token == Opt_resgid) { | ||
1579 | gid = make_kgid(current_user_ns(), arg); | ||
1580 | if (!gid_valid(gid)) { | ||
1581 | ext4_msg(sb, KERN_ERR, | ||
1582 | "Invalid gid value %d", arg); | ||
1583 | return -1; | ||
1584 | } | ||
1585 | sbi->s_resgid = gid; | ||
1586 | } else if (token == Opt_journal_dev) { | ||
1587 | if (is_remount) { | ||
1588 | ext4_msg(sb, KERN_ERR, | ||
1589 | "Cannot specify journal on remount"); | ||
1590 | return -1; | ||
1591 | } | ||
1592 | *journal_devnum = arg; | ||
1593 | } else if (token == Opt_journal_ioprio) { | ||
1594 | if (arg > 7) { | ||
1595 | ext4_msg(sb, KERN_ERR, | ||
1596 | "Invalid journal IO priority" | ||
1597 | " (must be 0-7)"); | ||
1598 | return -1; | ||
1599 | } | ||
1600 | *journal_ioprio = | ||
1601 | IOPRIO_PRIO_VALUE(IOPRIO_CLASS_BE, arg); | ||
1595 | } else if (m->flags & MOPT_DATAJ) { | 1602 | } else if (m->flags & MOPT_DATAJ) { |
1596 | if (is_remount) { | 1603 | if (is_remount) { |
1597 | if (!sbi->s_journal) | 1604 | if (!sbi->s_journal) |