[GFS2] Fixes to scanning of glocks (again)
authorSteven Whitehouse <swhiteho@redhat.com>
Thu, 6 Jul 2006 21:58:03 +0000 (17:58 -0400)
committerSteven Whitehouse <swhiteho@redhat.com>
Thu, 6 Jul 2006 21:58:03 +0000 (17:58 -0400)
This really is the correct fix this time. We just ignore all
glocks associated with inodes until the inodes are pushed
from the inode cache. At that point the glocks are queued for
reclaim, so we don't need to do it here.

Also fix one or two other minor bugs.

Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
fs/gfs2/glock.c
fs/gfs2/inode.c
fs/gfs2/ops_inode.c
fs/gfs2/page.c

index 7f362d0c3f7aac5233f95d18386a79a71571b5a1..0381d4cc414641f3c496f48e02bbb0951ba51ebd 100644 (file)
@@ -1965,19 +1965,13 @@ static int examine_bucket(glock_examiner examiner, struct gfs2_sbd *sdp,
 static void scan_glock(struct gfs2_glock *gl)
 {
        if (gfs2_glmutex_trylock(gl)) {
-               if (gl->gl_ops == &gfs2_inode_glops) {
-                       struct gfs2_inode *ip = gl->gl_object;
-                       if (ip == NULL) {
-                               struct gfs2_sbd *sdp = gl->gl_sbd;
-                               gfs2_assert_withdraw(sdp, gl->gl_state == LM_ST_UNLOCKED);
-                               goto out_schedule;
-                       }
-               }
+               if (gl->gl_ops == &gfs2_inode_glops)
+                       goto out;
                if (queue_empty(gl, &gl->gl_holders) &&
                    gl->gl_state != LM_ST_UNLOCKED &&
                    demote_ok(gl))
                        goto out_schedule;
-
+out:
                gfs2_glmutex_unlock(gl);
        }
 
index 6499c4f9107829789041792c1f3b5d8cd7abb4ab..f4c48395208a0be24e14ebf99a2d688d71bc176d 100644 (file)
@@ -325,6 +325,7 @@ int gfs2_change_nlink(struct gfs2_inode *ip, int diff)
        uint32_t nlink;
        int error;
 
+       BUG_ON(ip->i_di.di_nlink != ip->i_inode.i_nlink);
        nlink = ip->i_di.di_nlink + diff;
 
        /* If we are reducing the nlink count, but the new value ends up being
@@ -341,6 +342,7 @@ int gfs2_change_nlink(struct gfs2_inode *ip, int diff)
 
        ip->i_di.di_nlink = nlink;
        ip->i_di.di_ctime = get_seconds();
+       ip->i_inode.i_nlink = nlink;
 
        gfs2_trans_add_bh(ip->i_gl, dibh, 1);
        gfs2_dinode_out(&ip->i_di, dibh->b_data);
index 8895baafc64077515286a81bbfb6414e8d9a1d8d..caecafe0469ba1926c3c796b579c53ffdeca30d9 100644 (file)
@@ -250,6 +250,7 @@ out:
        gfs2_holder_uninit(ghs + 1);
 
        if (!error) {
+               atomic_inc(&inode->i_count);
                d_instantiate(dentry, inode);
                mark_inode_dirty(inode);
        }
index a8165a693b56c1631730c7ea0277af112b4398d6..b93caf294b9f49e7e6429bf2fcc3cb3e3d42acdb 100644 (file)
@@ -256,8 +256,7 @@ void gfs2_page_add_databufs(struct gfs2_inode *ip, struct page *page,
        struct buffer_head *bh;
        unsigned int start, end;
 
-       for (bh = head, start = 0;
-            bh != head || !start;
+       for (bh = head, start = 0; bh != head || !start;
             bh = bh->b_this_page, start = end) {
                end = start + bsize;
                if (end <= from || start >= to)