123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- /*
- File: linux/xattr.h
- Extended attributes handling.
- Copyright (C) 2001 by Andreas Gruenbacher <a.gruenbacher@computer.org>
- Copyright (c) 2001-2002 Silicon Graphics, Inc. All Rights Reserved.
- Copyright (c) 2004 Red Hat, Inc., James Morris <jmorris@redhat.com>
- */
- #ifndef _LINUX_XATTR_H
- #define _LINUX_XATTR_H
- #define XATTR_CREATE 0x1 /* set value, fail if attr already exists */
- #define XATTR_REPLACE 0x2 /* set value, fail if attr does not exist */
- /* Namespaces */
- #define XATTR_OS2_PREFIX "os2."
- #define XATTR_OS2_PREFIX_LEN (sizeof (XATTR_OS2_PREFIX) - 1)
- #define XATTR_SECURITY_PREFIX "security."
- #define XATTR_SECURITY_PREFIX_LEN (sizeof (XATTR_SECURITY_PREFIX) - 1)
- #define XATTR_SYSTEM_PREFIX "system."
- #define XATTR_SYSTEM_PREFIX_LEN (sizeof (XATTR_SYSTEM_PREFIX) - 1)
- #define XATTR_TRUSTED_PREFIX "trusted."
- #define XATTR_TRUSTED_PREFIX_LEN (sizeof (XATTR_TRUSTED_PREFIX) - 1)
- #define XATTR_USER_PREFIX "user."
- #define XATTR_USER_PREFIX_LEN (sizeof (XATTR_USER_PREFIX) - 1)
- /* Security namespace */
- #define XATTR_EVM_SUFFIX "evm"
- #define XATTR_NAME_EVM XATTR_SECURITY_PREFIX XATTR_EVM_SUFFIX
- #define XATTR_IMA_SUFFIX "ima"
- #define XATTR_NAME_IMA XATTR_SECURITY_PREFIX XATTR_IMA_SUFFIX
- #define XATTR_SELINUX_SUFFIX "selinux"
- #define XATTR_NAME_SELINUX XATTR_SECURITY_PREFIX XATTR_SELINUX_SUFFIX
- #define XATTR_SMACK_SUFFIX "SMACK64"
- #define XATTR_SMACK_IPIN "SMACK64IPIN"
- #define XATTR_SMACK_IPOUT "SMACK64IPOUT"
- #define XATTR_SMACK_EXEC "SMACK64EXEC"
- #define XATTR_SMACK_TRANSMUTE "SMACK64TRANSMUTE"
- #define XATTR_SMACK_MMAP "SMACK64MMAP"
- #define XATTR_NAME_SMACK XATTR_SECURITY_PREFIX XATTR_SMACK_SUFFIX
- #define XATTR_NAME_SMACKIPIN XATTR_SECURITY_PREFIX XATTR_SMACK_IPIN
- #define XATTR_NAME_SMACKIPOUT XATTR_SECURITY_PREFIX XATTR_SMACK_IPOUT
- #define XATTR_NAME_SMACKEXEC XATTR_SECURITY_PREFIX XATTR_SMACK_EXEC
- #define XATTR_NAME_SMACKTRANSMUTE XATTR_SECURITY_PREFIX XATTR_SMACK_TRANSMUTE
- #define XATTR_NAME_SMACKMMAP XATTR_SECURITY_PREFIX XATTR_SMACK_MMAP
- #define XATTR_CAPS_SUFFIX "capability"
- #define XATTR_NAME_CAPS XATTR_SECURITY_PREFIX XATTR_CAPS_SUFFIX
- #define XATTR_POSIX_ACL_ACCESS "posix_acl_access"
- #define XATTR_NAME_POSIX_ACL_ACCESS XATTR_SYSTEM_PREFIX XATTR_POSIX_ACL_ACCESS
- #define XATTR_POSIX_ACL_DEFAULT "posix_acl_default"
- #define XATTR_NAME_POSIX_ACL_DEFAULT XATTR_SYSTEM_PREFIX XATTR_POSIX_ACL_DEFAULT
- #ifdef __KERNEL__
- #include <linux/slab.h>
- #include <linux/types.h>
- #include <linux/spinlock.h>
- struct inode;
- struct dentry;
- struct xattr_handler {
- const char *prefix;
- int flags; /* fs private flags passed back to the handlers */
- size_t (*list)(struct dentry *dentry, char *list, size_t list_size,
- const char *name, size_t name_len, int handler_flags);
- int (*get)(struct dentry *dentry, const char *name, void *buffer,
- size_t size, int handler_flags);
- int (*set)(struct dentry *dentry, const char *name, const void *buffer,
- size_t size, int flags, int handler_flags);
- };
- struct xattr {
- char *name;
- void *value;
- size_t value_len;
- };
- ssize_t xattr_getsecurity(struct inode *, const char *, void *, size_t);
- ssize_t vfs_getxattr(struct dentry *, const char *, void *, size_t);
- ssize_t vfs_listxattr(struct dentry *d, char *list, size_t size);
- int __vfs_setxattr_noperm(struct dentry *, const char *, const void *, size_t, int);
- int vfs_setxattr(struct dentry *, const char *, const void *, size_t, int);
- int vfs_removexattr(struct dentry *, const char *);
- ssize_t generic_getxattr(struct dentry *dentry, const char *name, void *buffer, size_t size);
- ssize_t generic_listxattr(struct dentry *dentry, char *buffer, size_t buffer_size);
- int generic_setxattr(struct dentry *dentry, const char *name, const void *value, size_t size, int flags);
- int generic_removexattr(struct dentry *dentry, const char *name);
- ssize_t vfs_getxattr_alloc(struct dentry *dentry, const char *name,
- char **xattr_value, size_t size, gfp_t flags);
- int vfs_xattr_cmp(struct dentry *dentry, const char *xattr_name,
- const char *value, size_t size, gfp_t flags);
- struct simple_xattrs {
- struct list_head head;
- spinlock_t lock;
- };
- struct simple_xattr {
- struct list_head list;
- char *name;
- size_t size;
- char value[0];
- };
- /*
- * initialize the simple_xattrs structure
- */
- static inline void simple_xattrs_init(struct simple_xattrs *xattrs)
- {
- INIT_LIST_HEAD(&xattrs->head);
- spin_lock_init(&xattrs->lock);
- }
- /*
- * free all the xattrs
- */
- static inline void simple_xattrs_free(struct simple_xattrs *xattrs)
- {
- struct simple_xattr *xattr, *node;
- list_for_each_entry_safe(xattr, node, &xattrs->head, list) {
- kfree(xattr->name);
- kfree(xattr);
- }
- }
- struct simple_xattr *simple_xattr_alloc(const void *value, size_t size);
- int simple_xattr_get(struct simple_xattrs *xattrs, const char *name,
- void *buffer, size_t size);
- int simple_xattr_set(struct simple_xattrs *xattrs, const char *name,
- const void *value, size_t size, int flags);
- int simple_xattr_remove(struct simple_xattrs *xattrs, const char *name);
- ssize_t simple_xattr_list(struct simple_xattrs *xattrs, char *buffer,
- size_t size);
- void simple_xattr_list_add(struct simple_xattrs *xattrs,
- struct simple_xattr *new_xattr);
- #endif /* __KERNEL__ */
- #endif /* _LINUX_XATTR_H */
|