Commit 4b8dbdfb authored by Trond Myklebust's avatar Trond Myklebust

SUNRPC: Fix an RPC/RDMA performance regression

Use the standard gfp mask instead of using GFP_NOWAIT. The latter causes
issues when under memory pressure.
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
parent 32346491
...@@ -1340,14 +1340,11 @@ gss_hash_cred(struct auth_cred *acred, unsigned int hashbits) ...@@ -1340,14 +1340,11 @@ gss_hash_cred(struct auth_cred *acred, unsigned int hashbits)
/* /*
* Lookup RPCSEC_GSS cred for the current process * Lookup RPCSEC_GSS cred for the current process
*/ */
static struct rpc_cred * static struct rpc_cred *gss_lookup_cred(struct rpc_auth *auth,
gss_lookup_cred(struct rpc_auth *auth, struct auth_cred *acred, int flags) struct auth_cred *acred, int flags)
{ {
gfp_t gfp = GFP_KERNEL; return rpcauth_lookup_credcache(auth, acred, flags,
rpc_task_gfp_mask());
if (flags & RPCAUTH_LOOKUP_ASYNC)
gfp = GFP_NOWAIT | __GFP_NOWARN;
return rpcauth_lookup_credcache(auth, acred, flags, gfp);
} }
static struct rpc_cred * static struct rpc_cred *
......
...@@ -63,6 +63,7 @@ gfp_t rpc_task_gfp_mask(void) ...@@ -63,6 +63,7 @@ gfp_t rpc_task_gfp_mask(void)
return GFP_KERNEL | __GFP_NORETRY | __GFP_NOWARN; return GFP_KERNEL | __GFP_NORETRY | __GFP_NOWARN;
return GFP_KERNEL; return GFP_KERNEL;
} }
EXPORT_SYMBOL_GPL(rpc_task_gfp_mask);
unsigned long unsigned long
rpc_task_timeout(const struct rpc_task *task) rpc_task_timeout(const struct rpc_task *task)
......
...@@ -571,11 +571,7 @@ xprt_rdma_allocate(struct rpc_task *task) ...@@ -571,11 +571,7 @@ xprt_rdma_allocate(struct rpc_task *task)
struct rpc_rqst *rqst = task->tk_rqstp; struct rpc_rqst *rqst = task->tk_rqstp;
struct rpcrdma_xprt *r_xprt = rpcx_to_rdmax(rqst->rq_xprt); struct rpcrdma_xprt *r_xprt = rpcx_to_rdmax(rqst->rq_xprt);
struct rpcrdma_req *req = rpcr_to_rdmar(rqst); struct rpcrdma_req *req = rpcr_to_rdmar(rqst);
gfp_t flags; gfp_t flags = rpc_task_gfp_mask();
flags = RPCRDMA_DEF_GFP;
if (RPC_IS_ASYNC(task))
flags = GFP_NOWAIT | __GFP_NOWARN;
if (!rpcrdma_check_regbuf(r_xprt, req->rl_sendbuf, rqst->rq_callsize, if (!rpcrdma_check_regbuf(r_xprt, req->rl_sendbuf, rqst->rq_callsize,
flags)) flags))
......
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