From: Sage Weil Date: Mon, 21 Jan 2013 05:55:30 +0000 (-0800) Subject: ceph: pass ceph.* removexattrs through to MDS X-Git-Tag: upstream/snapshot3+hdmi~5334^2~24^2~55 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d421acb1ad7dfa31b7463b67f1593714b0b727c3;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git ceph: pass ceph.* removexattrs through to MDS If we do not explicitly recognized a vxattr (e.g., as readonly), pass the request through to the MDS and deal with it there. Signed-off-by: Sage Weil Reviewed-by: Sam Lang --- diff --git a/fs/ceph/xattr.c b/fs/ceph/xattr.c index edc47de..234270f 100644 --- a/fs/ceph/xattr.c +++ b/fs/ceph/xattr.c @@ -892,6 +892,10 @@ int ceph_removexattr(struct dentry *dentry, const char *name) if (vxattr && vxattr->readonly) return -EOPNOTSUPP; + /* pass any unhandled ceph.* xattrs through to the MDS */ + if (!strncmp(name, XATTR_CEPH_PREFIX, XATTR_CEPH_PREFIX_LEN)) + goto do_sync_unlocked; + err = -ENOMEM; spin_lock(&ci->i_ceph_lock); retry: @@ -931,6 +935,7 @@ retry: return err; do_sync: spin_unlock(&ci->i_ceph_lock); +do_sync_unlocked: err = ceph_send_removexattr(dentry, name); out: return err;