1652ecc20SKaiGai Kohei /* 2652ecc20SKaiGai Kohei * JFFS2 -- Journalling Flash File System, Version 2. 3aa98d7cfSKaiGai Kohei * 4c00c310eSDavid Woodhouse * Copyright © 2006 NEC Corporation 5aa98d7cfSKaiGai Kohei * 6652ecc20SKaiGai Kohei * Created by KaiGai Kohei <kaigai@ak.jp.nec.com> 7652ecc20SKaiGai Kohei * 8652ecc20SKaiGai Kohei * For licensing information, see the file 'LICENCE' in this directory. 9652ecc20SKaiGai Kohei * 10652ecc20SKaiGai Kohei */ 11c00c310eSDavid Woodhouse 12aa98d7cfSKaiGai Kohei #include <linux/kernel.h> 13aa98d7cfSKaiGai Kohei #include <linux/fs.h> 14aa98d7cfSKaiGai Kohei #include <linux/jffs2.h> 15aa98d7cfSKaiGai Kohei #include <linux/xattr.h> 16aa98d7cfSKaiGai Kohei #include <linux/mtd/mtd.h> 17aa98d7cfSKaiGai Kohei #include "nodelist.h" 18aa98d7cfSKaiGai Kohei 19*d9a82a04SAndreas Gruenbacher static int jffs2_user_getxattr(const struct xattr_handler *handler, 20*d9a82a04SAndreas Gruenbacher struct dentry *dentry, const char *name, 21*d9a82a04SAndreas Gruenbacher void *buffer, size_t size) 22aa98d7cfSKaiGai Kohei { 23aa98d7cfSKaiGai Kohei if (!strcmp(name, "")) 24aa98d7cfSKaiGai Kohei return -EINVAL; 252b0143b5SDavid Howells return do_jffs2_getxattr(d_inode(dentry), JFFS2_XPREFIX_USER, 26431547b3SChristoph Hellwig name, buffer, size); 27aa98d7cfSKaiGai Kohei } 28aa98d7cfSKaiGai Kohei 29*d9a82a04SAndreas Gruenbacher static int jffs2_user_setxattr(const struct xattr_handler *handler, 30*d9a82a04SAndreas Gruenbacher struct dentry *dentry, const char *name, 31*d9a82a04SAndreas Gruenbacher const void *buffer, size_t size, int flags) 32aa98d7cfSKaiGai Kohei { 33aa98d7cfSKaiGai Kohei if (!strcmp(name, "")) 34aa98d7cfSKaiGai Kohei return -EINVAL; 352b0143b5SDavid Howells return do_jffs2_setxattr(d_inode(dentry), JFFS2_XPREFIX_USER, 36431547b3SChristoph Hellwig name, buffer, size, flags); 37aa98d7cfSKaiGai Kohei } 38aa98d7cfSKaiGai Kohei 39*d9a82a04SAndreas Gruenbacher static size_t jffs2_user_listxattr(const struct xattr_handler *handler, 40*d9a82a04SAndreas Gruenbacher struct dentry *dentry, char *list, 41*d9a82a04SAndreas Gruenbacher size_t list_size, const char *name, 42*d9a82a04SAndreas Gruenbacher size_t name_len) 43aa98d7cfSKaiGai Kohei { 44aa98d7cfSKaiGai Kohei size_t retlen = XATTR_USER_PREFIX_LEN + name_len + 1; 45aa98d7cfSKaiGai Kohei 46aa98d7cfSKaiGai Kohei if (list && retlen <= list_size) { 47aa98d7cfSKaiGai Kohei strcpy(list, XATTR_USER_PREFIX); 48aa98d7cfSKaiGai Kohei strcpy(list + XATTR_USER_PREFIX_LEN, name); 49aa98d7cfSKaiGai Kohei } 50aa98d7cfSKaiGai Kohei 51aa98d7cfSKaiGai Kohei return retlen; 52aa98d7cfSKaiGai Kohei } 53aa98d7cfSKaiGai Kohei 54365f0cb9SStephen Hemminger const struct xattr_handler jffs2_user_xattr_handler = { 55aa98d7cfSKaiGai Kohei .prefix = XATTR_USER_PREFIX, 56aa98d7cfSKaiGai Kohei .list = jffs2_user_listxattr, 57aa98d7cfSKaiGai Kohei .set = jffs2_user_setxattr, 58aa98d7cfSKaiGai Kohei .get = jffs2_user_getxattr 59aa98d7cfSKaiGai Kohei }; 60