diff options
author | Chuck Lever <chuck.lever@oracle.com> | 2020-12-18 18:28:58 +0100 |
---|---|---|
committer | Chuck Lever <chuck.lever@oracle.com> | 2020-12-18 18:28:58 +0100 |
commit | 7b723008f9c95624c848fad661c01b06e47b20da (patch) | |
tree | 9cf7454596dd5ee45b66339d7a61be9dffefbd8f /net/sunrpc | |
parent | SUNRPC: Handle TCP socket sends with kernel_sendpage() again (diff) | |
download | linux-7b723008f9c95624c848fad661c01b06e47b20da.tar.xz linux-7b723008f9c95624c848fad661c01b06e47b20da.zip |
NFSD: Restore NFSv4 decoding's SAVEMEM functionality
While converting the NFSv4 decoder to use xdr_stream-based XDR
processing, I removed the old SAVEMEM() macro. This macro wrapped
a bit of logic that avoided a memory allocation by recognizing when
the decoded item resides in a linear section of the Receive buffer.
In that case, it returned a pointer into that buffer instead of
allocating a bounce buffer.
The bounce buffer is necessary only when xdr_inline_decode() has
placed the decoded item in the xdr_stream's scratch buffer, which
disappears the next time xdr_inline_decode() is called with that
xdr_stream. That happens only if the data item crosses a page
boundary in the receive buffer, an exceedingly rare occurrence.
Allocating a bounce buffer every time results in a minor performance
regression that was introduced by the recent NFSv4 decoder overhaul.
Let's restore the previous behavior. On average, it saves about 1.5
kmalloc() calls per COMPOUND.
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Diffstat (limited to 'net/sunrpc')
0 files changed, 0 insertions, 0 deletions