diff options
author | Trond Myklebust <trond.myklebust@primarydata.com> | 2016-06-25 19:19:28 -0400 |
---|---|---|
committer | Anna Schumaker <Anna.Schumaker@Netapp.com> | 2016-06-28 16:55:34 -0400 |
commit | e547f2628327fec6afd2e03b46f113f614cca05b (patch) | |
tree | 9daba7ada0d5a10f7fdf1828f38954d86253dcc1 /include/linux/userfaultfd_k.h | |
parent | d20cb71dbf3487f24549ede1a8e2d67579b4632e (diff) | |
download | talos-obmc-linux-e547f2628327fec6afd2e03b46f113f614cca05b.tar.gz talos-obmc-linux-e547f2628327fec6afd2e03b46f113f614cca05b.zip |
NFS: Fix another OPEN_DOWNGRADE bug
Olga Kornievskaia reports that the following test fails to trigger
an OPEN_DOWNGRADE on the wire, and only triggers the final CLOSE.
fd0 = open(foo, RDRW) -- should be open on the wire for "both"
fd1 = open(foo, RDONLY) -- should be open on the wire for "read"
close(fd0) -- should trigger an open_downgrade
read(fd1)
close(fd1)
The issue is that we're missing a check for whether or not the current
state transitioned from an O_RDWR state as opposed to having transitioned
from a combination of O_RDONLY and O_WRONLY.
Reported-by: Olga Kornievskaia <aglo@umich.edu>
Fixes: cd9288ffaea4 ("NFSv4: Fix another bug in the close/open_downgrade code")
Cc: stable@vger.kernel.org # 2.6.33+
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
Diffstat (limited to 'include/linux/userfaultfd_k.h')
0 files changed, 0 insertions, 0 deletions