xref: /openbmc/linux/fs/ext4/xattr_hurd.c (revision 39f60c1c)
188ee9d57SJan (janneke) Nieuwenhuizen // SPDX-License-Identifier: GPL-2.0
288ee9d57SJan (janneke) Nieuwenhuizen /*
388ee9d57SJan (janneke) Nieuwenhuizen  * linux/fs/ext4/xattr_hurd.c
488ee9d57SJan (janneke) Nieuwenhuizen  * Handler for extended gnu attributes for the Hurd.
588ee9d57SJan (janneke) Nieuwenhuizen  *
688ee9d57SJan (janneke) Nieuwenhuizen  * Copyright (C) 2001 by Andreas Gruenbacher, <a.gruenbacher@computer.org>
788ee9d57SJan (janneke) Nieuwenhuizen  * Copyright (C) 2020 by Jan (janneke) Nieuwenhuizen, <janneke@gnu.org>
888ee9d57SJan (janneke) Nieuwenhuizen  */
988ee9d57SJan (janneke) Nieuwenhuizen 
1088ee9d57SJan (janneke) Nieuwenhuizen #include <linux/init.h>
1188ee9d57SJan (janneke) Nieuwenhuizen #include <linux/string.h>
1288ee9d57SJan (janneke) Nieuwenhuizen #include "ext4.h"
1388ee9d57SJan (janneke) Nieuwenhuizen #include "xattr.h"
1488ee9d57SJan (janneke) Nieuwenhuizen 
1588ee9d57SJan (janneke) Nieuwenhuizen static bool
ext4_xattr_hurd_list(struct dentry * dentry)1688ee9d57SJan (janneke) Nieuwenhuizen ext4_xattr_hurd_list(struct dentry *dentry)
1788ee9d57SJan (janneke) Nieuwenhuizen {
1888ee9d57SJan (janneke) Nieuwenhuizen 	return test_opt(dentry->d_sb, XATTR_USER);
1988ee9d57SJan (janneke) Nieuwenhuizen }
2088ee9d57SJan (janneke) Nieuwenhuizen 
2188ee9d57SJan (janneke) Nieuwenhuizen static int
ext4_xattr_hurd_get(const struct xattr_handler * handler,struct dentry * unused,struct inode * inode,const char * name,void * buffer,size_t size)2288ee9d57SJan (janneke) Nieuwenhuizen ext4_xattr_hurd_get(const struct xattr_handler *handler,
2388ee9d57SJan (janneke) Nieuwenhuizen 		    struct dentry *unused, struct inode *inode,
2488ee9d57SJan (janneke) Nieuwenhuizen 		    const char *name, void *buffer, size_t size)
2588ee9d57SJan (janneke) Nieuwenhuizen {
2688ee9d57SJan (janneke) Nieuwenhuizen 	if (!test_opt(inode->i_sb, XATTR_USER))
2788ee9d57SJan (janneke) Nieuwenhuizen 		return -EOPNOTSUPP;
2888ee9d57SJan (janneke) Nieuwenhuizen 
2988ee9d57SJan (janneke) Nieuwenhuizen 	return ext4_xattr_get(inode, EXT4_XATTR_INDEX_HURD,
3088ee9d57SJan (janneke) Nieuwenhuizen 			      name, buffer, size);
3188ee9d57SJan (janneke) Nieuwenhuizen }
3288ee9d57SJan (janneke) Nieuwenhuizen 
3388ee9d57SJan (janneke) Nieuwenhuizen static int
ext4_xattr_hurd_set(const struct xattr_handler * handler,struct mnt_idmap * idmap,struct dentry * unused,struct inode * inode,const char * name,const void * value,size_t size,int flags)3488ee9d57SJan (janneke) Nieuwenhuizen ext4_xattr_hurd_set(const struct xattr_handler *handler,
35*39f60c1cSChristian Brauner 		    struct mnt_idmap *idmap,
3688ee9d57SJan (janneke) Nieuwenhuizen 		    struct dentry *unused, struct inode *inode,
3788ee9d57SJan (janneke) Nieuwenhuizen 		    const char *name, const void *value,
3888ee9d57SJan (janneke) Nieuwenhuizen 		    size_t size, int flags)
3988ee9d57SJan (janneke) Nieuwenhuizen {
4088ee9d57SJan (janneke) Nieuwenhuizen 	if (!test_opt(inode->i_sb, XATTR_USER))
4188ee9d57SJan (janneke) Nieuwenhuizen 		return -EOPNOTSUPP;
4288ee9d57SJan (janneke) Nieuwenhuizen 
4388ee9d57SJan (janneke) Nieuwenhuizen 	return ext4_xattr_set(inode, EXT4_XATTR_INDEX_HURD,
4488ee9d57SJan (janneke) Nieuwenhuizen 			      name, value, size, flags);
4588ee9d57SJan (janneke) Nieuwenhuizen }
4688ee9d57SJan (janneke) Nieuwenhuizen 
4788ee9d57SJan (janneke) Nieuwenhuizen const struct xattr_handler ext4_xattr_hurd_handler = {
4888ee9d57SJan (janneke) Nieuwenhuizen 	.prefix	= XATTR_HURD_PREFIX,
4988ee9d57SJan (janneke) Nieuwenhuizen 	.list	= ext4_xattr_hurd_list,
5088ee9d57SJan (janneke) Nieuwenhuizen 	.get	= ext4_xattr_hurd_get,
5188ee9d57SJan (janneke) Nieuwenhuizen 	.set	= ext4_xattr_hurd_set,
5288ee9d57SJan (janneke) Nieuwenhuizen };
53