mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-11 15:49:56 +00:00
md-cluster: init completion within lockres_init
We should init completion within lockres_init, otherwise completion could be initialized more than one time during it's life cycle. Reviewed-by: Goldwyn Rodrigues <rgoldwyn@suse.com> Signed-off-by: Guoqing Jiang <gqjiang@suse.com> Signed-off-by: NeilBrown <neilb@suse.com>
This commit is contained in:
parent
66099bb0ee
commit
b83d51c078
@ -100,7 +100,6 @@ static int dlm_lock_sync(struct dlm_lock_resource *res, int mode)
|
|||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
init_completion(&res->completion);
|
|
||||||
ret = dlm_lock(res->ls, mode, &res->lksb,
|
ret = dlm_lock(res->ls, mode, &res->lksb,
|
||||||
res->flags, res->name, strlen(res->name),
|
res->flags, res->name, strlen(res->name),
|
||||||
0, sync_ast, res, res->bast);
|
0, sync_ast, res, res->bast);
|
||||||
@ -125,6 +124,7 @@ static struct dlm_lock_resource *lockres_init(struct mddev *mddev,
|
|||||||
res = kzalloc(sizeof(struct dlm_lock_resource), GFP_KERNEL);
|
res = kzalloc(sizeof(struct dlm_lock_resource), GFP_KERNEL);
|
||||||
if (!res)
|
if (!res)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
init_completion(&res->completion);
|
||||||
res->ls = cinfo->lockspace;
|
res->ls = cinfo->lockspace;
|
||||||
res->mddev = mddev;
|
res->mddev = mddev;
|
||||||
namelen = strlen(name);
|
namelen = strlen(name);
|
||||||
@ -169,7 +169,6 @@ static void lockres_free(struct dlm_lock_resource *res)
|
|||||||
if (!res)
|
if (!res)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
init_completion(&res->completion);
|
|
||||||
dlm_unlock(res->ls, res->lksb.sb_lkid, 0, &res->lksb, res);
|
dlm_unlock(res->ls, res->lksb.sb_lkid, 0, &res->lksb, res);
|
||||||
wait_for_completion(&res->completion);
|
wait_for_completion(&res->completion);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user