blob: e50eab0464711f6ebe363ca9f2bd7ff7767aab12 [file] [log] [blame]
Al Virof466c6f2012-03-17 01:16:43 -04001#include "reiserfs.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#include <linux/errno.h>
3#include <linux/fs.h>
4#include <linux/pagemap.h>
5#include <linux/xattr.h>
Al Viroc45ac882012-03-17 00:59:06 -04006#include "xattr.h"
Fabian Frederick170939912014-08-08 14:21:12 -07007#include <linux/uaccess.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07008
Linus Torvalds1da177e2005-04-16 15:20:36 -07009static int
Christoph Hellwig431547b2009-11-13 09:52:56 +000010user_get(struct dentry *dentry, const char *name, void *buffer, size_t size,
11 int handler_flags)
Linus Torvalds1da177e2005-04-16 15:20:36 -070012{
13
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070014 if (strlen(name) < sizeof(XATTR_USER_PREFIX))
15 return -EINVAL;
Christoph Hellwig431547b2009-11-13 09:52:56 +000016 if (!reiserfs_xattrs_user(dentry->d_sb))
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070017 return -EOPNOTSUPP;
Christoph Hellwig431547b2009-11-13 09:52:56 +000018 return reiserfs_xattr_get(dentry->d_inode, name, buffer, size);
Linus Torvalds1da177e2005-04-16 15:20:36 -070019}
20
21static int
Christoph Hellwig431547b2009-11-13 09:52:56 +000022user_set(struct dentry *dentry, const char *name, const void *buffer,
23 size_t size, int flags, int handler_flags)
Linus Torvalds1da177e2005-04-16 15:20:36 -070024{
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070025 if (strlen(name) < sizeof(XATTR_USER_PREFIX))
26 return -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -070027
Christoph Hellwig431547b2009-11-13 09:52:56 +000028 if (!reiserfs_xattrs_user(dentry->d_sb))
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070029 return -EOPNOTSUPP;
Christoph Hellwig431547b2009-11-13 09:52:56 +000030 return reiserfs_xattr_set(dentry->d_inode, name, buffer, size, flags);
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070031}
32
Christoph Hellwig431547b2009-11-13 09:52:56 +000033static size_t user_list(struct dentry *dentry, char *list, size_t list_size,
34 const char *name, size_t name_len, int handler_flags)
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070035{
Jeff Mahoney48b32a32009-03-30 14:02:38 -040036 const size_t len = name_len + 1;
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070037
Christoph Hellwig431547b2009-11-13 09:52:56 +000038 if (!reiserfs_xattrs_user(dentry->d_sb))
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070039 return 0;
Jeff Mahoney48b32a32009-03-30 14:02:38 -040040 if (list && len <= list_size) {
41 memcpy(list, name, name_len);
42 list[name_len] = '\0';
43 }
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070044 return len;
Linus Torvalds1da177e2005-04-16 15:20:36 -070045}
46
Stephen Hemminger94d09a92010-05-13 17:53:19 -070047const struct xattr_handler reiserfs_xattr_user_handler = {
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 .prefix = XATTR_USER_PREFIX,
49 .get = user_get,
50 .set = user_set,
Linus Torvalds1da177e2005-04-16 15:20:36 -070051 .list = user_list,
52};