blob: 2ace7a60316d9905ae0a8fb419f68e5e1c177144 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
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
akpm@osdl.orge0ad7b02006-01-09 20:51:56 -080016/* Namespaces */
17#define XATTR_OS2_PREFIX "os2."
18#define XATTR_OS2_PREFIX_LEN (sizeof (XATTR_OS2_PREFIX) - 1)
19
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#define XATTR_SECURITY_PREFIX "security."
akpm@osdl.orge0ad7b02006-01-09 20:51:56 -080021#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
Mimi Zoharaf4f1362010-07-01 15:07:43 -040032/* Security namespace */
Mimi Zohar66dbc3252011-03-15 16:12:09 -040033#define XATTR_EVM_SUFFIX "evm"
34#define XATTR_NAME_EVM XATTR_SECURITY_PREFIX XATTR_EVM_SUFFIX
35
Mimi Zoharaf4f1362010-07-01 15:07:43 -040036#define XATTR_SELINUX_SUFFIX "selinux"
37#define XATTR_NAME_SELINUX XATTR_SECURITY_PREFIX XATTR_SELINUX_SUFFIX
38
39#define XATTR_SMACK_SUFFIX "SMACK64"
40#define XATTR_SMACK_IPIN "SMACK64IPIN"
41#define XATTR_SMACK_IPOUT "SMACK64IPOUT"
Casey Schaufler676dac42010-12-02 06:43:39 -080042#define XATTR_SMACK_EXEC "SMACK64EXEC"
Jarkko Sakkinen5c6d1122010-12-07 13:34:01 +020043#define XATTR_SMACK_TRANSMUTE "SMACK64TRANSMUTE"
Casey Schaufler7898e1f2011-01-17 08:05:27 -080044#define XATTR_SMACK_MMAP "SMACK64MMAP"
Mimi Zoharaf4f1362010-07-01 15:07:43 -040045#define XATTR_NAME_SMACK XATTR_SECURITY_PREFIX XATTR_SMACK_SUFFIX
46#define XATTR_NAME_SMACKIPIN XATTR_SECURITY_PREFIX XATTR_SMACK_IPIN
47#define XATTR_NAME_SMACKIPOUT XATTR_SECURITY_PREFIX XATTR_SMACK_IPOUT
Casey Schaufler676dac42010-12-02 06:43:39 -080048#define XATTR_NAME_SMACKEXEC XATTR_SECURITY_PREFIX XATTR_SMACK_EXEC
Jarkko Sakkinen5c6d1122010-12-07 13:34:01 +020049#define XATTR_NAME_SMACKTRANSMUTE XATTR_SECURITY_PREFIX XATTR_SMACK_TRANSMUTE
Casey Schaufler7898e1f2011-01-17 08:05:27 -080050#define XATTR_NAME_SMACKMMAP XATTR_SECURITY_PREFIX XATTR_SMACK_MMAP
Mimi Zoharaf4f1362010-07-01 15:07:43 -040051
52#define XATTR_CAPS_SUFFIX "capability"
53#define XATTR_NAME_CAPS XATTR_SECURITY_PREFIX XATTR_CAPS_SUFFIX
54
Mimi Zoharbf6d0f52011-08-18 18:07:44 -040055#define XATTR_POSIX_ACL_ACCESS "posix_acl_access"
56#define XATTR_NAME_POSIX_ACL_ACCESS XATTR_SYSTEM_PREFIX XATTR_POSIX_ACL_ACCESS
57#define XATTR_POSIX_ACL_DEFAULT "posix_acl_default"
58#define XATTR_NAME_POSIX_ACL_DEFAULT XATTR_SYSTEM_PREFIX XATTR_POSIX_ACL_DEFAULT
59
Eric Paris1dbe3942011-05-24 17:13:13 -070060#ifdef __KERNEL__
61
Aristeu Rozanski38f38652012-08-23 16:53:28 -040062#include <linux/slab.h>
Eric Paris1dbe3942011-05-24 17:13:13 -070063#include <linux/types.h>
Aristeu Rozanski38f38652012-08-23 16:53:28 -040064#include <linux/spinlock.h>
Eric Paris1dbe3942011-05-24 17:13:13 -070065
Adrian Bunk5b0a2072007-02-10 01:46:24 -080066struct inode;
67struct dentry;
Linus Torvalds1da177e2005-04-16 15:20:36 -070068
69struct xattr_handler {
Stephen Hemmingerbb435452010-05-13 17:53:14 -070070 const char *prefix;
Christoph Hellwig431547b2009-11-13 09:52:56 +000071 int flags; /* fs private flags passed back to the handlers */
72 size_t (*list)(struct dentry *dentry, char *list, size_t list_size,
73 const char *name, size_t name_len, int handler_flags);
74 int (*get)(struct dentry *dentry, const char *name, void *buffer,
75 size_t size, int handler_flags);
76 int (*set)(struct dentry *dentry, const char *name, const void *buffer,
77 size_t size, int flags, int handler_flags);
Linus Torvalds1da177e2005-04-16 15:20:36 -070078};
79
Mimi Zohar9d8f13b2011-06-06 15:29:25 -040080struct xattr {
81 char *name;
82 void *value;
83 size_t value_len;
84};
85
David P. Quigley42492592008-02-04 22:29:39 -080086ssize_t xattr_getsecurity(struct inode *, const char *, void *, size_t);
David Howells8f0cfa52008-04-29 00:59:41 -070087ssize_t vfs_getxattr(struct dentry *, const char *, void *, size_t);
Bill Nottingham659564c2006-10-09 16:10:48 -040088ssize_t vfs_listxattr(struct dentry *d, char *list, size_t size);
David P. Quigleyb1ab7e42009-09-03 14:25:56 -040089int __vfs_setxattr_noperm(struct dentry *, const char *, const void *, size_t, int);
David Howells8f0cfa52008-04-29 00:59:41 -070090int vfs_setxattr(struct dentry *, const char *, const void *, size_t, int);
91int vfs_removexattr(struct dentry *, const char *);
Christoph Hellwig5be196e2006-01-09 20:51:55 -080092
Linus Torvalds1da177e2005-04-16 15:20:36 -070093ssize_t generic_getxattr(struct dentry *dentry, const char *name, void *buffer, size_t size);
94ssize_t generic_listxattr(struct dentry *dentry, char *buffer, size_t buffer_size);
95int generic_setxattr(struct dentry *dentry, const char *name, const void *value, size_t size, int flags);
96int generic_removexattr(struct dentry *dentry, const char *name);
Mimi Zohar1601fba2011-03-09 14:23:34 -050097ssize_t vfs_getxattr_alloc(struct dentry *dentry, const char *name,
98 char **xattr_value, size_t size, gfp_t flags);
99int vfs_xattr_cmp(struct dentry *dentry, const char *xattr_name,
100 const char *value, size_t size, gfp_t flags);
Aristeu Rozanski38f38652012-08-23 16:53:28 -0400101
102struct simple_xattrs {
103 struct list_head head;
104 spinlock_t lock;
105};
106
107struct simple_xattr {
108 struct list_head list;
109 char *name;
110 size_t size;
111 char value[0];
112};
113
114/*
115 * initialize the simple_xattrs structure
116 */
117static inline void simple_xattrs_init(struct simple_xattrs *xattrs)
118{
119 INIT_LIST_HEAD(&xattrs->head);
120 spin_lock_init(&xattrs->lock);
121}
122
123/*
124 * free all the xattrs
125 */
126static inline void simple_xattrs_free(struct simple_xattrs *xattrs)
127{
128 struct simple_xattr *xattr, *node;
129
130 list_for_each_entry_safe(xattr, node, &xattrs->head, list) {
131 kfree(xattr->name);
132 kfree(xattr);
133 }
134}
135
136struct simple_xattr *simple_xattr_alloc(const void *value, size_t size);
137int simple_xattr_get(struct simple_xattrs *xattrs, const char *name,
138 void *buffer, size_t size);
139int simple_xattr_set(struct simple_xattrs *xattrs, const char *name,
140 const void *value, size_t size, int flags);
141int simple_xattr_remove(struct simple_xattrs *xattrs, const char *name);
142ssize_t simple_xattr_list(struct simple_xattrs *xattrs, char *buffer,
143 size_t size);
144void simple_xattr_list_add(struct simple_xattrs *xattrs,
145 struct simple_xattr *new_xattr);
146
Adrian Bunk5b0a2072007-02-10 01:46:24 -0800147#endif /* __KERNEL__ */
148
Linus Torvalds1da177e2005-04-16 15:20:36 -0700149#endif /* _LINUX_XATTR_H */