From 24fbf4c418fd013491bcd06173f0c5cce91e4e26 Mon Sep 17 00:00:00 2001 From: Hirofumi Ogawa Date: Fri, 25 Jul 2003 02:12:54 -0700 Subject: [PATCH] fat_access cleanup (6/11) This reads ->free_clusters without lock_fat() in fat_statfs(). --- fs/fat/inode.c | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) (limited to 'fs') diff --git a/fs/fat/inode.c b/fs/fat/inode.c index 9ac84b93aaa9..0809cfee59d4 100644 --- a/fs/fat/inode.c +++ b/fs/fat/inode.c @@ -1024,19 +1024,23 @@ out_fail: int fat_statfs(struct super_block *sb, struct kstatfs *buf) { - int free,nr; + int free, nr; - lock_fat(sb); if (MSDOS_SB(sb)->free_clusters != -1) free = MSDOS_SB(sb)->free_clusters; else { - free = 0; - for (nr = 2; nr < MSDOS_SB(sb)->clusters + 2; nr++) - if (fat_access(sb, nr, -1) == FAT_ENT_FREE) - free++; - MSDOS_SB(sb)->free_clusters = free; + lock_fat(sb); + if (MSDOS_SB(sb)->free_clusters != -1) + free = MSDOS_SB(sb)->free_clusters; + else { + free = 0; + for (nr = 2; nr < MSDOS_SB(sb)->clusters + 2; nr++) + if (fat_access(sb, nr, -1) == FAT_ENT_FREE) + free++; + MSDOS_SB(sb)->free_clusters = free; + } + unlock_fat(sb); } - unlock_fat(sb); buf->f_type = sb->s_magic; buf->f_bsize = 1 << MSDOS_SB(sb)->cluster_bits; -- cgit v1.2.3