Commit 2b4e926a authored by David Teigland's avatar David Teigland Committed by Steven Whitehouse

[DLM] fix loop in grant_after_purge

The loop in grant_after_purge is intended to find all rsb's in each hash
bucket that have the LOCKS_PURGED flag set.  The loop was quitting the
current bucket after finding just one rsb instead of going until there are
no more.
Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
parent f7da790d
...@@ -3366,12 +3366,16 @@ static struct dlm_rsb *find_purged_rsb(struct dlm_ls *ls, int bucket) ...@@ -3366,12 +3366,16 @@ static struct dlm_rsb *find_purged_rsb(struct dlm_ls *ls, int bucket)
void dlm_grant_after_purge(struct dlm_ls *ls) void dlm_grant_after_purge(struct dlm_ls *ls)
{ {
struct dlm_rsb *r; struct dlm_rsb *r;
int i; int bucket = 0;
for (i = 0; i < ls->ls_rsbtbl_size; i++) { while (1) {
r = find_purged_rsb(ls, i); r = find_purged_rsb(ls, bucket);
if (!r) if (!r) {
if (bucket == ls->ls_rsbtbl_size - 1)
break;
bucket++;
continue; continue;
}
lock_rsb(r); lock_rsb(r);
if (is_master(r)) { if (is_master(r)) {
grant_pending_locks(r); grant_pending_locks(r);
...@@ -3379,6 +3383,7 @@ void dlm_grant_after_purge(struct dlm_ls *ls) ...@@ -3379,6 +3383,7 @@ void dlm_grant_after_purge(struct dlm_ls *ls)
} }
unlock_rsb(r); unlock_rsb(r);
put_rsb(r); put_rsb(r);
schedule();
} }
} }
......
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