2006-05-13 10:18:27 +04:00
/*
* JFFS2 - - Journalling Flash File System , Version 2.
2006-05-13 10:09:47 +04:00
*
2007-04-25 17:16:47 +04:00
* Copyright © 2006 NEC Corporation
2006-05-13 10:09:47 +04:00
*
2006-05-13 10:18:27 +04:00
* Created by KaiGai Kohei < kaigai @ ak . jp . nec . com >
*
* For licensing information , see the file ' LICENCE ' in this directory .
*
*/
2007-04-25 17:16:47 +04:00
2006-05-13 10:09:47 +04:00
# include <linux/kernel.h>
# include <linux/slab.h>
# include <linux/fs.h>
# include <linux/time.h>
# include <linux/pagemap.h>
# include <linux/highmem.h>
# include <linux/crc32.h>
# include <linux/jffs2.h>
# include <linux/xattr.h>
# include <linux/mtd/mtd.h>
# include <linux/security.h>
# include "nodelist.h"
2011-06-06 23:29:25 +04:00
/* ---- Initial Security Label(s) Attachment callback --- */
2012-02-19 22:51:42 +04:00
static int jffs2_initxattrs ( struct inode * inode ,
const struct xattr * xattr_array , void * fs_info )
2006-05-13 10:09:47 +04:00
{
2011-06-06 23:29:25 +04:00
const struct xattr * xattr ;
int err = 0 ;
2006-05-13 10:09:47 +04:00
2011-06-06 23:29:25 +04:00
for ( xattr = xattr_array ; xattr - > name ! = NULL ; xattr + + ) {
err = do_jffs2_setxattr ( inode , JFFS2_XPREFIX_SECURITY ,
xattr - > name , xattr - > value ,
xattr - > value_len , 0 ) ;
if ( err < 0 )
break ;
2006-05-13 10:09:47 +04:00
}
2011-06-06 23:29:25 +04:00
return err ;
}
2006-05-13 10:09:47 +04:00
2011-06-06 23:29:25 +04:00
/* ---- Initial Security Label(s) Attachment ----------- */
int jffs2_init_security ( struct inode * inode , struct inode * dir ,
const struct qstr * qstr )
{
return security_inode_init_security ( inode , dir , qstr ,
& jffs2_initxattrs , NULL ) ;
2006-05-13 10:09:47 +04:00
}
/* ---- XATTR Handler for "security.*" ----------------- */
2009-11-13 12:52:56 +03:00
static int jffs2_security_getxattr ( struct dentry * dentry , const char * name ,
void * buffer , size_t size , int type )
2006-05-13 10:09:47 +04:00
{
if ( ! strcmp ( name , " " ) )
return - EINVAL ;
2009-11-13 12:52:56 +03:00
return do_jffs2_getxattr ( dentry - > d_inode , JFFS2_XPREFIX_SECURITY ,
name , buffer , size ) ;
2006-05-13 10:09:47 +04:00
}
2009-11-13 12:52:56 +03:00
static int jffs2_security_setxattr ( struct dentry * dentry , const char * name ,
const void * buffer , size_t size , int flags , int type )
2006-05-13 10:09:47 +04:00
{
if ( ! strcmp ( name , " " ) )
return - EINVAL ;
2009-11-13 12:52:56 +03:00
return do_jffs2_setxattr ( dentry - > d_inode , JFFS2_XPREFIX_SECURITY ,
name , buffer , size , flags ) ;
2006-05-13 10:09:47 +04:00
}
2009-11-13 12:52:56 +03:00
static size_t jffs2_security_listxattr ( struct dentry * dentry , char * list ,
size_t list_size , const char * name , size_t name_len , int type )
2006-05-13 10:09:47 +04:00
{
size_t retlen = XATTR_SECURITY_PREFIX_LEN + name_len + 1 ;
if ( list & & retlen < = list_size ) {
strcpy ( list , XATTR_SECURITY_PREFIX ) ;
strcpy ( list + XATTR_SECURITY_PREFIX_LEN , name ) ;
}
return retlen ;
}
2010-05-14 04:53:21 +04:00
const struct xattr_handler jffs2_security_xattr_handler = {
2006-05-13 10:09:47 +04:00
. prefix = XATTR_SECURITY_PREFIX ,
. list = jffs2_security_listxattr ,
. set = jffs2_security_setxattr ,
. get = jffs2_security_getxattr
} ;