]> git.neil.brown.name Git - history.git/commitdiff
[PATCH] use new fat_get_cluster (8/11)
authorHirofumi Ogawa <hirofumi@mail.parknet.co.jp>
Fri, 25 Jul 2003 09:13:07 +0000 (02:13 -0700)
committerLinus Torvalds <torvalds@home.osdl.org>
Fri, 25 Jul 2003 09:13:07 +0000 (02:13 -0700)
This uses the new fat_get_cluster() in fat_bmap_cluster().  Another part
removes an unneeded error check of fat_get_entry() by using
fat_get_cluster().

fs/fat/cache.c
fs/fat/misc.c

index 102738f6af82b2adf87cdda03bf87bfa4a81a428..485c050d8501410078238faa68520699c0e13a83 100644 (file)
@@ -332,28 +332,20 @@ int fat_get_cluster(struct inode *inode, int cluster, int *fclus, int *dclus)
 static int fat_bmap_cluster(struct inode *inode, int cluster)
 {
        struct super_block *sb = inode->i_sb;
-       int nr,count;
+       int ret, fclus, dclus;
 
-       if (!(nr = MSDOS_I(inode)->i_start)) return 0;
-       if (!cluster) return nr;
-       count = 0;
-       for (fat_cache_lookup(inode, cluster, &count, &nr);
-            count < cluster;
-            count++) {
-               nr = fat_access(sb, nr, -1);
-               if (nr == FAT_ENT_EOF) {
-                       fat_fs_panic(sb, "%s: request beyond EOF (ino %lu)",
-                                    __FUNCTION__, inode->i_ino);
-                       return -EIO;
-               } else if (nr == FAT_ENT_FREE) {
-                       fat_fs_panic(sb, "%s: invalid cluster chain (ino %lu)",
-                                    __FUNCTION__, inode->i_ino);
-                       return -EIO;
-               } else if (nr < 0)
-                       return nr;
+       if (MSDOS_I(inode)->i_start == 0)
+               return 0;
+
+       ret = fat_get_cluster(inode, cluster, &fclus, &dclus);
+       if (ret < 0)
+               return ret;
+       else if (ret == FAT_ENT_EOF) {
+               fat_fs_panic(sb, "%s: request beyond EOF (i_pos %llu)",
+                            __FUNCTION__, MSDOS_I(inode)->i_pos);
+               return -EIO;
        }
-       fat_cache_add(inode, cluster, nr);
-       return nr;
+       return dclus;
 }
 
 int fat_bmap(struct inode *inode, sector_t sector, sector_t *phys)
index 84d9791468775dee409573484fe869efefcc51e8..5a9cc67339eee46469b6876b468e588212aad3cd 100644 (file)
@@ -330,15 +330,7 @@ static int fat_get_short_entry(struct inode *dir, loff_t *pos,
                               struct buffer_head **bh,
                               struct msdos_dir_entry **de, loff_t *i_pos)
 {
-       struct super_block *sb = dir->i_sb;
-
        while (fat_get_entry(dir, pos, bh, de, i_pos) >= 0) {
-               if (*pos >= FAT_MAX_DIR_SIZE) {
-                       fat_fs_panic(sb, "Directory %llu: "
-                                    "exceeded the maximum size of directory",
-                                    MSDOS_I(dir)->i_pos);
-                       return -EIO;
-               }
                /* free entry or long name entry or volume label */
                if (!IS_FREE((*de)->name) && !((*de)->attr & ATTR_VOLUME))
                        return 0;