]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - fs/btrfs/tree-log.h
UBUNTU: Ubuntu-4.13.0-45.50
[mirror_ubuntu-artful-kernel.git] / fs / btrfs / tree-log.h
CommitLineData
e02119d5
CM
1/*
2 * Copyright (C) 2008 Oracle. All rights reserved.
3 *
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public
6 * License v2 as published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public
14 * License along with this program; if not, write to the
15 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
16 * Boston, MA 021110-1307, USA.
17 */
18
19#ifndef __TREE_LOG_
20#define __TREE_LOG_
21
995946dd
MX
22#include "ctree.h"
23#include "transaction.h"
24
257c62e1
CM
25/* return value for btrfs_log_dentry_safe that means we don't need to log it at all */
26#define BTRFS_NO_LOG_SYNC 256
27
8b050d35
MX
28struct btrfs_log_ctx {
29 int log_ret;
d1433deb 30 int log_transid;
8407f553 31 int io_err;
2f2ff0ee 32 bool log_new_dentries;
28a23593 33 struct inode *inode;
8b050d35
MX
34 struct list_head list;
35};
36
28a23593
FM
37static inline void btrfs_init_log_ctx(struct btrfs_log_ctx *ctx,
38 struct inode *inode)
8b050d35
MX
39{
40 ctx->log_ret = 0;
d1433deb 41 ctx->log_transid = 0;
8407f553 42 ctx->io_err = 0;
2f2ff0ee 43 ctx->log_new_dentries = false;
28a23593 44 ctx->inode = inode;
8b050d35
MX
45 INIT_LIST_HEAD(&ctx->list);
46}
47
995946dd
MX
48static inline void btrfs_set_log_full_commit(struct btrfs_fs_info *fs_info,
49 struct btrfs_trans_handle *trans)
50{
20c7bcec 51 WRITE_ONCE(fs_info->last_trans_log_full_commit, trans->transid);
995946dd
MX
52}
53
54static inline int btrfs_need_log_full_commit(struct btrfs_fs_info *fs_info,
55 struct btrfs_trans_handle *trans)
56{
20c7bcec 57 return READ_ONCE(fs_info->last_trans_log_full_commit) ==
995946dd
MX
58 trans->transid;
59}
60
e02119d5 61int btrfs_sync_log(struct btrfs_trans_handle *trans,
8b050d35 62 struct btrfs_root *root, struct btrfs_log_ctx *ctx);
e02119d5 63int btrfs_free_log(struct btrfs_trans_handle *trans, struct btrfs_root *root);
4a500fd1
YZ
64int btrfs_free_log_root_tree(struct btrfs_trans_handle *trans,
65 struct btrfs_fs_info *fs_info);
e02119d5
CM
66int btrfs_recover_log_trees(struct btrfs_root *tree_root);
67int btrfs_log_dentry_safe(struct btrfs_trans_handle *trans,
8b050d35 68 struct btrfs_root *root, struct dentry *dentry,
49dae1bc
FM
69 const loff_t start,
70 const loff_t end,
8b050d35 71 struct btrfs_log_ctx *ctx);
e02119d5
CM
72int btrfs_del_dir_entries_in_log(struct btrfs_trans_handle *trans,
73 struct btrfs_root *root,
74 const char *name, int name_len,
49f34d1f 75 struct btrfs_inode *dir, u64 index);
e02119d5
CM
76int btrfs_del_inode_ref_in_log(struct btrfs_trans_handle *trans,
77 struct btrfs_root *root,
78 const char *name, int name_len,
a491abb2 79 struct btrfs_inode *inode, u64 dirid);
143bede5 80void btrfs_end_log_trans(struct btrfs_root *root);
12fcfd22 81int btrfs_pin_log_trans(struct btrfs_root *root);
12fcfd22 82void btrfs_record_unlink_dir(struct btrfs_trans_handle *trans,
4176bdbf 83 struct btrfs_inode *dir, struct btrfs_inode *inode,
12fcfd22 84 int for_rename);
1ec9a1ae 85void btrfs_record_snapshot_destroy(struct btrfs_trans_handle *trans,
43663557 86 struct btrfs_inode *dir);
12fcfd22 87int btrfs_log_new_name(struct btrfs_trans_handle *trans,
9ca5fbfb 88 struct btrfs_inode *inode, struct btrfs_inode *old_dir,
12fcfd22 89 struct dentry *parent);
e02119d5 90#endif