diff options
| author | Scott Mayhew <smayhew@redhat.com> | 2025-04-16 11:23:38 -0400 | 
|---|---|---|
| committer | Anna Schumaker <anna.schumaker@oracle.com> | 2025-05-19 10:14:29 -0400 | 
| commit | 6e9a2f8dbe93c8004c2af2c0158888628b7ca034 (patch) | |
| tree | dfdb59937c90e74cda10e3396c268323ac072ad7 /rust/helpers/err.c | |
| parent | e5296637a322b840d772f88f4d58b4bc72b29058 (diff) | |
NFSv4: xattr handlers should check for absent nfs filehandles
The nfs inodes for referral anchors that have not yet been followed have
their filehandles zeroed out.
Attempting to call getxattr() on one of these will cause the nfs client
to send a GETATTR to the nfs server with the preceding PUTFH sans
filehandle.  The server will reply NFS4ERR_NOFILEHANDLE, leading to -EIO
being returned to the application.
For example:
$ strace -e trace=getxattr getfattr -n system.nfs4_acl /mnt/t/ref
getxattr("/mnt/t/ref", "system.nfs4_acl", NULL, 0) = -1 EIO (Input/output error)
/mnt/t/ref: system.nfs4_acl: Input/output error
+++ exited with 1 +++
Have the xattr handlers return -ENODATA instead.
Signed-off-by: Scott Mayhew <smayhew@redhat.com>
Signed-off-by: Anna Schumaker <anna.schumaker@oracle.com>
Diffstat (limited to 'rust/helpers/err.c')
0 files changed, 0 insertions, 0 deletions
