diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2024-06-10 22:00:20 +0200 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2024-06-10 22:00:20 +0200 |
commit | ed06248019908dd4f286552594ac3ec844ef3da4 (patch) | |
tree | d90142eac590a54a0d086f2c356fd16d90887929 | |
parent | ba5a23422a156804234dff6c5be89e20ee8f9ec2 (diff) | |
download | glibc-ed06248019908dd4f286552594ac3ec844ef3da4.zip glibc-ed06248019908dd4f286552594ac3ec844ef3da4.tar.gz glibc-ed06248019908dd4f286552594ac3ec844ef3da4.tar.bz2 |
hurd: Fix setxattr return value on replacing
When XATTR_REPLACE is set we shall succeed when the value already
exists, and fail with ENODATA otherwise, instead of the converse.
-rw-r--r-- | hurd/xattr.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/hurd/xattr.c b/hurd/xattr.c index f613d47..1a84c90 100644 --- a/hurd/xattr.c +++ b/hurd/xattr.c @@ -158,10 +158,9 @@ _hurd_xattr_set (io_t port, const char *name, const void *value, size_t size, if (err) return err; if (bufsz > 0) - { - __munmap (buf, bufsz); - return ENODATA; - } + __munmap (buf, bufsz); + else + return ENODATA; } return __file_set_translator (port, FS_TRANS_SET | ((flags & XATTR_CREATE) |