Commit 29937ac6 authored by Steven Whitehouse's avatar Steven Whitehouse

[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: default avatarSteven Whitehouse <swhiteho@redhat.com>
parent 71ec63c5
...@@ -1965,19 +1965,13 @@ static int examine_bucket(glock_examiner examiner, struct gfs2_sbd *sdp, ...@@ -1965,19 +1965,13 @@ static int examine_bucket(glock_examiner examiner, struct gfs2_sbd *sdp,
static void scan_glock(struct gfs2_glock *gl) static void scan_glock(struct gfs2_glock *gl)
{ {
if (gfs2_glmutex_trylock(gl)) { if (gfs2_glmutex_trylock(gl)) {
if (gl->gl_ops == &gfs2_inode_glops) { if (gl->gl_ops == &gfs2_inode_glops)
struct gfs2_inode *ip = gl->gl_object; goto out;
if (ip == NULL) {
struct gfs2_sbd *sdp = gl->gl_sbd;
gfs2_assert_withdraw(sdp, gl->gl_state == LM_ST_UNLOCKED);
goto out_schedule;
}
}
if (queue_empty(gl, &gl->gl_holders) && if (queue_empty(gl, &gl->gl_holders) &&
gl->gl_state != LM_ST_UNLOCKED && gl->gl_state != LM_ST_UNLOCKED &&
demote_ok(gl)) demote_ok(gl))
goto out_schedule; goto out_schedule;
out:
gfs2_glmutex_unlock(gl); gfs2_glmutex_unlock(gl);
} }
......
...@@ -325,6 +325,7 @@ int gfs2_change_nlink(struct gfs2_inode *ip, int diff) ...@@ -325,6 +325,7 @@ int gfs2_change_nlink(struct gfs2_inode *ip, int diff)
uint32_t nlink; uint32_t nlink;
int error; int error;
BUG_ON(ip->i_di.di_nlink != ip->i_inode.i_nlink);
nlink = ip->i_di.di_nlink + diff; nlink = ip->i_di.di_nlink + diff;
/* If we are reducing the nlink count, but the new value ends up being /* 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,6 +342,7 @@ int gfs2_change_nlink(struct gfs2_inode *ip, int diff)
ip->i_di.di_nlink = nlink; ip->i_di.di_nlink = nlink;
ip->i_di.di_ctime = get_seconds(); ip->i_di.di_ctime = get_seconds();
ip->i_inode.i_nlink = nlink;
gfs2_trans_add_bh(ip->i_gl, dibh, 1); gfs2_trans_add_bh(ip->i_gl, dibh, 1);
gfs2_dinode_out(&ip->i_di, dibh->b_data); gfs2_dinode_out(&ip->i_di, dibh->b_data);
......
...@@ -250,6 +250,7 @@ static int gfs2_link(struct dentry *old_dentry, struct inode *dir, ...@@ -250,6 +250,7 @@ static int gfs2_link(struct dentry *old_dentry, struct inode *dir,
gfs2_holder_uninit(ghs + 1); gfs2_holder_uninit(ghs + 1);
if (!error) { if (!error) {
atomic_inc(&inode->i_count);
d_instantiate(dentry, inode); d_instantiate(dentry, inode);
mark_inode_dirty(inode); mark_inode_dirty(inode);
} }
......
...@@ -256,8 +256,7 @@ void gfs2_page_add_databufs(struct gfs2_inode *ip, struct page *page, ...@@ -256,8 +256,7 @@ void gfs2_page_add_databufs(struct gfs2_inode *ip, struct page *page,
struct buffer_head *bh; struct buffer_head *bh;
unsigned int start, end; unsigned int start, end;
for (bh = head, start = 0; for (bh = head, start = 0; bh != head || !start;
bh != head || !start;
bh = bh->b_this_page, start = end) { bh = bh->b_this_page, start = end) {
end = start + bsize; end = start + bsize;
if (end <= from || start >= to) if (end <= from || start >= to)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment