GFS2: For exhash conversion, only one block is needed
authorSteven Whitehouse <swhiteho@redhat.com>
Wed, 8 Jan 2014 11:05:29 +0000 (11:05 +0000)
committerSteven Whitehouse <swhiteho@redhat.com>
Wed, 8 Jan 2014 11:05:29 +0000 (11:05 +0000)
For most cases, only a single new block is needed when we reach
the point of converting from stuffed to exhash directory. The
exception being when the file name is so long that it will not
fit within the new leaf block.

So this patch adds a simple test for that situation so that we
do not need to request the full reservation size in this case.

Potentially we could calculate more accurately the value to use
in other cases too, but that is much more complicated to do and
it is doubtful that the benefit would outweigh the extra cost
in code complexity.

Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
fs/gfs2/dir.c

index d5988aafaa74f4e4741139d55b95012ff997ecfa..b2e5ebfb4bb130c82e028323be3eb7076ee0038d 100644 (file)
@@ -2035,7 +2035,9 @@ out:
 int gfs2_diradd_alloc_required(struct inode *inode, const struct qstr *name,
                               struct gfs2_diradd *da)
 {
+       struct gfs2_inode *ip = GFS2_I(inode);
        struct gfs2_sbd *sdp = GFS2_SB(inode);
+       const unsigned int extra = sizeof(struct gfs2_dinode) - sizeof(struct gfs2_leaf);
        struct gfs2_dirent *dent;
        struct buffer_head *bh;
 
@@ -2046,6 +2048,9 @@ int gfs2_diradd_alloc_required(struct inode *inode, const struct qstr *name,
        dent = gfs2_dirent_search(inode, name, gfs2_dirent_find_space, &bh);
        if (!dent) {
                da->nr_blocks = sdp->sd_max_dirres;
+               if (!(ip->i_diskflags & GFS2_DIF_EXHASH) &&
+                   (GFS2_DIRENT_SIZE(name->len) < extra))
+                       da->nr_blocks = 1;
                return 0;
        }
        if (IS_ERR(dent))
This page took 0.034262 seconds and 5 git commands to generate.