blob: 483027f9a7f4f8dbc469c54c04ab47b4a9b4a116 [file] [log] [blame]
Chris Masone02119d2008-09-05 16:13:11 -04001/*
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
Miao Xie995946d2014-04-02 19:51:06 +080022#include "ctree.h"
23#include "transaction.h"
24
Chris Mason257c62e2009-10-13 13:21:08 -040025/* 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
Miao Xie8b050d32014-02-20 18:08:58 +080028struct btrfs_log_ctx {
29 int log_ret;
Miao Xied1433de2014-02-20 18:08:59 +080030 int log_transid;
Filipe Manana8407f552014-09-05 15:14:39 +010031 int io_err;
Filipe Manana2f2ff0e2015-03-20 17:19:46 +000032 bool log_new_dentries;
Filipe Manana28a23592016-08-23 21:13:51 +010033 struct inode *inode;
Miao Xie8b050d32014-02-20 18:08:58 +080034 struct list_head list;
35};
36
Filipe Manana28a23592016-08-23 21:13:51 +010037static inline void btrfs_init_log_ctx(struct btrfs_log_ctx *ctx,
38 struct inode *inode)
Miao Xie8b050d32014-02-20 18:08:58 +080039{
40 ctx->log_ret = 0;
Miao Xied1433de2014-02-20 18:08:59 +080041 ctx->log_transid = 0;
Filipe Manana8407f552014-09-05 15:14:39 +010042 ctx->io_err = 0;
Filipe Manana2f2ff0e2015-03-20 17:19:46 +000043 ctx->log_new_dentries = false;
Filipe Manana28a23592016-08-23 21:13:51 +010044 ctx->inode = inode;
Miao Xie8b050d32014-02-20 18:08:58 +080045 INIT_LIST_HEAD(&ctx->list);
46}
47
Miao Xie995946d2014-04-02 19:51:06 +080048static inline void btrfs_set_log_full_commit(struct btrfs_fs_info *fs_info,
49 struct btrfs_trans_handle *trans)
50{
Seraphime Kirkovski20c7bce2016-12-15 14:38:16 +010051 WRITE_ONCE(fs_info->last_trans_log_full_commit, trans->transid);
Miao Xie995946d2014-04-02 19:51:06 +080052}
53
54static inline int btrfs_need_log_full_commit(struct btrfs_fs_info *fs_info,
55 struct btrfs_trans_handle *trans)
56{
Seraphime Kirkovski20c7bce2016-12-15 14:38:16 +010057 return READ_ONCE(fs_info->last_trans_log_full_commit) ==
Miao Xie995946d2014-04-02 19:51:06 +080058 trans->transid;
59}
60
Chris Masone02119d2008-09-05 16:13:11 -040061int btrfs_sync_log(struct btrfs_trans_handle *trans,
Miao Xie8b050d32014-02-20 18:08:58 +080062 struct btrfs_root *root, struct btrfs_log_ctx *ctx);
Chris Masone02119d2008-09-05 16:13:11 -040063int btrfs_free_log(struct btrfs_trans_handle *trans, struct btrfs_root *root);
Yan, Zheng4a500fd2010-05-16 10:49:59 -040064int btrfs_free_log_root_tree(struct btrfs_trans_handle *trans,
65 struct btrfs_fs_info *fs_info);
Chris Masone02119d2008-09-05 16:13:11 -040066int btrfs_recover_log_trees(struct btrfs_root *tree_root);
67int btrfs_log_dentry_safe(struct btrfs_trans_handle *trans,
Miao Xie8b050d32014-02-20 18:08:58 +080068 struct btrfs_root *root, struct dentry *dentry,
Filipe Manana49dae1b2014-09-06 22:34:39 +010069 const loff_t start,
70 const loff_t end,
Miao Xie8b050d32014-02-20 18:08:58 +080071 struct btrfs_log_ctx *ctx);
Chris Masone02119d2008-09-05 16:13:11 -040072int btrfs_del_dir_entries_in_log(struct btrfs_trans_handle *trans,
73 struct btrfs_root *root,
74 const char *name, int name_len,
Nikolay Borisov49f34d12017-01-18 00:31:32 +020075 struct btrfs_inode *dir, u64 index);
Chris Masone02119d2008-09-05 16:13:11 -040076int btrfs_del_inode_ref_in_log(struct btrfs_trans_handle *trans,
77 struct btrfs_root *root,
78 const char *name, int name_len,
Nikolay Borisova491abb2017-01-18 00:31:33 +020079 struct btrfs_inode *inode, u64 dirid);
Jeff Mahoney143bede2012-03-01 14:56:26 +010080void btrfs_end_log_trans(struct btrfs_root *root);
Chris Mason12fcfd22009-03-24 10:24:20 -040081int btrfs_pin_log_trans(struct btrfs_root *root);
Chris Mason12fcfd22009-03-24 10:24:20 -040082void btrfs_record_unlink_dir(struct btrfs_trans_handle *trans,
Nikolay Borisov4176bdb2017-01-18 00:31:28 +020083 struct btrfs_inode *dir, struct btrfs_inode *inode,
Chris Mason12fcfd22009-03-24 10:24:20 -040084 int for_rename);
Filipe Manana1ec9a1a2016-02-10 10:42:25 +000085void btrfs_record_snapshot_destroy(struct btrfs_trans_handle *trans,
Nikolay Borisov43663552017-01-18 00:31:29 +020086 struct btrfs_inode *dir);
Chris Mason12fcfd22009-03-24 10:24:20 -040087int btrfs_log_new_name(struct btrfs_trans_handle *trans,
Nikolay Borisov9ca5fbfb2017-01-18 00:31:31 +020088 struct btrfs_inode *inode, struct btrfs_inode *old_dir,
Chris Mason12fcfd22009-03-24 10:24:20 -040089 struct dentry *parent);
Chris Masone02119d2008-09-05 16:13:11 -040090#endif