diff options
Diffstat (limited to 'fs')
-rw-r--r-- | fs/ufs/super.c | 117 |
1 files changed, 58 insertions, 59 deletions
diff --git a/fs/ufs/super.c b/fs/ufs/super.c index ae91e0af2664..ad56c6dffc64 100644 --- a/fs/ufs/super.c +++ b/fs/ufs/super.c | |||
@@ -691,6 +691,64 @@ static void ufs_put_super_internal(struct super_block *sb) | |||
691 | UFSD("EXIT\n"); | 691 | UFSD("EXIT\n"); |
692 | } | 692 | } |
693 | 693 | ||
694 | static int ufs_sync_fs(struct super_block *sb, int wait) | ||
695 | { | ||
696 | struct ufs_sb_private_info * uspi; | ||
697 | struct ufs_super_block_first * usb1; | ||
698 | struct ufs_super_block_third * usb3; | ||
699 | unsigned flags; | ||
700 | |||
701 | lock_ufs(sb); | ||
702 | lock_super(sb); | ||
703 | |||
704 | UFSD("ENTER\n"); | ||
705 | |||
706 | flags = UFS_SB(sb)->s_flags; | ||
707 | uspi = UFS_SB(sb)->s_uspi; | ||
708 | usb1 = ubh_get_usb_first(uspi); | ||
709 | usb3 = ubh_get_usb_third(uspi); | ||
710 | |||
711 | usb1->fs_time = cpu_to_fs32(sb, get_seconds()); | ||
712 | if ((flags & UFS_ST_MASK) == UFS_ST_SUN || | ||
713 | (flags & UFS_ST_MASK) == UFS_ST_SUNOS || | ||
714 | (flags & UFS_ST_MASK) == UFS_ST_SUNx86) | ||
715 | ufs_set_fs_state(sb, usb1, usb3, | ||
716 | UFS_FSOK - fs32_to_cpu(sb, usb1->fs_time)); | ||
717 | ufs_put_cstotal(sb); | ||
718 | sb->s_dirt = 0; | ||
719 | |||
720 | UFSD("EXIT\n"); | ||
721 | unlock_super(sb); | ||
722 | unlock_ufs(sb); | ||
723 | |||
724 | return 0; | ||
725 | } | ||
726 | |||
727 | static void ufs_write_super(struct super_block *sb) | ||
728 | { | ||
729 | if (!(sb->s_flags & MS_RDONLY)) | ||
730 | ufs_sync_fs(sb, 1); | ||
731 | else | ||
732 | sb->s_dirt = 0; | ||
733 | } | ||
734 | |||
735 | static void ufs_put_super(struct super_block *sb) | ||
736 | { | ||
737 | struct ufs_sb_info * sbi = UFS_SB(sb); | ||
738 | |||
739 | UFSD("ENTER\n"); | ||
740 | |||
741 | if (!(sb->s_flags & MS_RDONLY)) | ||
742 | ufs_put_super_internal(sb); | ||
743 | |||
744 | ubh_brelse_uspi (sbi->s_uspi); | ||
745 | kfree (sbi->s_uspi); | ||
746 | kfree (sbi); | ||
747 | sb->s_fs_info = NULL; | ||
748 | UFSD("EXIT\n"); | ||
749 | return; | ||
750 | } | ||
751 | |||
694 | static int ufs_fill_super(struct super_block *sb, void *data, int silent) | 752 | static int ufs_fill_super(struct super_block *sb, void *data, int silent) |
695 | { | 753 | { |
696 | struct ufs_sb_info * sbi; | 754 | struct ufs_sb_info * sbi; |
@@ -1191,65 +1249,6 @@ failed_nomem: | |||
1191 | return -ENOMEM; | 1249 | return -ENOMEM; |
1192 | } | 1250 | } |
1193 | 1251 | ||
1194 | static int ufs_sync_fs(struct super_block *sb, int wait) | ||
1195 | { | ||
1196 | struct ufs_sb_private_info * uspi; | ||
1197 | struct ufs_super_block_first * usb1; | ||
1198 | struct ufs_super_block_third * usb3; | ||
1199 | unsigned flags; | ||
1200 | |||
1201 | lock_ufs(sb); | ||
1202 | lock_super(sb); | ||
1203 | |||
1204 | UFSD("ENTER\n"); | ||
1205 | |||
1206 | flags = UFS_SB(sb)->s_flags; | ||
1207 | uspi = UFS_SB(sb)->s_uspi; | ||
1208 | usb1 = ubh_get_usb_first(uspi); | ||
1209 | usb3 = ubh_get_usb_third(uspi); | ||
1210 | |||
1211 | usb1->fs_time = cpu_to_fs32(sb, get_seconds()); | ||
1212 | if ((flags & UFS_ST_MASK) == UFS_ST_SUN || | ||
1213 | (flags & UFS_ST_MASK) == UFS_ST_SUNOS || | ||
1214 | (flags & UFS_ST_MASK) == UFS_ST_SUNx86) | ||
1215 | ufs_set_fs_state(sb, usb1, usb3, | ||
1216 | UFS_FSOK - fs32_to_cpu(sb, usb1->fs_time)); | ||
1217 | ufs_put_cstotal(sb); | ||
1218 | sb->s_dirt = 0; | ||
1219 | |||
1220 | UFSD("EXIT\n"); | ||
1221 | unlock_super(sb); | ||
1222 | unlock_ufs(sb); | ||
1223 | |||
1224 | return 0; | ||
1225 | } | ||
1226 | |||
1227 | static void ufs_write_super(struct super_block *sb) | ||
1228 | { | ||
1229 | if (!(sb->s_flags & MS_RDONLY)) | ||
1230 | ufs_sync_fs(sb, 1); | ||
1231 | else | ||
1232 | sb->s_dirt = 0; | ||
1233 | } | ||
1234 | |||
1235 | static void ufs_put_super(struct super_block *sb) | ||
1236 | { | ||
1237 | struct ufs_sb_info * sbi = UFS_SB(sb); | ||
1238 | |||
1239 | UFSD("ENTER\n"); | ||
1240 | |||
1241 | if (!(sb->s_flags & MS_RDONLY)) | ||
1242 | ufs_put_super_internal(sb); | ||
1243 | |||
1244 | ubh_brelse_uspi (sbi->s_uspi); | ||
1245 | kfree (sbi->s_uspi); | ||
1246 | kfree (sbi); | ||
1247 | sb->s_fs_info = NULL; | ||
1248 | UFSD("EXIT\n"); | ||
1249 | return; | ||
1250 | } | ||
1251 | |||
1252 | |||
1253 | static int ufs_remount (struct super_block *sb, int *mount_flags, char *data) | 1252 | static int ufs_remount (struct super_block *sb, int *mount_flags, char *data) |
1254 | { | 1253 | { |
1255 | struct ufs_sb_private_info * uspi; | 1254 | struct ufs_sb_private_info * uspi; |