diff options
author | Steven Whitehouse <swhiteho@redhat.com> | 2006-07-06 17:58:03 -0400 |
---|---|---|
committer | Steven Whitehouse <swhiteho@redhat.com> | 2006-07-06 17:58:03 -0400 |
commit | 29937ac6caa68d60c7f1a3e07b6137cf53e09e24 (patch) | |
tree | ace90d235f2ee44926885efeab8d6fe9761427f8 /fs/gfs2/inode.c | |
parent | 71ec63c5d66b577a71910b82740751be73e81310 (diff) |
[GFS2] Fixes to scanning of glocks (again)
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>
Diffstat (limited to 'fs/gfs2/inode.c')
-rw-r--r-- | fs/gfs2/inode.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/gfs2/inode.c b/fs/gfs2/inode.c index 6499c4f91078..f4c48395208a 100644 --- a/fs/gfs2/inode.c +++ b/fs/gfs2/inode.c | |||
@@ -325,6 +325,7 @@ int gfs2_change_nlink(struct gfs2_inode *ip, int diff) | |||
325 | uint32_t nlink; | 325 | uint32_t nlink; |
326 | int error; | 326 | int error; |
327 | 327 | ||
328 | BUG_ON(ip->i_di.di_nlink != ip->i_inode.i_nlink); | ||
328 | nlink = ip->i_di.di_nlink + diff; | 329 | nlink = ip->i_di.di_nlink + diff; |
329 | 330 | ||
330 | /* If we are reducing the nlink count, but the new value ends up being | 331 | /* 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) | |||
341 | 342 | ||
342 | ip->i_di.di_nlink = nlink; | 343 | ip->i_di.di_nlink = nlink; |
343 | ip->i_di.di_ctime = get_seconds(); | 344 | ip->i_di.di_ctime = get_seconds(); |
345 | ip->i_inode.i_nlink = nlink; | ||
344 | 346 | ||
345 | gfs2_trans_add_bh(ip->i_gl, dibh, 1); | 347 | gfs2_trans_add_bh(ip->i_gl, dibh, 1); |
346 | gfs2_dinode_out(&ip->i_di, dibh->b_data); | 348 | gfs2_dinode_out(&ip->i_di, dibh->b_data); |