mirror of
https://github.com/tbsdtv/linux_media.git
synced 2025-07-23 12:43:29 +02:00
svcrdma: Make svc_rdma_send_error_msg() a global function
Prepare for svc_rdma_send_error_msg() to be invoked from another source file. Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
This commit is contained in:
@@ -195,6 +195,10 @@ extern int svc_rdma_map_reply_msg(struct svcxprt_rdma *rdma,
|
||||
struct svc_rdma_send_ctxt *sctxt,
|
||||
const struct svc_rdma_recv_ctxt *rctxt,
|
||||
struct xdr_buf *xdr);
|
||||
extern void svc_rdma_send_error_msg(struct svcxprt_rdma *rdma,
|
||||
struct svc_rdma_send_ctxt *sctxt,
|
||||
struct svc_rdma_recv_ctxt *rctxt,
|
||||
int status);
|
||||
extern int svc_rdma_sendto(struct svc_rqst *);
|
||||
extern int svc_rdma_read_payload(struct svc_rqst *rqstp, unsigned int offset,
|
||||
unsigned int length);
|
||||
|
@@ -804,16 +804,25 @@ static int svc_rdma_send_reply_msg(struct svcxprt_rdma *rdma,
|
||||
return svc_rdma_send(rdma, &sctxt->sc_send_wr);
|
||||
}
|
||||
|
||||
/* Given the client-provided Write and Reply chunks, the server was not
|
||||
* able to form a complete reply. Return an RDMA_ERROR message so the
|
||||
* client can retire this RPC transaction.
|
||||
/**
|
||||
* svc_rdma_send_error_msg - Send an RPC/RDMA v1 error response
|
||||
* @rdma: controlling transport context
|
||||
* @sctxt: Send context for the response
|
||||
* @rctxt: Receive context for incoming bad message
|
||||
* @status: negative errno indicating error that occurred
|
||||
*
|
||||
* Remote Invalidation is skipped for simplicity.
|
||||
* Given the client-provided Read, Write, and Reply chunks, the
|
||||
* server was not able to parse the Call or form a complete Reply.
|
||||
* Return an RDMA_ERROR message so the client can retire the RPC
|
||||
* transaction.
|
||||
*
|
||||
* The caller does not have to release @sctxt. It is released by
|
||||
* Send completion, or by this function on error.
|
||||
*/
|
||||
static void svc_rdma_send_error_msg(struct svcxprt_rdma *rdma,
|
||||
struct svc_rdma_send_ctxt *sctxt,
|
||||
struct svc_rdma_recv_ctxt *rctxt,
|
||||
int status)
|
||||
void svc_rdma_send_error_msg(struct svcxprt_rdma *rdma,
|
||||
struct svc_rdma_send_ctxt *sctxt,
|
||||
struct svc_rdma_recv_ctxt *rctxt,
|
||||
int status)
|
||||
{
|
||||
__be32 *rdma_argp = rctxt->rc_recv_buf;
|
||||
__be32 *p;
|
||||
@@ -852,6 +861,7 @@ static void svc_rdma_send_error_msg(struct svcxprt_rdma *rdma,
|
||||
trace_svcrdma_err_chunk(*rdma_argp);
|
||||
}
|
||||
|
||||
/* Remote Invalidation is skipped for simplicity. */
|
||||
sctxt->sc_send_wr.num_sge = 1;
|
||||
sctxt->sc_send_wr.opcode = IB_WR_SEND;
|
||||
sctxt->sc_sges[0].length = sctxt->sc_hdrbuf.len;
|
||||
|
Reference in New Issue
Block a user