diff options
author | Chuck Lever <chuck.lever@oracle.com> | 2022-07-22 22:08:38 +0200 |
---|---|---|
committer | Chuck Lever <chuck.lever@oracle.com> | 2022-07-30 02:16:57 +0200 |
commit | 095a764b7afb06c9499b798c04eaa3cbf70ebe2d (patch) | |
tree | 0c404a2fdb9660498fd150b22cd8ad6f887a7f8e /fs/nfsd/nfs4xdr.c | |
parent | nfsd: silence extraneous printk on nfsd.ko insertion (diff) | |
download | linux-095a764b7afb06c9499b798c04eaa3cbf70ebe2d.tar.xz linux-095a764b7afb06c9499b798c04eaa3cbf70ebe2d.zip |
NFSD: Optimize nfsd4_encode_operation()
write_bytes_to_xdr_buf() is a generic way to place a variable-length
data item in an already-reserved spot in the encoding buffer.
However, it is costly, and here, it is unnecessary because the
data item is fixed in size, the buffer destination address is
always word-aligned, and the destination location is already in
@p.
Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Diffstat (limited to 'fs/nfsd/nfs4xdr.c')
-rw-r--r-- | fs/nfsd/nfs4xdr.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/fs/nfsd/nfs4xdr.c b/fs/nfsd/nfs4xdr.c index 2acea7792bb2..b52ea7d8313a 100644 --- a/fs/nfsd/nfs4xdr.c +++ b/fs/nfsd/nfs4xdr.c @@ -5373,8 +5373,7 @@ nfsd4_encode_operation(struct nfsd4_compoundres *resp, struct nfsd4_op *op) so->so_replay.rp_buf, len); } status: - /* Note that op->status is already in network byte order: */ - write_bytes_to_xdr_buf(xdr->buf, post_err_offset - 4, &op->status, 4); + *p = op->status; } /* |