diff options
author | Chuck Lever <chuck.lever@oracle.com> | 2020-07-25 00:08:57 +0300 |
---|---|---|
committer | Chuck Lever <chuck.lever@oracle.com> | 2020-07-25 00:10:23 +0300 |
commit | 986a4b63d3bc5f2c0eb4083b05aff2bf883b7b2f (patch) | |
tree | e10a0734385d66e46ed12116a15f3c3676681021 /net/ax25/ax25_ds_in.c | |
parent | df60446cd1fb487becd1f36f4c0da9e0e523c0cf (diff) | |
download | linux-986a4b63d3bc5f2c0eb4083b05aff2bf883b7b2f.tar.xz |
SUNRPC: Fix ("SUNRPC: Add "@len" parameter to gss_unwrap()")
Braino when converting "buf->len -=" to "buf->len = len -".
The result is under-estimation of the ralign and rslack values. On
krb5p mounts, this has caused READDIR to fail with EIO, and KASAN
splats when decoding READLINK replies.
As a result of fixing this oversight, the gss_unwrap method now
returns a buf->len that can be shorter than priv_len for small
RPC messages. The additional adjustment done in unwrap_priv_data()
can underflow buf->len. This causes the nfsd_request_too_large
check to fail during some NFSv3 operations.
Reported-by: Marian Rainer-Harbach
Reported-by: Pierre Sauter <pierre.sauter@stwm.de>
BugLink: https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1886277
Fixes: 31c9590ae468 ("SUNRPC: Add "@len" parameter to gss_unwrap()")
Reviewed-by: J. Bruce Fields <bfields@redhat.com>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Diffstat (limited to 'net/ax25/ax25_ds_in.c')
0 files changed, 0 insertions, 0 deletions