Skip to content

Commit

Permalink
[PATCH] fat: move fat_clusters_flush() to write_super()
Browse files Browse the repository at this point in the history
It is overkill to update the FS_INFO whenever modifying
prev_free/free_clusters, because those are just a hint.

So, this patch uses ->write_super() for updating FS_INFO instead.

Signed-off-by: OGAWA Hirofumi <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
  • Loading branch information
OGAWAHirofumi authored and Linus Torvalds committed Jan 9, 2006
1 parent 9ded96f commit a6bf6b2
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 6 deletions.
8 changes: 6 additions & 2 deletions fs/fat/fatent.c
Original file line number Diff line number Diff line change
Expand Up @@ -476,6 +476,7 @@ int fat_alloc_clusters(struct inode *inode, int *cluster, int nr_cluster)
sbi->prev_free = entry;
if (sbi->free_clusters != -1)
sbi->free_clusters--;
sb->s_dirt = 1;

cluster[idx_clus] = entry;
idx_clus++;
Expand All @@ -496,6 +497,7 @@ int fat_alloc_clusters(struct inode *inode, int *cluster, int nr_cluster)

/* Couldn't allocate the free entries */
sbi->free_clusters = 0;
sb->s_dirt = 1;
err = -ENOSPC;

out:
Expand All @@ -509,7 +511,6 @@ int fat_alloc_clusters(struct inode *inode, int *cluster, int nr_cluster)
}
for (i = 0; i < nr_bhs; i++)
brelse(bhs[i]);
fat_clusters_flush(sb);

if (err && idx_clus)
fat_free_clusters(inode, cluster[0]);
Expand Down Expand Up @@ -542,8 +543,10 @@ int fat_free_clusters(struct inode *inode, int cluster)
}

ops->ent_put(&fatent, FAT_ENT_FREE);
if (sbi->free_clusters != -1)
if (sbi->free_clusters != -1) {
sbi->free_clusters++;
sb->s_dirt = 1;
}

if (nr_bhs + fatent.nr_bhs > MAX_BUF_PER_PAGE) {
if (sb->s_flags & MS_SYNCHRONOUS) {
Expand Down Expand Up @@ -605,6 +608,7 @@ int fat_count_free_clusters(struct super_block *sb)
} while (fat_ent_next(sbi, &fatent));
}
sbi->free_clusters = free;
sb->s_dirt = 1;
fatent_brelse(&fatent);
out:
unlock_fat(sbi);
Expand Down
10 changes: 8 additions & 2 deletions fs/fat/inode.c
Original file line number Diff line number Diff line change
Expand Up @@ -374,12 +374,17 @@ static void fat_clear_inode(struct inode *inode)
unlock_kernel();
}

static void fat_put_super(struct super_block *sb)
static void fat_write_super(struct super_block *sb)
{
struct msdos_sb_info *sbi = MSDOS_SB(sb);
sb->s_dirt = 0;

if (!(sb->s_flags & MS_RDONLY))
fat_clusters_flush(sb);
}

static void fat_put_super(struct super_block *sb)
{
struct msdos_sb_info *sbi = MSDOS_SB(sb);

if (sbi->nls_disk) {
unload_nls(sbi->nls_disk);
Expand Down Expand Up @@ -546,6 +551,7 @@ static struct super_operations fat_sops = {
.write_inode = fat_write_inode,
.delete_inode = fat_delete_inode,
.put_super = fat_put_super,
.write_super = fat_write_super,
.statfs = fat_statfs,
.clear_inode = fat_clear_inode,
.remount_fs = fat_remount,
Expand Down
2 changes: 0 additions & 2 deletions fs/fat/misc.c
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,6 @@ void fat_clusters_flush(struct super_block *sb)
if (sbi->prev_free != -1)
fsinfo->next_cluster = cpu_to_le32(sbi->prev_free);
mark_buffer_dirty(bh);
if (sb->s_flags & MS_SYNCHRONOUS)
sync_dirty_buffer(bh);
}
brelse(bh);
}
Expand Down

0 comments on commit a6bf6b2

Please sign in to comment.