diff options
Diffstat (limited to 'net/ceph/osd_client.c')
| -rw-r--r-- | net/ceph/osd_client.c | 20 | 
1 files changed, 14 insertions, 6 deletions
| diff --git a/net/ceph/osd_client.c b/net/ceph/osd_client.c index 11c04e7d928e..658a6f2320cf 100644 --- a/net/ceph/osd_client.c +++ b/net/ceph/osd_client.c @@ -3334,17 +3334,24 @@ static int linger_reg_commit_wait(struct ceph_osd_linger_request *lreq)  	int ret;  	dout("%s lreq %p linger_id %llu\n", __func__, lreq, lreq->linger_id); -	ret = wait_for_completion_interruptible(&lreq->reg_commit_wait); +	ret = wait_for_completion_killable(&lreq->reg_commit_wait);  	return ret ?: lreq->reg_commit_error;  } -static int linger_notify_finish_wait(struct ceph_osd_linger_request *lreq) +static int linger_notify_finish_wait(struct ceph_osd_linger_request *lreq, +				     unsigned long timeout)  { -	int ret; +	long left;  	dout("%s lreq %p linger_id %llu\n", __func__, lreq, lreq->linger_id); -	ret = wait_for_completion_interruptible(&lreq->notify_finish_wait); -	return ret ?: lreq->notify_finish_error; +	left = wait_for_completion_killable_timeout(&lreq->notify_finish_wait, +						ceph_timeout_jiffies(timeout)); +	if (left <= 0) +		left = left ?: -ETIMEDOUT; +	else +		left = lreq->notify_finish_error; /* completed */ + +	return left;  }  /* @@ -4896,7 +4903,8 @@ int ceph_osdc_notify(struct ceph_osd_client *osdc,  	linger_submit(lreq);  	ret = linger_reg_commit_wait(lreq);  	if (!ret) -		ret = linger_notify_finish_wait(lreq); +		ret = linger_notify_finish_wait(lreq, +				 msecs_to_jiffies(2 * timeout * MSEC_PER_SEC));  	else  		dout("lreq %p failed to initiate notify %d\n", lreq, ret); | 
