Commit 109b88ab authored by Chuck Lever's avatar Chuck Lever Committed by Anna Schumaker

xprtrdma: Address coverity complaint about wait_for_completion()

> ** CID 114101:  Error handling issues  (CHECKED_RETURN)
> /net/sunrpc/xprtrdma/verbs.c: 355 in rpcrdma_create_id()

Commit 5675add3 ("RPC/RDMA: harden connection logic against
missing/late rdma_cm upcalls.") replaced wait_for_completion() calls
with these two call sites.

The original wait_for_completion() calls were added in the initial
commit of verbs.c, which was commit c56c65fb ("RPCRDMA: rpc rdma
verbs interface implementation"), but these returned void.

rpcrdma_create_id() is called by the RDMA connect worker, which
probably won't ever be interrupted. It is also called by
rpcrdma_ia_open which is in the synchronous mount path, and ^C is
possible there.

Add a bit of logic at those two call sites to return if the waits
return ERESTARTSYS.
Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
Signed-off-by: default avatarAnna Schumaker <Anna.Schumaker@Netapp.com>
parent ae09531d
...@@ -331,6 +331,7 @@ static struct rdma_cm_id * ...@@ -331,6 +331,7 @@ static struct rdma_cm_id *
rpcrdma_create_id(struct rpcrdma_xprt *xprt, rpcrdma_create_id(struct rpcrdma_xprt *xprt,
struct rpcrdma_ia *ia, struct sockaddr *addr) struct rpcrdma_ia *ia, struct sockaddr *addr)
{ {
unsigned long wtimeout = msecs_to_jiffies(RDMA_RESOLVE_TIMEOUT) + 1;
struct rdma_cm_id *id; struct rdma_cm_id *id;
int rc; int rc;
...@@ -352,8 +353,12 @@ rpcrdma_create_id(struct rpcrdma_xprt *xprt, ...@@ -352,8 +353,12 @@ rpcrdma_create_id(struct rpcrdma_xprt *xprt,
__func__, rc); __func__, rc);
goto out; goto out;
} }
wait_for_completion_interruptible_timeout(&ia->ri_done, rc = wait_for_completion_interruptible_timeout(&ia->ri_done, wtimeout);
msecs_to_jiffies(RDMA_RESOLVE_TIMEOUT) + 1); if (rc < 0) {
dprintk("RPC: %s: wait() exited: %i\n",
__func__, rc);
goto out;
}
/* FIXME: /* FIXME:
* Until xprtrdma supports DEVICE_REMOVAL, the provider must * Until xprtrdma supports DEVICE_REMOVAL, the provider must
...@@ -376,8 +381,12 @@ rpcrdma_create_id(struct rpcrdma_xprt *xprt, ...@@ -376,8 +381,12 @@ rpcrdma_create_id(struct rpcrdma_xprt *xprt,
__func__, rc); __func__, rc);
goto put; goto put;
} }
wait_for_completion_interruptible_timeout(&ia->ri_done, rc = wait_for_completion_interruptible_timeout(&ia->ri_done, wtimeout);
msecs_to_jiffies(RDMA_RESOLVE_TIMEOUT) + 1); if (rc < 0) {
dprintk("RPC: %s: wait() exited: %i\n",
__func__, rc);
goto put;
}
rc = ia->ri_async_rc; rc = ia->ri_async_rc;
if (rc) if (rc)
goto put; goto put;
......
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