Commit | Line | Data |
---|---|---|
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 | ||
e20d96d6 | 22 | #include <linux/buffer_head.h> |
eb60ceac | 23 | |
e20d96d6 CM |
24 | #define BTRFS_SUPER_INFO_OFFSET (16 * 1024) |
25 | ||
090d1875 CM |
26 | enum btrfs_bh_state_bits { |
27 | BH_Checked = BH_PrivateStart, | |
28 | }; | |
29 | BUFFER_FNS(Checked, checked); | |
30 | ||
e20d96d6 CM |
31 | static inline struct btrfs_node *btrfs_buffer_node(struct buffer_head *bh) |
32 | { | |
33 | return (struct btrfs_node *)bh->b_data; | |
34 | } | |
35 | ||
36 | static inline struct btrfs_leaf *btrfs_buffer_leaf(struct buffer_head *bh) | |
37 | { | |
38 | return (struct btrfs_leaf *)bh->b_data; | |
39 | } | |
40 | ||
41 | static inline struct btrfs_header *btrfs_buffer_header(struct buffer_head *bh) | |
42 | { | |
43 | return &((struct btrfs_node *)bh->b_data)->header; | |
44 | } | |
45 | ||
46 | struct buffer_head *read_tree_block(struct btrfs_root *root, u64 blocknr); | |
090d1875 | 47 | int readahead_tree_block(struct btrfs_root *root, u64 blocknr); |
d98237b3 CM |
48 | struct buffer_head *btrfs_find_create_tree_block(struct btrfs_root *root, |
49 | u64 blocknr); | |
e089f05c | 50 | int write_tree_block(struct btrfs_trans_handle *trans, struct btrfs_root *root, |
e20d96d6 | 51 | struct buffer_head *buf); |
e089f05c | 52 | int dirty_tree_block(struct btrfs_trans_handle *trans, struct btrfs_root *root, |
e20d96d6 | 53 | struct buffer_head *buf); |
e089f05c | 54 | int clean_tree_block(struct btrfs_trans_handle *trans, |
e20d96d6 | 55 | struct btrfs_root *root, struct buffer_head *buf); |
79154b1b CM |
56 | int btrfs_commit_transaction(struct btrfs_trans_handle *trans, |
57 | struct btrfs_root *root); | |
2c90e5d6 | 58 | struct btrfs_root *open_ctree(struct super_block *sb); |
e20d96d6 CM |
59 | int close_ctree(struct btrfs_root *root); |
60 | void btrfs_block_release(struct btrfs_root *root, struct buffer_head *buf); | |
79154b1b CM |
61 | int write_ctree_super(struct btrfs_trans_handle *trans, |
62 | struct btrfs_root *root); | |
d98237b3 | 63 | struct buffer_head *btrfs_find_tree_block(struct btrfs_root *root, u64 blocknr); |
f254e52c CM |
64 | int btrfs_csum_data(struct btrfs_root * root, char *data, size_t len, |
65 | char *result); | |
0f7d52f4 CM |
66 | struct btrfs_root *btrfs_read_fs_root(struct btrfs_fs_info *fs_info, |
67 | struct btrfs_key *location); | |
7eccb903 | 68 | u64 bh_blocknr(struct buffer_head *bh); |
8352d8a4 CM |
69 | int btrfs_insert_dev_radix(struct btrfs_root *root, |
70 | struct block_device *bdev, | |
b4100d64 | 71 | u64 device_id, |
8352d8a4 CM |
72 | u64 block_start, |
73 | u64 num_blocks); | |
74 | int btrfs_map_bh_to_logical(struct btrfs_root *root, struct buffer_head *bh, | |
75 | u64 logical); | |
35b7e476 CM |
76 | int btrfs_releasepage(struct page *page, gfp_t flags); |
77 | void btrfs_btree_balance_dirty(struct btrfs_root *root); | |
eb60ceac | 78 | #endif |