Thomas Gleixner | 1802d0b | 2019-05-27 08:55:21 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Masahiro Yamada | fa60ce2 | 2021-05-06 18:06:44 -0700 | [diff] [blame] | 2 | /* |
Tiger Yang | cf1d6c7 | 2008-08-18 17:11:00 +0800 | [diff] [blame] | 3 | * xattr.h |
| 4 | * |
Tiger Yang | c3cb682 | 2008-10-23 16:33:03 +0800 | [diff] [blame] | 5 | * Copyright (C) 2004, 2008 Oracle. All rights reserved. |
Tiger Yang | cf1d6c7 | 2008-08-18 17:11:00 +0800 | [diff] [blame] | 6 | */ |
| 7 | |
| 8 | #ifndef OCFS2_XATTR_H |
| 9 | #define OCFS2_XATTR_H |
| 10 | |
| 11 | #include <linux/init.h> |
| 12 | #include <linux/xattr.h> |
| 13 | |
| 14 | enum ocfs2_xattr_type { |
| 15 | OCFS2_XATTR_INDEX_USER = 1, |
| 16 | OCFS2_XATTR_INDEX_POSIX_ACL_ACCESS, |
| 17 | OCFS2_XATTR_INDEX_POSIX_ACL_DEFAULT, |
| 18 | OCFS2_XATTR_INDEX_TRUSTED, |
| 19 | OCFS2_XATTR_INDEX_SECURITY, |
| 20 | OCFS2_XATTR_MAX |
| 21 | }; |
| 22 | |
Tiger Yang | 534eadd | 2008-11-14 11:16:41 +0800 | [diff] [blame] | 23 | struct ocfs2_security_xattr_info { |
| 24 | int enable; |
Tetsuo Handa | 9548906 | 2013-07-25 05:44:02 +0900 | [diff] [blame] | 25 | const char *name; |
Tiger Yang | 534eadd | 2008-11-14 11:16:41 +0800 | [diff] [blame] | 26 | void *value; |
| 27 | size_t value_len; |
| 28 | }; |
| 29 | |
Stephen Hemminger | 537d81c | 2010-05-13 17:53:22 -0700 | [diff] [blame] | 30 | extern const struct xattr_handler ocfs2_xattr_user_handler; |
| 31 | extern const struct xattr_handler ocfs2_xattr_trusted_handler; |
| 32 | extern const struct xattr_handler ocfs2_xattr_security_handler; |
Stephen Hemminger | 537d81c | 2010-05-13 17:53:22 -0700 | [diff] [blame] | 33 | extern const struct xattr_handler *ocfs2_xattr_handlers[]; |
Tiger Yang | cf1d6c7 | 2008-08-18 17:11:00 +0800 | [diff] [blame] | 34 | |
Tiger Yang | 0030e00 | 2008-10-23 16:33:33 +0800 | [diff] [blame] | 35 | ssize_t ocfs2_listxattr(struct dentry *, char *, size_t); |
Tiger Yang | 4e3e9d0 | 2008-11-14 11:16:53 +0800 | [diff] [blame] | 36 | int ocfs2_xattr_get_nolock(struct inode *, struct buffer_head *, int, |
| 37 | const char *, void *, size_t); |
Tiger Yang | 0030e00 | 2008-10-23 16:33:33 +0800 | [diff] [blame] | 38 | int ocfs2_xattr_set(struct inode *, int, const char *, const void *, |
| 39 | size_t, int); |
Tiger Yang | 6c3faba | 2008-11-14 11:16:03 +0800 | [diff] [blame] | 40 | int ocfs2_xattr_set_handle(handle_t *, struct inode *, struct buffer_head *, |
| 41 | int, const char *, const void *, size_t, int, |
| 42 | struct ocfs2_alloc_context *, |
| 43 | struct ocfs2_alloc_context *); |
Tao Ma | 8b2c0db | 2009-08-18 11:43:49 +0800 | [diff] [blame] | 44 | int ocfs2_has_inline_xattr_value_outside(struct inode *inode, |
| 45 | struct ocfs2_dinode *di); |
Tiger Yang | 0030e00 | 2008-10-23 16:33:33 +0800 | [diff] [blame] | 46 | int ocfs2_xattr_remove(struct inode *, struct buffer_head *); |
Tiger Yang | 534eadd | 2008-11-14 11:16:41 +0800 | [diff] [blame] | 47 | int ocfs2_init_security_get(struct inode *, struct inode *, |
Eric Paris | 2a7dba3 | 2011-02-01 11:05:39 -0500 | [diff] [blame] | 48 | const struct qstr *, |
Tiger Yang | 534eadd | 2008-11-14 11:16:41 +0800 | [diff] [blame] | 49 | struct ocfs2_security_xattr_info *); |
| 50 | int ocfs2_init_security_set(handle_t *, struct inode *, |
| 51 | struct buffer_head *, |
| 52 | struct ocfs2_security_xattr_info *, |
| 53 | struct ocfs2_alloc_context *, |
| 54 | struct ocfs2_alloc_context *); |
| 55 | int ocfs2_calc_security_init(struct inode *, |
| 56 | struct ocfs2_security_xattr_info *, |
| 57 | int *, int *, struct ocfs2_alloc_context **); |
Tiger Yang | 89c38bd | 2008-11-14 11:17:41 +0800 | [diff] [blame] | 58 | int ocfs2_calc_xattr_init(struct inode *, struct buffer_head *, |
Al Viro | 67697cb | 2011-07-26 02:55:32 -0400 | [diff] [blame] | 59 | umode_t, struct ocfs2_security_xattr_info *, |
Mark Fasheh | 9b7895e | 2008-11-12 16:27:44 -0800 | [diff] [blame] | 60 | int *, int *, int *); |
Tao Ma | 0c044f0 | 2008-08-18 17:38:50 +0800 | [diff] [blame] | 61 | |
Joel Becker | 2a50a74 | 2008-12-09 14:24:33 -0800 | [diff] [blame] | 62 | /* |
| 63 | * xattrs can live inside an inode, as part of an external xattr block, |
| 64 | * or inside an xattr bucket, which is the leaf of a tree rooted in an |
| 65 | * xattr block. Some of the xattr calls, especially the value setting |
| 66 | * functions, want to treat each of these locations as equal. Let's wrap |
| 67 | * them in a structure that we can pass around instead of raw buffer_heads. |
| 68 | */ |
| 69 | struct ocfs2_xattr_value_buf { |
| 70 | struct buffer_head *vb_bh; |
| 71 | ocfs2_journal_access_func vb_access; |
| 72 | struct ocfs2_xattr_value_root *vb_xv; |
| 73 | }; |
| 74 | |
Tao Ma | 0129241 | 2009-09-21 13:04:19 +0800 | [diff] [blame] | 75 | int ocfs2_xattr_attach_refcount_tree(struct inode *inode, |
| 76 | struct buffer_head *fe_bh, |
| 77 | struct ocfs2_caching_info *ref_ci, |
| 78 | struct buffer_head *ref_root_bh, |
| 79 | struct ocfs2_cached_dealloc_ctxt *dealloc); |
Tao Ma | 2999d12 | 2009-08-18 11:43:55 +0800 | [diff] [blame] | 80 | int ocfs2_reflink_xattrs(struct inode *old_inode, |
| 81 | struct buffer_head *old_bh, |
| 82 | struct inode *new_inode, |
Tao Ma | 0fe9b66 | 2009-08-18 11:47:56 +0800 | [diff] [blame] | 83 | struct buffer_head *new_bh, |
| 84 | bool preserve_security); |
| 85 | int ocfs2_init_security_and_acl(struct inode *dir, |
Eric Paris | 2a7dba3 | 2011-02-01 11:05:39 -0500 | [diff] [blame] | 86 | struct inode *inode, |
Junxiao Bi | c25a1e0 | 2016-05-12 15:42:18 -0700 | [diff] [blame] | 87 | const struct qstr *qstr); |
Tiger Yang | cf1d6c7 | 2008-08-18 17:11:00 +0800 | [diff] [blame] | 88 | #endif /* OCFS2_XATTR_H */ |