blob: 4fa78736423e2e5a37a51b3ce1f4c0891f1b1136 [file] [log] [blame]
Chris Masondc17ff82008-01-08 15:46:30 -05001/*
2 * Copyright (C) 2007 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 __BTRFS_ORDERED_DATA__
20#define __BTRFS_ORDERED_DATA__
21
22struct btrfs_ordered_inode_tree {
23 rwlock_t lock;
24 struct rb_root tree;
25};
26
27static inline void
28btrfs_ordered_inode_tree_init(struct btrfs_ordered_inode_tree *t)
29{
30 rwlock_init(&t->lock);
31 t->tree.rb_node = NULL;
32}
33
34int btrfs_add_ordered_inode(struct inode *inode);
35int btrfs_find_del_first_ordered_inode(struct btrfs_ordered_inode_tree *tree,
Chris Mason4d5e74b2008-01-16 16:09:22 -050036 u64 *root_objectid, u64 *objectid,
37 struct inode **inode);
Chris Masondc17ff82008-01-08 15:46:30 -050038int btrfs_find_first_ordered_inode(struct btrfs_ordered_inode_tree *tree,
Chris Mason4d5e74b2008-01-16 16:09:22 -050039 u64 *root_objectid, u64 *objectid,
40 struct inode **inode);
Chris Mason594a24e2008-06-25 16:01:30 -040041void btrfs_del_ordered_inode(struct inode *inode, int force);
Chris Mason81d7ed22008-04-25 08:51:48 -040042int btrfs_ordered_throttle(struct btrfs_root *root, struct inode *inode);
Chris Masondc17ff82008-01-08 15:46:30 -050043#endif