Commit 1307a0fd authored by NeilBrown's avatar NeilBrown Committed by Greg Kroah-Hartman

staging: lustre: make polling loop in ptlrpc_unregister_bulk more obvious

This use of l_wait_event() is a polling loop that re-checks
every second.  Make this more obvious with a while loop
and wait_event_idle_timeout().
Reviewed-by: default avatarJames Simmons <jsimmons@infradead.org>
Signed-off-by: default avatarNeilBrown <neilb@suse.com>
Reviewed-by: default avatarPatrick Farrell <paf@cray.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent cac6e457
...@@ -229,7 +229,6 @@ int ptlrpc_unregister_bulk(struct ptlrpc_request *req, int async) ...@@ -229,7 +229,6 @@ int ptlrpc_unregister_bulk(struct ptlrpc_request *req, int async)
{ {
struct ptlrpc_bulk_desc *desc = req->rq_bulk; struct ptlrpc_bulk_desc *desc = req->rq_bulk;
wait_queue_head_t *wq; wait_queue_head_t *wq;
struct l_wait_info lwi;
int rc; int rc;
LASSERT(!in_interrupt()); /* might sleep */ LASSERT(!in_interrupt()); /* might sleep */
...@@ -246,7 +245,7 @@ int ptlrpc_unregister_bulk(struct ptlrpc_request *req, int async) ...@@ -246,7 +245,7 @@ int ptlrpc_unregister_bulk(struct ptlrpc_request *req, int async)
/* the unlink ensures the callback happens ASAP and is the last /* the unlink ensures the callback happens ASAP and is the last
* one. If it fails, it must be because completion just happened, * one. If it fails, it must be because completion just happened,
* but we must still l_wait_event() in this case to give liblustre * but we must still wait_event() in this case to give liblustre
* a chance to run client_bulk_callback() * a chance to run client_bulk_callback()
*/ */
mdunlink_iterate_helper(desc->bd_mds, desc->bd_md_max_brw); mdunlink_iterate_helper(desc->bd_mds, desc->bd_md_max_brw);
...@@ -270,15 +269,17 @@ int ptlrpc_unregister_bulk(struct ptlrpc_request *req, int async) ...@@ -270,15 +269,17 @@ int ptlrpc_unregister_bulk(struct ptlrpc_request *req, int async)
/* Network access will complete in finite time but the HUGE /* Network access will complete in finite time but the HUGE
* timeout lets us CWARN for visibility of sluggish LNDs * timeout lets us CWARN for visibility of sluggish LNDs
*/ */
lwi = LWI_TIMEOUT_INTERVAL(LONG_UNLINK * HZ, int cnt = 0;
HZ, NULL, NULL); while (cnt < LONG_UNLINK &&
rc = l_wait_event(*wq, !ptlrpc_client_bulk_active(req), &lwi); (rc = wait_event_idle_timeout(*wq,
if (rc == 0) { !ptlrpc_client_bulk_active(req),
HZ)) == 0)
cnt += 1;
if (rc > 0) {
ptlrpc_rqphase_move(req, req->rq_next_phase); ptlrpc_rqphase_move(req, req->rq_next_phase);
return 1; return 1;
} }
LASSERT(rc == -ETIMEDOUT);
DEBUG_REQ(D_WARNING, req, "Unexpectedly long timeout: desc %p", DEBUG_REQ(D_WARNING, req, "Unexpectedly long timeout: desc %p",
desc); desc);
} }
......
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