xref: /openbmc/linux/fs/jffs2/security.c (revision c00c310e)
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/slab.h>
14aa98d7cfSKaiGai Kohei #include <linux/fs.h>
15aa98d7cfSKaiGai Kohei #include <linux/time.h>
16aa98d7cfSKaiGai Kohei #include <linux/pagemap.h>
17aa98d7cfSKaiGai Kohei #include <linux/highmem.h>
18aa98d7cfSKaiGai Kohei #include <linux/crc32.h>
19aa98d7cfSKaiGai Kohei #include <linux/jffs2.h>
20aa98d7cfSKaiGai Kohei #include <linux/xattr.h>
21aa98d7cfSKaiGai Kohei #include <linux/mtd/mtd.h>
22aa98d7cfSKaiGai Kohei #include <linux/security.h>
23aa98d7cfSKaiGai Kohei #include "nodelist.h"
24aa98d7cfSKaiGai Kohei 
25aa98d7cfSKaiGai Kohei /* ---- Initial Security Label Attachment -------------- */
26aa98d7cfSKaiGai Kohei int jffs2_init_security(struct inode *inode, struct inode *dir)
27aa98d7cfSKaiGai Kohei {
28aa98d7cfSKaiGai Kohei 	int rc;
29aa98d7cfSKaiGai Kohei 	size_t len;
30aa98d7cfSKaiGai Kohei 	void *value;
31aa98d7cfSKaiGai Kohei 	char *name;
32aa98d7cfSKaiGai Kohei 
33aa98d7cfSKaiGai Kohei 	rc = security_inode_init_security(inode, dir, &name, &value, &len);
34aa98d7cfSKaiGai Kohei 	if (rc) {
35aa98d7cfSKaiGai Kohei 		if (rc == -EOPNOTSUPP)
36aa98d7cfSKaiGai Kohei 			return 0;
37aa98d7cfSKaiGai Kohei 		return rc;
38aa98d7cfSKaiGai Kohei 	}
39aa98d7cfSKaiGai Kohei 	rc = do_jffs2_setxattr(inode, JFFS2_XPREFIX_SECURITY, name, value, len, 0);
40aa98d7cfSKaiGai Kohei 
41aa98d7cfSKaiGai Kohei         kfree(name);
42aa98d7cfSKaiGai Kohei         kfree(value);
43aa98d7cfSKaiGai Kohei         return rc;
44aa98d7cfSKaiGai Kohei }
45aa98d7cfSKaiGai Kohei 
46aa98d7cfSKaiGai Kohei /* ---- XATTR Handler for "security.*" ----------------- */
47aa98d7cfSKaiGai Kohei static int jffs2_security_getxattr(struct inode *inode, const char *name,
48aa98d7cfSKaiGai Kohei 				   void *buffer, size_t size)
49aa98d7cfSKaiGai Kohei {
50aa98d7cfSKaiGai Kohei 	if (!strcmp(name, ""))
51aa98d7cfSKaiGai Kohei 		return -EINVAL;
52aa98d7cfSKaiGai Kohei 
53aa98d7cfSKaiGai Kohei 	return do_jffs2_getxattr(inode, JFFS2_XPREFIX_SECURITY, name, buffer, size);
54aa98d7cfSKaiGai Kohei }
55aa98d7cfSKaiGai Kohei 
56aa98d7cfSKaiGai Kohei static int jffs2_security_setxattr(struct inode *inode, const char *name, const void *buffer,
57aa98d7cfSKaiGai Kohei 				   size_t size, int flags)
58aa98d7cfSKaiGai Kohei {
59aa98d7cfSKaiGai Kohei 	if (!strcmp(name, ""))
60aa98d7cfSKaiGai Kohei 		return -EINVAL;
61aa98d7cfSKaiGai Kohei 
62aa98d7cfSKaiGai Kohei 	return do_jffs2_setxattr(inode, JFFS2_XPREFIX_SECURITY, name, buffer, size, flags);
63aa98d7cfSKaiGai Kohei }
64aa98d7cfSKaiGai Kohei 
65aa98d7cfSKaiGai Kohei static size_t jffs2_security_listxattr(struct inode *inode, char *list, size_t list_size,
66aa98d7cfSKaiGai Kohei 				       const char *name, size_t name_len)
67aa98d7cfSKaiGai Kohei {
68aa98d7cfSKaiGai Kohei 	size_t retlen = XATTR_SECURITY_PREFIX_LEN + name_len + 1;
69aa98d7cfSKaiGai Kohei 
70aa98d7cfSKaiGai Kohei 	if (list && retlen <= list_size) {
71aa98d7cfSKaiGai Kohei 		strcpy(list, XATTR_SECURITY_PREFIX);
72aa98d7cfSKaiGai Kohei 		strcpy(list + XATTR_SECURITY_PREFIX_LEN, name);
73aa98d7cfSKaiGai Kohei 	}
74aa98d7cfSKaiGai Kohei 
75aa98d7cfSKaiGai Kohei 	return retlen;
76aa98d7cfSKaiGai Kohei }
77aa98d7cfSKaiGai Kohei 
78aa98d7cfSKaiGai Kohei struct xattr_handler jffs2_security_xattr_handler = {
79aa98d7cfSKaiGai Kohei 	.prefix = XATTR_SECURITY_PREFIX,
80aa98d7cfSKaiGai Kohei 	.list = jffs2_security_listxattr,
81aa98d7cfSKaiGai Kohei 	.set = jffs2_security_setxattr,
82aa98d7cfSKaiGai Kohei 	.get = jffs2_security_getxattr
83aa98d7cfSKaiGai Kohei };
84