]> git.neil.brown.name Git - history.git/commitdiff
[PATCH] ->cluster_size cleanup (11/11)
authorHirofumi Ogawa <hirofumi@mail.parknet.co.jp>
Fri, 25 Jul 2003 09:13:29 +0000 (02:13 -0700)
committerLinus Torvalds <torvalds@home.osdl.org>
Fri, 25 Jul 2003 09:13:29 +0000 (02:13 -0700)
This renames ->cluster_size to ->sec_per_clus. Old ->cluster_size was
"sectors per cluster". Adds a _real_ ->cluster_size.

fs/fat/cache.c
fs/fat/file.c
fs/fat/inode.c
fs/fat/misc.c
include/linux/msdos_fs.h
include/linux/msdos_fs_sb.h

index eeecd8a2b780043661a380998b2e4abb3eaf6fb2..9884189dece76846fbec0d31b75c5b0a4c87ad8b 100644 (file)
@@ -371,12 +371,12 @@ int fat_bmap(struct inode *inode, sector_t sector, sector_t *phys)
                return 0;
 
        cluster = sector >> (sbi->cluster_bits - sb->s_blocksize_bits);
-       offset  = sector & (sbi->cluster_size - 1);
+       offset  = sector & (sbi->sec_per_clus - 1);
        cluster = fat_bmap_cluster(inode, cluster);
        if (cluster < 0)
                return cluster;
        else if (cluster) {
-               *phys = ((sector_t)cluster - 2) * sbi->cluster_size
+               *phys = ((sector_t)cluster - 2) * sbi->sec_per_clus
                        + sbi->data_start + offset;
        }
        return 0;
@@ -434,7 +434,7 @@ int fat_free(struct inode *inode, int skip)
                }
                if (MSDOS_SB(sb)->free_clusters != -1)
                        MSDOS_SB(sb)->free_clusters++;
-               inode->i_blocks -= (1 << MSDOS_SB(sb)->cluster_bits) >> 9;
+               inode->i_blocks -= MSDOS_SB(sb)->cluster_size >> 9;
        } while (nr != FAT_ENT_EOF);
        fat_clusters_flush(sb);
        nr = 0;
index 8f2babbeb4f7050569c0ef1f23d0960323485f04..029190ca34e3e5fbb3dcf3d2a8a46a1952308894 100644 (file)
@@ -48,7 +48,7 @@ int fat_get_block(struct inode *inode, sector_t iblock,
                BUG();
                return -EIO;
        }
