diff options
author | Chuck Lever <chuck.lever@oracle.com> | 2017-08-18 17:12:27 +0200 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2017-09-05 21:15:29 +0200 |
commit | eae03e2ac80a3476f0652cb0ee451d7b06d30564 (patch) | |
tree | a07c8ea087aec4334faf0c626f2ab5f396685622 /lib/test_user_copy.c | |
parent | merge nfsd 4.13 bugfixes into nfsd for-4.14 branch (diff) | |
download | linux-eae03e2ac80a3476f0652cb0ee451d7b06d30564.tar.xz linux-eae03e2ac80a3476f0652cb0ee451d7b06d30564.zip |
nfsd: Incoming xdr_bufs may have content in tail buffer
Since the beginning, svcsock has built a received RPC Call message
by populating the xdr_buf's head, then placing the remaining
message bytes in the xdr_buf's page list. The xdr_buf's tail is
never populated.
This means that an NFSv4 COMPOUND containing an NFS WRITE operation
plus trailing operations has a page list that contains the WRITE
data payload followed by the trailing operations. NFSv4 XDR decoders
will not look in the xdr_buf's tail, ever, because svcsock never put
anything there.
To support transports that can pass the write payload in the
xdr_buf's pagelist and trailing content in the xdr_buf's tail,
introduce logic in READ_BUF that switches to the xdr_buf's tail vec
when the decoder runs out of content in rq_arg.pages.
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'lib/test_user_copy.c')
0 files changed, 0 insertions, 0 deletions