]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
ceph: pass unhandled ceph.* setxattrs through to MDS
authorSage Weil <sage@inktank.com>
Thu, 31 Jan 2013 19:53:41 +0000 (11:53 -0800)
committerSage Weil <sage@inktank.com>
Thu, 14 Feb 2013 02:25:51 +0000 (18:25 -0800)
If we do not specifically understand a setxattr on a ceph.* virtual
xattr, send it through to the MDS.  This allows us to implement new
functionality via the MDS without direct support on the client side.

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Sam Lang <sam.lang@inktank.com>
fs/ceph/xattr.c

index 43063d0dee8f16973a78b964fb76db7d8fb1d9d9..edc47de77fed31533d194fa44f0b339c364918f8 100644 (file)
@@ -777,6 +777,10 @@ int ceph_setxattr(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;
+
        /* preallocate memory for xattr name, value, index node */
        err = -ENOMEM;
        newname = kmemdup(name, name_len + 1, GFP_NOFS);
@@ -833,6 +837,7 @@ retry:
 
 do_sync:
        spin_unlock(&ci->i_ceph_lock);
+do_sync_unlocked:
        err = ceph_sync_setxattr(dentry, name, value, size, flags);
 out:
        kfree(newname);