blob: 77a3e686d56627cba522616bd9425ae551b0ce35 [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 Zohar2fe5d6d2012-02-13 10:15:05 -050036#define XATTR_IMA_SUFFIX "ima"
37#define XATTR_NAME_IMA XATTR_SECURITY_PREFIX XATTR_IMA_SUFFIX
38
Mimi Zoharaf4f1362010-07-01 15:07:43 -040039#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"
Casey Schaufler676dac42010-12-02 06:43:39 -080045#define XATTR_SMACK_EXEC "SMACK64EXEC"
Jarkko Sakkinen5c6d1122010-12-07 13:34:01 +020046#define XATTR_SMACK_TRANSMUTE "SMACK64TRANSMUTE"
Casey Schaufler7898e1f2011-01-17 08:05:27 -080047#define XATTR_SMACK_MMAP "SMACK64MMAP"
Mimi Zoharaf4f1362010-07-01 15:07:43 -040048#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
Casey Schaufler676dac42010-12-02 06:43:39 -080051#define XATTR_NAME_SMACKEXEC XATTR_SECURITY_PREFIX XATTR_SMACK_EXEC
Jarkko Sakkinen5c6d1122010-12-07 13:34:01 +020052#define XATTR_NAME_SMACKTRANSMUTE XATTR_SECURITY_PREFIX XATTR_SMACK_TRANSMUTE
Casey Schaufler7898e1f2011-01-17 08:05:27 -080053#define XATTR_NAME_SMACKMMAP XATTR_SECURITY_PREFIX XATTR_SMACK_MMAP
Mimi Zoharaf4f1362010-07-01 15:07:43 -040054
55#define XATTR_CAPS_SUFFIX "capability"
56#define XATTR_NAME_CAPS XATTR_SECURITY_PREFIX XATTR_CAPS_SUFFIX
57
Mimi Zoharbf6d0f52011-08-18 18:07:44 -040058#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
Eric Paris1dbe3942011-05-24 17:13:13 -070063#ifdef __KERNEL__
64
65#include <linux/types.h>
66
Adrian Bunk5b0a2072007-02-10 01:46:24 -080067struct inode;
68struct dentry;
Linus Torvalds1da177e2005-04-16 15:20:36 -070069
70struct xattr_handler {
Stephen Hemmingerbb435452010-05-13 17:53:14 -070071 const char *prefix;
Christoph Hellwig431547b2009-11-13 09:52:56 +000072 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);
Linus Torvalds1da177e2005-04-16 15:20:36 -070079};
80
Mimi Zohar9d8f13b2011-06-06 15:29:25 -040081struct xattr {
82 char *name;
83 void *value;
84 size_t value_len;
85};
86
David P. Quigley42492592008-02-04 22:29:39 -080087ssize_t xattr_getsecurity(struct inode *, const char *, void *, size_t);
David Howells8f0cfa52008-04-29 00:59:41 -070088ssize_t vfs_getxattr(struct dentry *, const char *, void *, size_t);
Bill Nottingham659564c2006-10-09 16:10:48 -040089ssize_t vfs_listxattr(struct dentry *d, char *list, size_t size);
David P. Quigleyb1ab7e42009-09-03 14:25:56 -040090int __vfs_setxattr_noperm(struct dentry *, const char *, const void *, size_t, int);
David Howells8f0cfa52008-04-29 00:59:41 -070091int vfs_setxattr(struct dentry *, const char *, const void *, size_t, int);
92int vfs_removexattr(struct dentry *, const char *);
Christoph Hellwig5be196e2006-01-09 20:51:55 -080093
Linus Torvalds1da177e2005-04-16 15:20:36 -070094ssize_t generic_getxattr(struct dentry *dentry, const char *name, void *buffer, size_t size);
95ssize_t generic_listxattr(struct dentry *dentry, char *buffer, size_t buffer_size);
96int generic_setxattr(struct dentry *dentry, const char *name, const void *value, size_t size, int flags);
97int generic_removexattr(struct dentry *dentry, const char *name);
Mimi Zohar1601fba2011-03-09 14:23:34 -050098ssize_t vfs_getxattr_alloc(struct dentry *dentry, const char *name,
99 char **xattr_value, size_t size, gfp_t flags);
100int vfs_xattr_cmp(struct dentry *dentry, const char *xattr_name,
101 const char *value, size_t size, gfp_t flags);
Adrian Bunk5b0a2072007-02-10 01:46:24 -0800102#endif /* __KERNEL__ */
103
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104#endif /* _LINUX_XATTR_H */