ima: integrity appraisal extension
[firefly-linux-kernel-4.4.55.git] / include / linux / xattr.h
1 /*
2   File: linux/xattr.h
3
4   Extended attributes handling.
5
6   Copyright (C) 2001 by Andreas Gruenbacher <a.gruenbacher@computer.org>
7   Copyright (c) 2001-2002 Silicon Graphics, Inc.  All Rights Reserved.
8   Copyright (c) 2004 Red Hat, Inc., James Morris <jmorris@redhat.com>
9 */
10 #ifndef _LINUX_XATTR_H
11 #define _LINUX_XATTR_H
12
13 #define XATTR_CREATE    0x1     /* set value, fail if attr already exists */
14 #define XATTR_REPLACE   0x2     /* set value, fail if attr does not exist */
15
16 /* Namespaces */
17 #define XATTR_OS2_PREFIX "os2."
18 #define XATTR_OS2_PREFIX_LEN (sizeof (XATTR_OS2_PREFIX) - 1)
19
20 #define XATTR_SECURITY_PREFIX   "security."
21 #define XATTR_SECURITY_PREFIX_LEN (sizeof (XATTR_SECURITY_PREFIX) - 1)
22
23 #define XATTR_SYSTEM_PREFIX "system."
24 #define XATTR_SYSTEM_PREFIX_LEN (sizeof (XATTR_SYSTEM_PREFIX) - 1)
25
26 #define XATTR_TRUSTED_PREFIX "trusted."
27 #define XATTR_TRUSTED_PREFIX_LEN (sizeof (XATTR_TRUSTED_PREFIX) - 1)
28
29 #define XATTR_USER_PREFIX "user."
30 #define XATTR_USER_PREFIX_LEN (sizeof (XATTR_USER_PREFIX) - 1)
31
32 /* Security namespace */
33 #define XATTR_EVM_SUFFIX "evm"
34 #define XATTR_NAME_EVM XATTR_SECURITY_PREFIX XATTR_EVM_SUFFIX
35
36 #define XATTR_IMA_SUFFIX "ima"
37 #define XATTR_NAME_IMA XATTR_SECURITY_PREFIX XATTR_IMA_SUFFIX
38
39 #define XATTR_SELINUX_SUFFIX "selinux"
40 #define XATTR_NAME_SELINUX XATTR_SECURITY_PREFIX XATTR_SELINUX_SUFFIX
41
42 #define XATTR_SMACK_SUFFIX "SMACK64"
43 #define XATTR_SMACK_IPIN "SMACK64IPIN"
44 #define XATTR_SMACK_IPOUT "SMACK64IPOUT"
45 #define XATTR_SMACK_EXEC "SMACK64EXEC"
46 #define XATTR_SMACK_TRANSMUTE "SMACK64TRANSMUTE"
47 #define XATTR_SMACK_MMAP "SMACK64MMAP"
48 #define XATTR_NAME_SMACK XATTR_SECURITY_PREFIX XATTR_SMACK_SUFFIX
49 #define XATTR_NAME_SMACKIPIN    XATTR_SECURITY_PREFIX XATTR_SMACK_IPIN
50 #define XATTR_NAME_SMACKIPOUT   XATTR_SECURITY_PREFIX XATTR_SMACK_IPOUT
51 #define XATTR_NAME_SMACKEXEC    XATTR_SECURITY_PREFIX XATTR_SMACK_EXEC
52 #define XATTR_NAME_SMACKTRANSMUTE XATTR_SECURITY_PREFIX XATTR_SMACK_TRANSMUTE
53 #define XATTR_NAME_SMACKMMAP XATTR_SECURITY_PREFIX XATTR_SMACK_MMAP
54
55 #define XATTR_CAPS_SUFFIX "capability"
56 #define XATTR_NAME_CAPS XATTR_SECURITY_PREFIX XATTR_CAPS_SUFFIX
57
58 #define XATTR_POSIX_ACL_ACCESS  "posix_acl_access"
59 #define XATTR_NAME_POSIX_ACL_ACCESS XATTR_SYSTEM_PREFIX XATTR_POSIX_ACL_ACCESS
60 #define XATTR_POSIX_ACL_DEFAULT  "posix_acl_default"
61 #define XATTR_NAME_POSIX_ACL_DEFAULT XATTR_SYSTEM_PREFIX XATTR_POSIX_ACL_DEFAULT
62
63 #ifdef  __KERNEL__
64
65 #include <linux/types.h>
66
67 struct inode;
68 struct dentry;
69
70 struct xattr_handler {
71         const char *prefix;
72         int flags;      /* fs private flags passed back to the handlers */
73         size_t (*list)(struct dentry *dentry, char *list, size_t list_size,
74                        const char *name, size_t name_len, int handler_flags);
75         int (*get)(struct dentry *dentry, const char *name, void *buffer,
76                    size_t size, int handler_flags);
77         int (*set)(struct dentry *dentry, const char *name, const void *buffer,
78                    size_t size, int flags, int handler_flags);
79 };
80
81 struct xattr {
82         char *name;
83         void *value;
84         size_t value_len;
85 };
86
87 ssize_t xattr_getsecurity(struct inode *, const char *, void *, size_t);
88 ssize_t vfs_getxattr(struct dentry *, const char *, void *, size_t);
89 ssize_t vfs_listxattr(struct dentry *d, char *list, size_t size);
90 int __vfs_setxattr_noperm(struct dentry *, const char *, const void *, size_t, int);
91 int vfs_setxattr(struct dentry *, const char *, const void *, size_t, int);
92 int vfs_removexattr(struct dentry *, const char *);
93
94 ssize_t generic_getxattr(struct dentry *dentry, const char *name, void *buffer, size_t size);
95 ssize_t generic_listxattr(struct dentry *dentry, char *buffer, size_t buffer_size);
96 int generic_setxattr(struct dentry *dentry, const char *name, const void *value, size_t size, int flags);
97 int generic_removexattr(struct dentry *dentry, const char *name);
98 ssize_t vfs_getxattr_alloc(struct dentry *dentry, const char *name,
99                            char **xattr_value, size_t size, gfp_t flags);
100 int vfs_xattr_cmp(struct dentry *dentry, const char *xattr_name,
101                   const char *value, size_t size, gfp_t flags);
102 #endif  /*  __KERNEL__  */
103
104 #endif  /* _LINUX_XATTR_H */