]> bbs.cooldavid.org Git - net-next-2.6.git/blame - fs/btrfs/disk-io.h
Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
[net-next-2.6.git] / fs / btrfs / disk-io.h
CommitLineData
6cbd5570
CM
1/*
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
eb60ceac
CM
19#ifndef __DISKIO__
20#define __DISKIO__
21
a512bbf8 22#define BTRFS_SUPER_INFO_OFFSET (64 * 1024)
f2984462 23#define BTRFS_SUPER_INFO_SIZE 4096
a512bbf8
YZ
24
25#define BTRFS_SUPER_MIRROR_MAX 3
26#define BTRFS_SUPER_MIRROR_SHIFT 12
27
28static inline u64 btrfs_sb_offset(int mirror)
29{
30 u64 start = 16 * 1024;
31 if (mirror)
32 return start << (BTRFS_SUPER_MIRROR_SHIFT * mirror);
33 return BTRFS_SUPER_INFO_OFFSET;
34}
35
0b86a832 36struct btrfs_device;
8a4b83cc 37struct btrfs_fs_devices;
e20d96d6 38
db94535d 39struct extent_buffer *read_tree_block(struct btrfs_root *root, u64 bytenr,
ca7a79ad
CM
40 u32 blocksize, u64 parent_transid);
41int readahead_tree_block(struct btrfs_root *root, u64 bytenr, u32 blocksize,
42 u64 parent_transid);
5f39d397 43struct extent_buffer *btrfs_find_create_tree_block(struct btrfs_root *root,
db94535d 44 u64 bytenr, u32 blocksize);
e089f05c 45int clean_tree_block(struct btrfs_trans_handle *trans,
5f39d397 46 struct btrfs_root *root, struct extent_buffer *buf);
8a4b83cc 47struct btrfs_root *open_ctree(struct super_block *sb,
dfe25020
CM
48 struct btrfs_fs_devices *fs_devices,
49 char *options);
e20d96d6 50int close_ctree(struct btrfs_root *root);
79154b1b 51int write_ctree_super(struct btrfs_trans_handle *trans,
a512bbf8
YZ
52 struct btrfs_root *root, int max_mirrors);
53struct buffer_head *btrfs_read_dev_super(struct block_device *bdev);
c146afad 54int btrfs_commit_super(struct btrfs_root *root);
5f39d397 55struct extent_buffer *btrfs_find_tree_block(struct btrfs_root *root,
db94535d 56 u64 bytenr, u32 blocksize);
dc17ff8f
CM
57struct btrfs_root *btrfs_lookup_fs_root(struct btrfs_fs_info *fs_info,
58 u64 root_objectid);
0f7d52f4 59struct btrfs_root *btrfs_read_fs_root(struct btrfs_fs_info *fs_info,
58176a96
JB
60 struct btrfs_key *location,
61 const char *name, int namelen);
e02119d5 62struct btrfs_root *btrfs_read_fs_root_no_radix(struct btrfs_root *tree_root,
5eda7b5e 63 struct btrfs_key *location);
edbd8d4e
CM
64struct btrfs_root *btrfs_read_fs_root_no_name(struct btrfs_fs_info *fs_info,
65 struct btrfs_key *location);
c146afad 66int btrfs_cleanup_fs_roots(struct btrfs_fs_info *fs_info);
8352d8a4
CM
67int btrfs_insert_dev_radix(struct btrfs_root *root,
68 struct block_device *bdev,
b4100d64 69 u64 device_id,
8352d8a4
CM
70 u64 block_start,
71 u64 num_blocks);
d3c2fdcf 72void btrfs_btree_balance_dirty(struct btrfs_root *root, unsigned long nr);
5eda7b5e 73int btrfs_free_fs_root(struct btrfs_fs_info *fs_info, struct btrfs_root *root);
5f39d397 74void btrfs_mark_buffer_dirty(struct extent_buffer *buf);
b9473439 75void btrfs_mark_buffer_dirty_nonblocking(struct extent_buffer *buf);
1259ab75 76int btrfs_buffer_uptodate(struct extent_buffer *buf, u64 parent_transid);
5f39d397
CM
77int btrfs_set_buffer_uptodate(struct extent_buffer *buf);
78int wait_on_tree_block_writeback(struct btrfs_root *root,
79 struct extent_buffer *buf);
ca7a79ad 80int btrfs_read_buffer(struct extent_buffer *buf, u64 parent_transid);
ff79f819
CM
81u32 btrfs_csum_data(struct btrfs_root *root, char *data, u32 seed, size_t len);
82void btrfs_csum_final(u32 crc, char *result);
0b86a832 83int btrfs_open_device(struct btrfs_device *dev);
0999df54
CM
84int btrfs_verify_block_csum(struct btrfs_root *root,
85 struct extent_buffer *buf);
22c59948
CM
86int btrfs_bio_wq_end_io(struct btrfs_fs_info *info, struct bio *bio,
87 int metadata);
44b8bd7e
CM
88int btrfs_wq_submit_bio(struct btrfs_fs_info *fs_info, struct inode *inode,
89 int rw, struct bio *bio, int mirror_num,
eaf25d93 90 unsigned long bio_flags, u64 bio_offset,
4a69a410
CM
91 extent_submit_bio_hook_t *submit_bio_start,
92 extent_submit_bio_hook_t *submit_bio_done);
93
777e6bd7 94int btrfs_congested_async(struct btrfs_fs_info *info, int iodone);
b64a2851 95unsigned long btrfs_async_submit_limit(struct btrfs_fs_info *info);
e02119d5
CM
96int btrfs_write_tree_block(struct extent_buffer *buf);
97int btrfs_wait_tree_block_writeback(struct extent_buffer *buf);
e02119d5
CM
98int btrfs_init_log_root_tree(struct btrfs_trans_handle *trans,
99 struct btrfs_fs_info *fs_info);
7237f183
YZ
100int btrfs_add_log_tree(struct btrfs_trans_handle *trans,
101 struct btrfs_root *root);
4bef0848 102int btree_lock_page_hook(struct page *page);
4008c04a
CM
103
104
105#ifdef CONFIG_DEBUG_LOCK_ALLOC
106void btrfs_set_buffer_lockdep_class(struct extent_buffer *eb, int level);
107#else
108static inline void btrfs_set_buffer_lockdep_class(struct extent_buffer *eb,
109 int level)
110{
111}
112#endif
eb60ceac 113#endif