Skip to content

Commit

Permalink
gfs2: don't return ENODATA in __gfs2_xattr_set unless replacing
Browse files Browse the repository at this point in the history
The function __gfs2_xattr_set() will return -ENODATA when called to
remove a xattr that does not exist. The result is that setfacl will
show an exit status of 1 when called to set only a file's mode bits
(on a file with no ACLs), despite succeeding. A "No data available"
error will be printed as well.

To fix this return 0 instead, except when the XATTR_REPLACE flag is
set, in which case -ENODATA is appropriate. This is consistent with
how most other xattr setting functions work, in other filesystems.

Signed-off-by: Ernesto A. Fernández <[email protected]>
Signed-off-by: Bob Peterson <[email protected]>
  • Loading branch information
eafer authored and AstralBob committed Aug 31, 2017
1 parent c4a9d18 commit 54aae14
Showing 1 changed file with 6 additions and 2 deletions.
8 changes: 6 additions & 2 deletions fs/gfs2/xattr.c
Original file line number Diff line number Diff line change
Expand Up @@ -1210,8 +1210,12 @@ int __gfs2_xattr_set(struct inode *inode, const char *name,
if (namel > GFS2_EA_MAX_NAME_LEN)
return -ERANGE;

if (value == NULL)
return gfs2_xattr_remove(ip, type, name);
if (value == NULL) {
error = gfs2_xattr_remove(ip, type, name);
if (error == -ENODATA && !(flags & XATTR_REPLACE))
error = 0;
return error;
}

if (ea_check_size(sdp, namel, size))
return -ERANGE;
Expand Down

0 comments on commit 54aae14

Please sign in to comment.