Blame view
fs/ext4/xattr_security.c
1.81 KB
ac27a0ec1
|
1 |
/* |
617ba13b3
|
2 |
* linux/fs/ext4/xattr_security.c |
ac27a0ec1
|
3 4 5 6 7 8 |
* Handler for storing security labels as extended attributes. */ #include <linux/module.h> #include <linux/string.h> #include <linux/fs.h> |
dab291af8
|
9 |
#include <linux/ext4_jbd2.h> |
617ba13b3
|
10 |
#include <linux/ext4_fs.h> |
ac27a0ec1
|
11 12 13 14 |
#include <linux/security.h> #include "xattr.h" static size_t |
617ba13b3
|
15 |
ext4_xattr_security_list(struct inode *inode, char *list, size_t list_size, |
ac27a0ec1
|
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
const char *name, size_t name_len) { const size_t prefix_len = sizeof(XATTR_SECURITY_PREFIX)-1; const size_t total_len = prefix_len + name_len + 1; if (list && total_len <= list_size) { memcpy(list, XATTR_SECURITY_PREFIX, prefix_len); memcpy(list+prefix_len, name, name_len); list[prefix_len + name_len] = '\0'; } return total_len; } static int |
617ba13b3
|
31 |
ext4_xattr_security_get(struct inode *inode, const char *name, |
ac27a0ec1
|
32 33 34 35 |
void *buffer, size_t size) { if (strcmp(name, "") == 0) return -EINVAL; |
617ba13b3
|
36 |
return ext4_xattr_get(inode, EXT4_XATTR_INDEX_SECURITY, name, |
ac27a0ec1
|
37 38 39 40 |
buffer, size); } static int |
617ba13b3
|
41 |
ext4_xattr_security_set(struct inode *inode, const char *name, |
ac27a0ec1
|
42 43 44 45 |
const void *value, size_t size, int flags) { if (strcmp(name, "") == 0) return -EINVAL; |
617ba13b3
|
46 |
return ext4_xattr_set(inode, EXT4_XATTR_INDEX_SECURITY, name, |
ac27a0ec1
|
47 48 49 50 |
value, size, flags); } int |
617ba13b3
|
51 |
ext4_init_security(handle_t *handle, struct inode *inode, struct inode *dir) |
ac27a0ec1
|
52 53 54 55 56 57 58 59 60 61 62 63 |
{ int err; size_t len; void *value; char *name; err = security_inode_init_security(inode, dir, &name, &value, &len); if (err) { if (err == -EOPNOTSUPP) return 0; return err; } |
617ba13b3
|
64 |
err = ext4_xattr_set_handle(handle, inode, EXT4_XATTR_INDEX_SECURITY, |
ac27a0ec1
|
65 66 67 68 69 |
name, value, len, 0); kfree(name); kfree(value); return err; } |
617ba13b3
|
70 |
struct xattr_handler ext4_xattr_security_handler = { |
ac27a0ec1
|
71 |
.prefix = XATTR_SECURITY_PREFIX, |
617ba13b3
|
72 73 74 |
.list = ext4_xattr_security_list, .get = ext4_xattr_security_get, .set = ext4_xattr_security_set, |
ac27a0ec1
|
75 |
}; |