blob: 8197a94feec0f1164a237d04b88baa784876d7c6 [file] [log] [blame]
Thomas Gleixner1802d0b2019-05-27 08:55:21 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Masahiro Yamadafa60ce22021-05-06 18:06:44 -07002/*
Tao Ma8dec98e2009-08-18 11:19:58 +08003 * refcounttree.h
4 *
5 * Copyright (C) 2009 Oracle. All rights reserved.
Tao Ma8dec98e2009-08-18 11:19:58 +08006 */
7#ifndef OCFS2_REFCOUNTTREE_H
8#define OCFS2_REFCOUNTTREE_H
9
10struct ocfs2_refcount_tree {
11 struct rb_node rf_node;
12 u64 rf_blkno;
13 u32 rf_generation;
Goldwyn Rodrigues83fd9c72010-06-10 17:21:36 -050014 struct kref rf_getcnt;
Tao Ma8dec98e2009-08-18 11:19:58 +080015 struct rw_semaphore rf_sem;
16 struct ocfs2_lock_res rf_lockres;
Tao Ma8dec98e2009-08-18 11:19:58 +080017 int rf_removed;
18
19 /* the following 4 fields are used by caching_info. */
Tao Ma8dec98e2009-08-18 11:19:58 +080020 spinlock_t rf_lock;
Goldwyn Rodrigues83fd9c72010-06-10 17:21:36 -050021 struct ocfs2_caching_info rf_ci;
Tao Ma8dec98e2009-08-18 11:19:58 +080022 struct mutex rf_io_mutex;
23 struct super_block *rf_sb;
24};
25
Tao Ma374a2632009-08-24 11:13:37 +080026void ocfs2_purge_refcount_trees(struct ocfs2_super *osb);
27int ocfs2_lock_refcount_tree(struct ocfs2_super *osb, u64 ref_blkno, int rw,
28 struct ocfs2_refcount_tree **tree,
29 struct buffer_head **ref_bh);
30void ocfs2_unlock_refcount_tree(struct ocfs2_super *osb,
31 struct ocfs2_refcount_tree *tree,
32 int rw);
Tao Ma1823cb02009-08-18 11:24:49 +080033
34int ocfs2_decrease_refcount(struct inode *inode,
35 handle_t *handle, u32 cpos, u32 len,
36 struct ocfs2_alloc_context *meta_ac,
Tao Ma6ae23c52009-08-18 11:30:55 +080037 struct ocfs2_cached_dealloc_ctxt *dealloc,
38 int delete);
Tao Mabcbbb242009-08-18 11:29:12 +080039int ocfs2_prepare_refcount_change_for_del(struct inode *inode,
Tristan Ye78f94672010-05-11 17:54:42 +080040 u64 refcount_loc,
Tao Mabcbbb242009-08-18 11:29:12 +080041 u64 phys_blkno,
42 u32 clusters,
43 int *credits,
Tristan Ye78f94672010-05-11 17:54:42 +080044 int *ref_blocks);
Tao Ma15502712010-08-12 10:36:38 +080045int ocfs2_refcount_cow(struct inode *inode,
Tiger Yangc7dd3392013-08-13 16:00:58 -070046 struct buffer_head *di_bh,
Tao Ma37f8a2b2009-08-26 09:47:28 +080047 u32 cpos, u32 write_len, u32 max_cpos);
Tao Ma492a8a32009-08-18 11:43:17 +080048
49typedef int (ocfs2_post_refcount_func)(struct inode *inode,
50 handle_t *handle,
51 void *para);
52/*
53 * Some refcount caller need to do more work after we modify the data b-tree
54 * during refcount operation(including CoW and add refcount flag), and make the
55 * transaction complete. So it must give us this structure so that we can do it
56 * within our transaction.
57 *
58 */
59struct ocfs2_post_refcount {
60 int credits; /* credits it need for journal. */
61 ocfs2_post_refcount_func *func; /* real function. */
62 void *para;
63};
64
65int ocfs2_refcounted_xattr_delete_need(struct inode *inode,
66 struct ocfs2_caching_info *ref_ci,
67 struct buffer_head *ref_root_bh,
68 struct ocfs2_xattr_value_root *xv,
69 int *meta_add, int *credits);
70int ocfs2_refcount_cow_xattr(struct inode *inode,
71 struct ocfs2_dinode *di,
72 struct ocfs2_xattr_value_buf *vb,
73 struct ocfs2_refcount_tree *ref_tree,
74 struct buffer_head *ref_root_bh,
75 u32 cpos, u32 write_len,
76 struct ocfs2_post_refcount *post);
Tristan Ye3e19a252011-05-24 16:21:20 +080077int ocfs2_duplicate_clusters_by_page(handle_t *handle,
Tiger Yangc7dd3392013-08-13 16:00:58 -070078 struct inode *inode,
Tristan Ye3e19a252011-05-24 16:21:20 +080079 u32 cpos, u32 old_cluster,
80 u32 new_cluster, u32 new_len);
81int ocfs2_duplicate_clusters_by_jbd(handle_t *handle,
Tiger Yangc7dd3392013-08-13 16:00:58 -070082 struct inode *inode,
Tristan Ye3e19a252011-05-24 16:21:20 +080083 u32 cpos, u32 old_cluster,
84 u32 new_cluster, u32 new_len);
85int ocfs2_cow_sync_writeback(struct super_block *sb,
86 struct inode *inode,
87 u32 cpos, u32 num_clusters);
Tao Ma01292412009-09-21 13:04:19 +080088int ocfs2_add_refcount_flag(struct inode *inode,
89 struct ocfs2_extent_tree *data_et,
90 struct ocfs2_caching_info *ref_ci,
91 struct buffer_head *ref_root_bh,
92 u32 cpos, u32 p_cluster, u32 num_clusters,
93 struct ocfs2_cached_dealloc_ctxt *dealloc,
94 struct ocfs2_post_refcount *post);
Tao Ma8b2c0db2009-08-18 11:43:49 +080095int ocfs2_remove_refcount_tree(struct inode *inode, struct buffer_head *di_bh);
96int ocfs2_try_remove_refcount_tree(struct inode *inode,
97 struct buffer_head *di_bh);
Tao Ma2999d122009-08-18 11:43:55 +080098int ocfs2_increase_refcount(handle_t *handle,
99 struct ocfs2_caching_info *ci,
100 struct buffer_head *ref_root_bh,
101 u64 cpos, u32 len,
102 struct ocfs2_alloc_context *meta_ac,
103 struct ocfs2_cached_dealloc_ctxt *dealloc);
Tao Mabd508732009-09-21 11:25:14 +0800104int ocfs2_reflink_ioctl(struct inode *inode,
105 const char __user *oldname,
106 const char __user *newname,
107 bool preserve);
Darrick J. Wong65f098e2018-10-30 10:45:48 +1100108loff_t ocfs2_reflink_remap_blocks(struct inode *s_inode,
109 struct buffer_head *s_bh,
110 loff_t pos_in,
111 struct inode *t_inode,
112 struct buffer_head *t_bh,
113 loff_t pos_out,
114 loff_t len);
115int ocfs2_reflink_inodes_lock(struct inode *s_inode,
116 struct buffer_head **bh1,
117 struct inode *t_inode,
118 struct buffer_head **bh2);
119void ocfs2_reflink_inodes_unlock(struct inode *s_inode,
120 struct buffer_head *s_bh,
121 struct inode *t_inode,
122 struct buffer_head *t_bh);
123int ocfs2_reflink_update_dest(struct inode *dest,
124 struct buffer_head *d_bh,
125 loff_t newlen);
Darrick J. Wong29ac8e82016-11-09 14:13:11 -0800126
Tao Ma8dec98e2009-08-18 11:19:58 +0800127#endif /* OCFS2_REFCOUNTTREE_H */