diff options
Diffstat (limited to 'net/sunrpc/svc.c')
| -rw-r--r-- | net/sunrpc/svc.c | 28 | 
1 files changed, 19 insertions, 9 deletions
| diff --git a/net/sunrpc/svc.c b/net/sunrpc/svc.c index b1fab3a69544..4704dce7284e 100644 --- a/net/sunrpc/svc.c +++ b/net/sunrpc/svc.c @@ -352,7 +352,7 @@ static int svc_pool_map_get_node(unsigned int pidx)  		if (m->mode == SVC_POOL_PERNODE)  			return m->pool_to[pidx];  	} -	return NUMA_NO_NODE; +	return numa_mem_id();  }  /*   * Set the given thread's cpus_allowed mask so that it @@ -436,7 +436,6 @@ void svc_rpcb_cleanup(struct svc_serv *serv, struct net *net)  	svc_unregister(serv, net);  	rpcb_put_local(net);  } -EXPORT_SYMBOL_GPL(svc_rpcb_cleanup);  static int svc_uses_rpcbind(struct svc_serv *serv)  { @@ -670,8 +669,8 @@ svc_rqst_free(struct svc_rqst *rqstp)  	folio_batch_release(&rqstp->rq_fbatch);  	kfree(rqstp->rq_bvec);  	svc_release_buffer(rqstp); -	if (rqstp->rq_scratch_page) -		put_page(rqstp->rq_scratch_page); +	if (rqstp->rq_scratch_folio) +		folio_put(rqstp->rq_scratch_folio);  	kfree(rqstp->rq_resp);  	kfree(rqstp->rq_argp);  	kfree(rqstp->rq_auth_data); @@ -692,8 +691,8 @@ svc_prepare_thread(struct svc_serv *serv, struct svc_pool *pool, int node)  	rqstp->rq_server = serv;  	rqstp->rq_pool = pool; -	rqstp->rq_scratch_page = alloc_pages_node(node, GFP_KERNEL, 0); -	if (!rqstp->rq_scratch_page) +	rqstp->rq_scratch_folio = __folio_alloc_node(GFP_KERNEL, 0, node); +	if (!rqstp->rq_scratch_folio)  		goto out_enomem;  	rqstp->rq_argp = kmalloc_node(serv->sv_xdrsize, GFP_KERNEL, node); @@ -1426,8 +1425,6 @@ svc_process_common(struct svc_rqst *rqstp)  	/* Call the function that processes the request. */  	rc = process.dispatch(rqstp); -	if (procp->pc_release) -		procp->pc_release(rqstp);  	xdr_finish_decode(xdr);  	if (!rc) @@ -1526,6 +1523,14 @@ static void svc_drop(struct svc_rqst *rqstp)  	trace_svc_drop(rqstp);  } +static void svc_release_rqst(struct svc_rqst *rqstp) +{ +	const struct svc_procedure *procp = rqstp->rq_procinfo; + +	if (procp && procp->pc_release) +		procp->pc_release(rqstp); +} +  /**   * svc_process - Execute one RPC transaction   * @rqstp: RPC transaction context @@ -1565,9 +1570,12 @@ void svc_process(struct svc_rqst *rqstp)  	if (unlikely(*p != rpc_call))  		goto out_baddir; -	if (!svc_process_common(rqstp)) +	if (!svc_process_common(rqstp)) { +		svc_release_rqst(rqstp);  		goto out_drop; +	}  	svc_send(rqstp); +	svc_release_rqst(rqstp);  	return;  out_baddir: @@ -1635,6 +1643,7 @@ void svc_process_bc(struct rpc_rqst *req, struct svc_rqst *rqstp)  	if (!proc_error) {  		/* Processing error: drop the request */  		xprt_free_bc_request(req); +		svc_release_rqst(rqstp);  		return;  	}  	/* Finally, send the reply synchronously */ @@ -1648,6 +1657,7 @@ void svc_process_bc(struct rpc_rqst *req, struct svc_rqst *rqstp)  	timeout.to_maxval = timeout.to_initval;  	memcpy(&req->rq_snd_buf, &rqstp->rq_res, sizeof(req->rq_snd_buf));  	task = rpc_run_bc_task(req, &timeout); +	svc_release_rqst(rqstp);  	if (IS_ERR(task))  		return; | 