-       if (!((unsigned long)iblock % MSDOS_SB(sb)->cluster_size)) {
+       if (!((unsigned long)iblock % MSDOS_SB(sb)->sec_per_clus)) {
                int error;
 
                error = fat_add_cluster(inode);
@@ -84,14 +84,15 @@ static ssize_t fat_file_write(struct file *filp, const char *buf, size_t count,
 void fat_truncate(struct inode *inode)
 {
        struct msdos_sb_info *sbi = MSDOS_SB(inode->i_sb);
-       int cluster;
+       const unsigned int cluster_size = sbi->cluster_size;
+       int nr_clusters;
 
        /* Why no return value?  Surely the disk could fail... */
        if (IS_RDONLY (inode))
                return /* -EPERM */;
        if (IS_IMMUTABLE(inode))
                return /* -EPERM */;
-       cluster = 1 << sbi->cluster_bits;
+
        /* 
         * This protects against truncating a file bigger than it was then
         * trying to write into the hole.
@@ -99,8 +100,10 @@ void fat_truncate(struct inode *inode)
        if (MSDOS_I(inode)->mmu_private > inode->i_size)
                MSDOS_I(inode)->mmu_private = inode->i_size;
 
+       nr_clusters = (inode->i_size + (cluster_size - 1)) >> sbi->cluster_bits;
+
        lock_kernel();
-       fat_free(inode, (inode->i_size + (cluster - 1)) >> sbi->cluster_bits);
+       fat_free(inode, nr_clusters);
        MSDOS_I(inode)->i_attrs |= ATTR_ARCH;
        unlock_kernel();
        inode->i_ctime = inode->i_mtime = CURRENT_TIME;
index da7130f71693e4458094ef66117c56aaa811f542..4d23eafeca3d2cda638ab8109efc201099fe683c 100644 (file)
@@ -504,9 +504,9 @@ static int fat_read_root(struct inode *inode)
                MSDOS_I(inode)->i_start = 0;
                inode->i_size = sbi->dir_entries * sizeof(struct msdos_dir_entry);
        }
-       inode->i_blksize = 1 << sbi->cluster_bits;
-       inode->i_blocks = ((inode->i_size + inode->i_blksize - 1)
-                          & ~((loff_t)inode->i_blksize - 1)) >> 9;
+       inode->i_blksize = sbi->cluster_size;
+       inode->i_blocks = ((inode->i_size + (sbi->cluster_size - 1))
+                          & ~((loff_t)sbi->cluster_size - 1)) >> 9;
        MSDOS_I(inode)->i_logstart = 0;
        MSDOS_I(inode)->mmu_private = inode->i_size;
 
@@ -810,12 +810,12 @@ int fat_fill_super(struct super_block *sb, void *data, int silent,
                brelse(bh);
                goto out_invalid;
        }
-       sbi->cluster_size = b->cluster_size;
-       if (!sbi->cluster_size
-           || (sbi->cluster_size & (sbi->cluster_size - 1))) {
+       sbi->sec_per_clus = b->sec_per_clus;
+       if (!sbi->sec_per_clus
+           || (sbi->sec_per_clus & (sbi->sec_per_clus - 1))) {
                if (!silent)
-                       printk(KERN_ERR "FAT: bogus cluster size %d\n",
-                              sbi->cluster_size);
+                       printk(KERN_ERR "FAT: bogus sectors per cluster %d\n",
+                              sbi->sec_per_clus);
                brelse(bh);
                goto out_invalid;
        }
@@ -844,7 +844,8 @@ int fat_fill_super(struct super_block *sb, void *data, int silent,
                b = (struct fat_boot_sector *) bh->b_data;
        }
 
-       sbi->cluster_bits = ffs(sb->s_blocksize * sbi->cluster_size) - 1;
+       sbi->cluster_size = sb->s_blocksize * sbi->sec_per_clus;
+       sbi->cluster_bits = ffs(sbi->cluster_size) - 1;
        sbi->fats = b->fats;
        sbi->fat_bits = 0;              /* Don't know yet */
        sbi->fat_start = CF_LE_W(b->reserved);
@@ -912,7 +913,7 @@ int fat_fill_super(struct super_block *sb, void *data, int silent,
        total_sectors = CF_LE_W(get_unaligned((unsigned short *)&b->sectors));
        if (total_sectors == 0)
                total_sectors = CF_LE_L(b->total_sect);
-       sbi->clusters = (total_sectors - sbi->data_start) / sbi->cluster_size;
+       sbi->clusters = (total_sectors - sbi->data_start) / sbi->sec_per_clus;
 
        if (sbi->fat_bits != 32)
                sbi->fat_bits = (sbi->clusters > MSDOS_FAT12) ? 16 : 12;
@@ -1028,7 +1029,7 @@ int fat_statfs(struct super_block *sb, struct kstatfs *buf)
        }
 
        buf->f_type = sb->s_magic;
-       buf->f_bsize = 1 << MSDOS_SB(sb)->cluster_bits;
+       buf->f_bsize = MSDOS_SB(sb)->cluster_size;
        buf->f_blocks = MSDOS_SB(sb)->clusters;
        buf->f_bfree = free;
        buf->f_bavail = free;
@@ -1141,9 +1142,9 @@ static int fat_fill_inode(struct inode *inode, struct msdos_dir_entry *de)
                        inode->i_flags |= S_IMMUTABLE;
        MSDOS_I(inode)->i_attrs = de->attr & ATTR_UNUSED;
        /* this is as close to the truth as we can get ... */
-       inode->i_blksize = 1 << sbi->cluster_bits;
-       inode->i_blocks = ((inode->i_size + inode->i_blksize - 1)
-                          & ~((loff_t)inode->i_blksize - 1)) >> 9;
+       inode->i_blksize = sbi->cluster_size;
+       inode->i_blocks = ((inode->i_size + (sbi->cluster_size - 1))
+                          & ~((loff_t)sbi->cluster_size - 1)) >> 9;
        inode->i_mtime.tv_sec = inode->i_atime.tv_sec =
                date_dos2unix(CF_LE_W(de->time),CF_LE_W(de->date));
        inode->i_mtime.tv_nsec = inode->i_atime.tv_nsec = 0;
index da1fad702cd242ec35436d51683d4a3d7a576dc2..d4c56f74c762b6943ef03c76c9f185a37a579392 100644 (file)
@@ -154,7 +154,7 @@ int fat_add_cluster(struct inode *inode)
                        new_fclus, inode->i_blocks >> (cluster_bits - 9));
                fat_cache_inval_inode(inode);
        }
-       inode->i_blocks += (1 << cluster_bits) >> 9;
+       inode->i_blocks += MSDOS_SB(sb)->cluster_size >> 9;
 
        return new_dclus;
 }
@@ -163,7 +163,7 @@ struct buffer_head *fat_extend_dir(struct inode *inode)
 {
        struct super_block *sb = inode->i_sb;
        struct buffer_head *bh, *res = NULL;
-       int nr, cluster_size = MSDOS_SB(sb)->cluster_size;
+       int nr, sec_per_clus = MSDOS_SB(sb)->sec_per_clus;
        sector_t sector, last_sector;
 
        if (MSDOS_SB(sb)->fat_bits != 32) {
@@ -175,8 +175,8 @@ struct buffer_head *fat_extend_dir(struct inode *inode)
        if (nr < 0)
                return ERR_PTR(nr);
        
-       sector = ((sector_t)nr - 2) * cluster_size + MSDOS_SB(sb)->data_start;
-       last_sector = sector + cluster_size;
+       sector = ((sector_t)nr - 2) * sec_per_clus + MSDOS_SB(sb)->data_start;
+       last_sector = sector + sec_per_clus;
        for ( ; sector < last_sector; sector++) {
                if ((bh = sb_getblk(sb, sector))) {
                        memset(bh->b_data, 0, sb->s_blocksize);
@@ -195,8 +195,8 @@ struct buffer_head *fat_extend_dir(struct inode *inode)
                inode->i_size = (inode->i_size + sb->s_blocksize)
                        & ~(sb->s_blocksize - 1);
        }
-       inode->i_size += 1 << MSDOS_SB(sb)->cluster_bits;
-       MSDOS_I(inode)->mmu_private += 1 << MSDOS_SB(sb)->cluster_bits;
+       inode->i_size += MSDOS_SB(sb)->cluster_size;
+       MSDOS_I(inode)->mmu_private += MSDOS_SB(sb)->cluster_size;
 
        return res;
 }
index 75bfcff08d49f692d221a9ac33055eb6072b312b..060549a8785195254bfb689f540ca94f57fe91ac 100644 (file)
@@ -117,7 +117,7 @@ struct fat_boot_sector {
        __u8    system_id[8];   /* Name - can be used to special case
                                   partition manager volumes */
        __u8    sector_size[2]; /* bytes per logical sector */
-       __u8    cluster_size;   /* sectors/cluster */
+       __u8    sec_per_clus;   /* sectors/cluster */
        __u16   reserved;       /* reserved sectors */
        __u8    fats;           /* number of FATs */
        __u8    dir_entries[2]; /* root directory entries */
index 339fb5624943dd5a8affd452d474530fcf7a6c56..546458d82ece7620d985e0459eae5a11bc010580 100644 (file)
@@ -36,8 +36,9 @@ struct fat_cache {
 };
 
 struct msdos_sb_info {
-       unsigned short cluster_size; /* sectors/cluster */
-       unsigned short cluster_bits; /* sectors/cluster */
+       unsigned short sec_per_clus; /* sectors/cluster */
+       unsigned short cluster_bits; /* log2(cluster_size) */
+       unsigned int cluster_size;   /* cluster size */
        unsigned char fats,fat_bits; /* number of FATs, FAT bits (12 or 16) */
        unsigned short fat_start;
        unsigned long fat_length;    /* FAT start & length (sec.) */