gfs2: don't return ENODATA in __gfs2_xattr_set unless replacing
authorErnesto A. Fernández <ernesto.mnd.fernandez@gmail.com>
Wed, 30 Aug 2017 12:26:30 +0000 (07:26 -0500)
committerBob Peterson <rpeterso@redhat.com>
Thu, 31 Aug 2017 12:43:03 +0000 (07:43 -0500)
commit54aae14beee6a6e9f72358f1873b3e497029c41d
tree20fc8689454f86a7a9984df602c1ec8bc033dc85
parentc4a9d1892f1ce6fe040b717b68bd21e689cc2410
gfs2: don't return ENODATA in __gfs2_xattr_set unless replacing

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 <ernesto.mnd.fernandez@gmail.com>
Signed-off-by: Bob Peterson <rpeterso@redhat.com>
fs/gfs2/xattr.c