xattr.h 5.1 KB

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