Skip to content

Commit 379c3bc

Browse files
committed
svcrdma: Add common XDR encoders for RDMA and Read segments
Clean up: De-duplicate some code. Signed-off-by: Chuck Lever <[email protected]>
1 parent f60a086 commit 379c3bc

File tree

3 files changed

+41
-14
lines changed

3 files changed

+41
-14
lines changed

include/linux/sunrpc/rpc_rdma.h

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -124,6 +124,43 @@ rpcrdma_decode_buffer_size(u8 val)
124124
return ((unsigned int)val + 1) << 10;
125125
}
126126

127+
/**
128+
* xdr_encode_rdma_segment - Encode contents of an RDMA segment
129+
* @p: Pointer into a send buffer
130+
* @handle: The RDMA handle to encode
131+
* @length: The RDMA length to encode
132+
* @offset: The RDMA offset to encode
133+
*
134+
* Return value:
135+
* Pointer to the XDR position that follows the encoded RDMA segment
136+
*/
137+
static inline __be32 *xdr_encode_rdma_segment(__be32 *p, u32 handle,
138+
u32 length, u64 offset)
139+
{
140+
*p++ = cpu_to_be32(handle);
141+
*p++ = cpu_to_be32(length);
142+
return xdr_encode_hyper(p, offset);
143+
}
144+
145+
/**
146+
* xdr_encode_read_segment - Encode contents of a Read segment
147+
* @p: Pointer into a send buffer
148+
* @position: The position to encode
149+
* @handle: The RDMA handle to encode
150+
* @length: The RDMA length to encode
151+
* @offset: The RDMA offset to encode
152+
*
153+
* Return value:
154+
* Pointer to the XDR position that follows the encoded Read segment
155+
*/
156+
static inline __be32 *xdr_encode_read_segment(__be32 *p, u32 position,
157+
u32 handle, u32 length,
158+
u64 offset)
159+
{
160+
*p++ = cpu_to_be32(position);
161+
return xdr_encode_rdma_segment(p, handle, length, offset);
162+
}
163+
127164
/**
128165
* xdr_decode_rdma_segment - Decode contents of an RDMA segment
129166
* @p: Pointer to the undecoded RDMA segment

net/sunrpc/xprtrdma/rpc_rdma.c

Lines changed: 3 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -275,14 +275,6 @@ rpcrdma_convert_iovs(struct rpcrdma_xprt *r_xprt, struct xdr_buf *xdrbuf,
275275
return n;
276276
}
277277

278-
static void
279-
xdr_encode_rdma_segment(__be32 *iptr, struct rpcrdma_mr *mr)
280-
{
281-
*iptr++ = cpu_to_be32(mr->mr_handle);
282-
*iptr++ = cpu_to_be32(mr->mr_length);
283-
xdr_encode_hyper(iptr, mr->mr_offset);
284-
}
285-
286278
static int
287279
encode_rdma_segment(struct xdr_stream *xdr, struct rpcrdma_mr *mr)
288280
{
@@ -292,7 +284,7 @@ encode_rdma_segment(struct xdr_stream *xdr, struct rpcrdma_mr *mr)
292284
if (unlikely(!p))
293285
return -EMSGSIZE;
294286

295-
xdr_encode_rdma_segment(p, mr);
287+
xdr_encode_rdma_segment(p, mr->mr_handle, mr->mr_length, mr->mr_offset);
296288
return 0;
297289
}
298290

@@ -307,8 +299,8 @@ encode_read_segment(struct xdr_stream *xdr, struct rpcrdma_mr *mr,
307299
return -EMSGSIZE;
308300

309301
*p++ = xdr_one; /* Item present */
310-
*p++ = cpu_to_be32(position);
311-
xdr_encode_rdma_segment(p, mr);
302+
xdr_encode_read_segment(p, position, mr->mr_handle, mr->mr_length,
303+
mr->mr_offset);
312304
return 0;
313305
}
314306

net/sunrpc/xprtrdma/svc_rdma_sendto.c

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -376,7 +376,6 @@ static ssize_t svc_rdma_encode_write_segment(__be32 *src,
376376

377377
xdr_decode_rdma_segment(src, &handle, &length, &offset);
378378

379-
*p++ = cpu_to_be32(handle);
380379
if (*remaining < length) {
381380
/* segment only partly filled */
382381
length = *remaining;
@@ -385,8 +384,7 @@ static ssize_t svc_rdma_encode_write_segment(__be32 *src,
385384
/* entire segment was consumed */
386385
*remaining -= length;
387386
}
388-
*p++ = cpu_to_be32(length);
389-
xdr_encode_hyper(p, offset);
387+
xdr_encode_rdma_segment(p, handle, length, offset);
390388

391389
trace_svcrdma_encode_wseg(handle, length, offset);
392390
return len;

0 commit comments

Comments
 (0)