aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext3
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ext3')
-rw-r--r--fs/ext3/super.c47
1 files changed, 20 insertions, 27 deletions
diff --git a/fs/ext3/super.c b/fs/ext3/super.c
index afa2b569da10..7950ff6ec4e8 100644
--- a/fs/ext3/super.c
+++ b/fs/ext3/super.c
@@ -181,7 +181,7 @@ static void ext3_handle_error(struct super_block *sb)
181 if (!test_opt (sb, ERRORS_CONT)) { 181 if (!test_opt (sb, ERRORS_CONT)) {
182 journal_t *journal = EXT3_SB(sb)->s_journal; 182 journal_t *journal = EXT3_SB(sb)->s_journal;
183 183
184 EXT3_SB(sb)->s_mount_opt |= EXT3_MOUNT_ABORT; 184 set_opt(EXT3_SB(sb)->s_mount_opt, ABORT);
185 if (journal) 185 if (journal)
186 journal_abort(journal, -EIO); 186 journal_abort(journal, -EIO);
187 } 187 }
@@ -296,7 +296,7 @@ void ext3_abort (struct super_block * sb, const char * function,
296 "error: remounting filesystem read-only"); 296 "error: remounting filesystem read-only");
297 EXT3_SB(sb)->s_mount_state |= EXT3_ERROR_FS; 297 EXT3_SB(sb)->s_mount_state |= EXT3_ERROR_FS;
298 sb->s_flags |= MS_RDONLY; 298 sb->s_flags |= MS_RDONLY;
299 EXT3_SB(sb)->s_mount_opt |= EXT3_MOUNT_ABORT; 299 set_opt(EXT3_SB(sb)->s_mount_opt, ABORT);
300 if (EXT3_SB(sb)->s_journal) 300 if (EXT3_SB(sb)->s_journal)
301 journal_abort(EXT3_SB(sb)->s_journal, -EIO); 301 journal_abort(EXT3_SB(sb)->s_journal, -EIO);
302} 302}
@@ -562,10 +562,10 @@ static inline void ext3_show_quota_options(struct seq_file *seq, struct super_bl
562 if (sbi->s_qf_names[GRPQUOTA]) 562 if (sbi->s_qf_names[GRPQUOTA])
563 seq_printf(seq, ",grpjquota=%s", sbi->s_qf_names[GRPQUOTA]); 563 seq_printf(seq, ",grpjquota=%s", sbi->s_qf_names[GRPQUOTA]);
564 564
565 if (sbi->s_mount_opt & EXT3_MOUNT_USRQUOTA) 565 if (test_opt(sb, USRQUOTA))
566 seq_puts(seq, ",usrquota"); 566 seq_puts(seq, ",usrquota");
567 567
568 if (sbi->s_mount_opt & EXT3_MOUNT_GRPQUOTA) 568 if (test_opt(sb, GRPQUOTA))
569 seq_puts(seq, ",grpquota"); 569 seq_puts(seq, ",grpquota");
570#endif 570#endif
571} 571}
@@ -656,8 +656,7 @@ static int ext3_show_options(struct seq_file *seq, struct vfsmount *vfs)
656 if (test_opt(sb, NOBH)) 656 if (test_opt(sb, NOBH))
657 seq_puts(seq, ",nobh"); 657 seq_puts(seq, ",nobh");
658 658
659 seq_printf(seq, ",data=%s", data_mode_string(sbi->s_mount_opt & 659 seq_printf(seq, ",data=%s", data_mode_string(test_opt(sb, DATA_FLAGS)));
660 EXT3_MOUNT_DATA_FLAGS));
661 if (test_opt(sb, DATA_ERR_ABORT)) 660 if (test_opt(sb, DATA_ERR_ABORT))
662 seq_puts(seq, ",data_err=abort"); 661 seq_puts(seq, ",data_err=abort");
663 662
@@ -1065,20 +1064,19 @@ static int parse_options (char *options, struct super_block *sb,
1065 data_opt = EXT3_MOUNT_WRITEBACK_DATA; 1064 data_opt = EXT3_MOUNT_WRITEBACK_DATA;
1066 datacheck: 1065 datacheck:
1067 if (is_remount) { 1066 if (is_remount) {
1068 if ((sbi->s_mount_opt & EXT3_MOUNT_DATA_FLAGS) 1067 if (test_opt(sb, DATA_FLAGS) == data_opt)
1069 == data_opt)
1070 break; 1068 break;
1071 ext3_msg(sb, KERN_ERR, 1069 ext3_msg(sb, KERN_ERR,
1072 "error: cannot change " 1070 "error: cannot change "
1073 "data mode on remount. The filesystem " 1071 "data mode on remount. The filesystem "
1074 "is mounted in data=%s mode and you " 1072 "is mounted in data=%s mode and you "
1075 "try to remount it in data=%s mode.", 1073 "try to remount it in data=%s mode.",
1076 data_mode_string(sbi->s_mount_opt & 1074 data_mode_string(test_opt(sb,
1077 EXT3_MOUNT_DATA_FLAGS), 1075 DATA_FLAGS)),
1078 data_mode_string(data_opt)); 1076 data_mode_string(data_opt));
1079 return 0; 1077 return 0;
1080 } else { 1078 } else {
1081 sbi->s_mount_opt &= ~EXT3_MOUNT_DATA_FLAGS; 1079 clear_opt(sbi->s_mount_opt, DATA_FLAGS);
1082 sbi->s_mount_opt |= data_opt; 1080 sbi->s_mount_opt |= data_opt;
1083 } 1081 }
1084 break; 1082 break;
@@ -1244,18 +1242,13 @@ set_qf_format:
1244 } 1242 }
1245#ifdef CONFIG_QUOTA 1243#ifdef CONFIG_QUOTA
1246 if (sbi->s_qf_names[USRQUOTA] || sbi->s_qf_names[GRPQUOTA]) { 1244 if (sbi->s_qf_names[USRQUOTA] || sbi->s_qf_names[GRPQUOTA]) {
1247 if ((sbi->s_mount_opt & EXT3_MOUNT_USRQUOTA) && 1245 if (test_opt(sb, USRQUOTA) && sbi->s_qf_names[USRQUOTA])
1248 sbi->s_qf_names[USRQUOTA])
1249 clear_opt(sbi->s_mount_opt, USRQUOTA); 1246 clear_opt(sbi->s_mount_opt, USRQUOTA);
1250 1247 if (test_opt(sb, GRPQUOTA) && sbi->s_qf_names[GRPQUOTA])
1251 if ((sbi->s_mount_opt & EXT3_MOUNT_GRPQUOTA) &&
1252 sbi->s_qf_names[GRPQUOTA])
1253 clear_opt(sbi->s_mount_opt, GRPQUOTA); 1248 clear_opt(sbi->s_mount_opt, GRPQUOTA);
1254 1249
1255 if ((sbi->s_qf_names[USRQUOTA] && 1250 if ((sbi->s_qf_names[USRQUOTA] && test_opt(sb, GRPQUOTA)) ||
1256 (sbi->s_mount_opt & EXT3_MOUNT_GRPQUOTA)) || 1251 (sbi->s_qf_names[GRPQUOTA] && test_opt(sb, USRQUOTA))) {
1257 (sbi->s_qf_names[GRPQUOTA] &&
1258 (sbi->s_mount_opt & EXT3_MOUNT_USRQUOTA))) {
1259 ext3_msg(sb, KERN_ERR, "error: old and new quota " 1252 ext3_msg(sb, KERN_ERR, "error: old and new quota "
1260 "format mixing."); 1253 "format mixing.");
1261 return 0; 1254 return 0;
@@ -1671,11 +1664,11 @@ static int ext3_fill_super (struct super_block *sb, void *data, int silent)
1671 set_opt(sbi->s_mount_opt, POSIX_ACL); 1664 set_opt(sbi->s_mount_opt, POSIX_ACL);
1672#endif 1665#endif
1673 if ((def_mount_opts & EXT3_DEFM_JMODE) == EXT3_DEFM_JMODE_DATA) 1666 if ((def_mount_opts & EXT3_DEFM_JMODE) == EXT3_DEFM_JMODE_DATA)
1674 sbi->s_mount_opt |= EXT3_MOUNT_JOURNAL_DATA; 1667 set_opt(sbi->s_mount_opt, JOURNAL_DATA);
1675 else if ((def_mount_opts & EXT3_DEFM_JMODE) == EXT3_DEFM_JMODE_ORDERED) 1668 else if ((def_mount_opts & EXT3_DEFM_JMODE) == EXT3_DEFM_JMODE_ORDERED)
1676 sbi->s_mount_opt |= EXT3_MOUNT_ORDERED_DATA; 1669 set_opt(sbi->s_mount_opt, ORDERED_DATA);
1677 else if ((def_mount_opts & EXT3_DEFM_JMODE) == EXT3_DEFM_JMODE_WBACK) 1670 else if ((def_mount_opts & EXT3_DEFM_JMODE) == EXT3_DEFM_JMODE_WBACK)
1678 sbi->s_mount_opt |= EXT3_MOUNT_WRITEBACK_DATA; 1671 set_opt(sbi->s_mount_opt, WRITEBACK_DATA);
1679 1672
1680 if (le16_to_cpu(sbi->s_es->s_errors) == EXT3_ERRORS_PANIC) 1673 if (le16_to_cpu(sbi->s_es->s_errors) == EXT3_ERRORS_PANIC)
1681 set_opt(sbi->s_mount_opt, ERRORS_PANIC); 1674 set_opt(sbi->s_mount_opt, ERRORS_PANIC);
@@ -1694,7 +1687,7 @@ static int ext3_fill_super (struct super_block *sb, void *data, int silent)
1694 goto failed_mount; 1687 goto failed_mount;
1695 1688
1696 sb->s_flags = (sb->s_flags & ~MS_POSIXACL) | 1689 sb->s_flags = (sb->s_flags & ~MS_POSIXACL) |
1697 ((sbi->s_mount_opt & EXT3_MOUNT_POSIX_ACL) ? MS_POSIXACL : 0); 1690 (test_opt(sb, POSIX_ACL) ? MS_POSIXACL : 0);
1698 1691
1699 if (le32_to_cpu(es->s_rev_level) == EXT3_GOOD_OLD_REV && 1692 if (le32_to_cpu(es->s_rev_level) == EXT3_GOOD_OLD_REV &&
1700 (EXT3_HAS_COMPAT_FEATURE(sb, ~0U) || 1693 (EXT3_HAS_COMPAT_FEATURE(sb, ~0U) ||
@@ -2561,11 +2554,11 @@ static int ext3_remount (struct super_block * sb, int * flags, char * data)
2561 goto restore_opts; 2554 goto restore_opts;
2562 } 2555 }
2563 2556
2564 if (sbi->s_mount_opt & EXT3_MOUNT_ABORT) 2557 if (test_opt(sb, ABORT))
2565 ext3_abort(sb, __func__, "Abort forced by user"); 2558 ext3_abort(sb, __func__, "Abort forced by user");
2566 2559
2567 sb->s_flags = (sb->s_flags & ~MS_POSIXACL) | 2560 sb->s_flags = (sb->s_flags & ~MS_POSIXACL) |
2568 ((sbi->s_mount_opt & EXT3_MOUNT_POSIX_ACL) ? MS_POSIXACL : 0); 2561 (test_opt(sb, POSIX_ACL) ? MS_POSIXACL : 0);
2569 2562
2570 es = sbi->s_es; 2563 es = sbi->s_es;
2571 2564
@@ -2573,7 +2566,7 @@ static int ext3_remount (struct super_block * sb, int * flags, char * data)
2573 2566
2574 if ((*flags & MS_RDONLY) != (sb->s_flags & MS_RDONLY) || 2567 if ((*flags & MS_RDONLY) != (sb->s_flags & MS_RDONLY) ||
2575 n_blocks_count > le32_to_cpu(es->s_blocks_count)) { 2568 n_blocks_count > le32_to_cpu(es->s_blocks_count)) {
2576 if (sbi->s_mount_opt & EXT3_MOUNT_ABORT) { 2569 if (test_opt(sb, ABORT)) {
2577 err = -EROFS; 2570 err = -EROFS;
2578 goto restore_opts; 2571 goto restore_opts;
2579 } 2572 }