diff options
Diffstat (limited to 'fs/nilfs2')
-rw-r--r-- | fs/nilfs2/btree.c | 52 | ||||
-rw-r--r-- | fs/nilfs2/btree.h | 26 |
2 files changed, 15 insertions, 63 deletions
diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c index 20e3fd0f4d4f..24395e6d29d0 100644 --- a/fs/nilfs2/btree.c +++ b/fs/nilfs2/btree.c | |||
@@ -913,9 +913,9 @@ static int nilfs_btree_prepare_insert(struct nilfs_btree *btree, | |||
913 | level = NILFS_BTREE_LEVEL_DATA; | 913 | level = NILFS_BTREE_LEVEL_DATA; |
914 | 914 | ||
915 | /* allocate a new ptr for data block */ | 915 | /* allocate a new ptr for data block */ |
916 | if (btree->bt_ops->btop_find_target != NULL) | 916 | if (NILFS_BMAP_USE_VBN(&btree->bt_bmap)) |
917 | path[level].bp_newreq.bpr_ptr = | 917 | path[level].bp_newreq.bpr_ptr = |
918 | btree->bt_ops->btop_find_target(btree, path, key); | 918 | nilfs_btree_find_target_v(btree, path, key); |
919 | 919 | ||
920 | ret = nilfs_bmap_prepare_alloc_ptr(&btree->bt_bmap, | 920 | ret = nilfs_bmap_prepare_alloc_ptr(&btree->bt_bmap, |
921 | &path[level].bp_newreq); | 921 | &path[level].bp_newreq); |
@@ -1061,8 +1061,8 @@ static void nilfs_btree_commit_insert(struct nilfs_btree *btree, | |||
1061 | 1061 | ||
1062 | set_buffer_nilfs_volatile((struct buffer_head *)((unsigned long)ptr)); | 1062 | set_buffer_nilfs_volatile((struct buffer_head *)((unsigned long)ptr)); |
1063 | ptr = path[NILFS_BTREE_LEVEL_DATA].bp_newreq.bpr_ptr; | 1063 | ptr = path[NILFS_BTREE_LEVEL_DATA].bp_newreq.bpr_ptr; |
1064 | if (btree->bt_ops->btop_set_target != NULL) | 1064 | if (NILFS_BMAP_USE_VBN(&btree->bt_bmap)) |
1065 | btree->bt_ops->btop_set_target(btree, key, ptr); | 1065 | nilfs_btree_set_target_v(btree, key, ptr); |
1066 | 1066 | ||
1067 | for (level = NILFS_BTREE_LEVEL_NODE_MIN; level <= maxlevel; level++) { | 1067 | for (level = NILFS_BTREE_LEVEL_NODE_MIN; level <= maxlevel; level++) { |
1068 | nilfs_bmap_commit_alloc_ptr(&btree->bt_bmap, | 1068 | nilfs_bmap_commit_alloc_ptr(&btree->bt_bmap, |
@@ -1586,9 +1586,9 @@ nilfs_btree_prepare_convert_and_insert(struct nilfs_bmap *bmap, __u64 key, | |||
1586 | 1586 | ||
1587 | /* for data */ | 1587 | /* for data */ |
1588 | /* cannot find near ptr */ | 1588 | /* cannot find near ptr */ |
1589 | if (btree->bt_ops->btop_find_target != NULL) | 1589 | if (NILFS_BMAP_USE_VBN(bmap)) |
1590 | dreq->bpr_ptr | 1590 | dreq->bpr_ptr = nilfs_btree_find_target_v(btree, NULL, key); |
1591 | = btree->bt_ops->btop_find_target(btree, NULL, key); | 1591 | |
1592 | ret = nilfs_bmap_prepare_alloc_ptr(bmap, dreq); | 1592 | ret = nilfs_bmap_prepare_alloc_ptr(bmap, dreq); |
1593 | if (ret < 0) | 1593 | if (ret < 0) |
1594 | return ret; | 1594 | return ret; |
@@ -1681,8 +1681,8 @@ nilfs_btree_commit_convert_and_insert(struct nilfs_bmap *bmap, | |||
1681 | nilfs_bmap_set_dirty(bmap); | 1681 | nilfs_bmap_set_dirty(bmap); |
1682 | } | 1682 | } |
1683 | 1683 | ||
1684 | if (btree->bt_ops->btop_set_target != NULL) | 1684 | if (NILFS_BMAP_USE_VBN(bmap)) |
1685 | btree->bt_ops->btop_set_target(btree, key, dreq->bpr_ptr); | 1685 | nilfs_btree_set_target_v(btree, key, dreq->bpr_ptr); |
1686 | } | 1686 | } |
1687 | 1687 | ||
1688 | /** | 1688 | /** |
@@ -1926,7 +1926,9 @@ static int nilfs_btree_propagate(const struct nilfs_bmap *bmap, | |||
1926 | goto out; | 1926 | goto out; |
1927 | } | 1927 | } |
1928 | 1928 | ||
1929 | ret = btree->bt_ops->btop_propagate(btree, path, level, bh); | 1929 | ret = NILFS_BMAP_USE_VBN(bmap) ? |
1930 | nilfs_btree_propagate_v(btree, path, level, bh) : | ||
1931 | nilfs_btree_propagate_p(btree, path, level, bh); | ||
1930 | 1932 | ||
1931 | out: | 1933 | out: |
1932 | nilfs_btree_clear_path(btree, path); | 1934 | nilfs_btree_clear_path(btree, path); |
@@ -2107,8 +2109,9 @@ static int nilfs_btree_assign(struct nilfs_bmap *bmap, | |||
2107 | goto out; | 2109 | goto out; |
2108 | } | 2110 | } |
2109 | 2111 | ||
2110 | ret = btree->bt_ops->btop_assign(btree, path, level, bh, | 2112 | ret = NILFS_BMAP_USE_VBN(bmap) ? |
2111 | blocknr, binfo); | 2113 | nilfs_btree_assign_v(btree, path, level, bh, blocknr, binfo) : |
2114 | nilfs_btree_assign_p(btree, path, level, bh, blocknr, binfo); | ||
2112 | 2115 | ||
2113 | out: | 2116 | out: |
2114 | nilfs_btree_clear_path(btree, path); | 2117 | nilfs_btree_clear_path(btree, path); |
@@ -2220,34 +2223,9 @@ static const struct nilfs_bmap_operations nilfs_btree_ops_gc = { | |||
2220 | .bop_gather_data = NULL, | 2223 | .bop_gather_data = NULL, |
2221 | }; | 2224 | }; |
2222 | 2225 | ||
2223 | static const struct nilfs_btree_operations nilfs_btree_ops_v = { | ||
2224 | .btop_find_target = nilfs_btree_find_target_v, | ||
2225 | .btop_set_target = nilfs_btree_set_target_v, | ||
2226 | .btop_propagate = nilfs_btree_propagate_v, | ||
2227 | .btop_assign = nilfs_btree_assign_v, | ||
2228 | }; | ||
2229 | |||
2230 | static const struct nilfs_btree_operations nilfs_btree_ops_p = { | ||
2231 | .btop_find_target = NULL, | ||
2232 | .btop_set_target = NULL, | ||
2233 | .btop_propagate = nilfs_btree_propagate_p, | ||
2234 | .btop_assign = nilfs_btree_assign_p, | ||
2235 | }; | ||
2236 | |||
2237 | int nilfs_btree_init(struct nilfs_bmap *bmap) | 2226 | int nilfs_btree_init(struct nilfs_bmap *bmap) |
2238 | { | 2227 | { |
2239 | struct nilfs_btree *btree = (struct nilfs_btree *)bmap; | ||
2240 | |||
2241 | bmap->b_ops = &nilfs_btree_ops; | 2228 | bmap->b_ops = &nilfs_btree_ops; |
2242 | switch (bmap->b_inode->i_ino) { | ||
2243 | case NILFS_DAT_INO: | ||
2244 | btree->bt_ops = &nilfs_btree_ops_p; | ||
2245 | break; | ||
2246 | default: | ||
2247 | btree->bt_ops = &nilfs_btree_ops_v; | ||
2248 | break; | ||
2249 | } | ||
2250 | |||
2251 | return 0; | 2229 | return 0; |
2252 | } | 2230 | } |
2253 | 2231 | ||
diff --git a/fs/nilfs2/btree.h b/fs/nilfs2/btree.h index 48aad2a0c59f..0e72bbbc6b64 100644 --- a/fs/nilfs2/btree.h +++ b/fs/nilfs2/btree.h | |||
@@ -34,28 +34,6 @@ struct nilfs_btree; | |||
34 | struct nilfs_btree_path; | 34 | struct nilfs_btree_path; |
35 | 35 | ||
36 | /** | 36 | /** |
37 | * struct nilfs_btree_operations - B-tree operation table | ||
38 | */ | ||
39 | struct nilfs_btree_operations { | ||
40 | __u64 (*btop_find_target)(const struct nilfs_btree *, | ||
41 | const struct nilfs_btree_path *, __u64); | ||
42 | void (*btop_set_target)(struct nilfs_btree *, __u64, __u64); | ||
43 | |||
44 | struct the_nilfs *(*btop_get_nilfs)(struct nilfs_btree *); | ||
45 | |||
46 | int (*btop_propagate)(struct nilfs_btree *, | ||
47 | struct nilfs_btree_path *, | ||
48 | int, | ||
49 | struct buffer_head *); | ||
50 | int (*btop_assign)(struct nilfs_btree *, | ||
51 | struct nilfs_btree_path *, | ||
52 | int, | ||
53 | struct buffer_head **, | ||
54 | sector_t, | ||
55 | union nilfs_binfo *); | ||
56 | }; | ||
57 | |||
58 | /** | ||
59 | * struct nilfs_btree_node - B-tree node | 37 | * struct nilfs_btree_node - B-tree node |
60 | * @bn_flags: flags | 38 | * @bn_flags: flags |
61 | * @bn_level: level | 39 | * @bn_level: level |
@@ -80,13 +58,9 @@ struct nilfs_btree_node { | |||
80 | /** | 58 | /** |
81 | * struct nilfs_btree - B-tree structure | 59 | * struct nilfs_btree - B-tree structure |
82 | * @bt_bmap: bmap base structure | 60 | * @bt_bmap: bmap base structure |
83 | * @bt_ops: B-tree operation table | ||
84 | */ | 61 | */ |
85 | struct nilfs_btree { | 62 | struct nilfs_btree { |
86 | struct nilfs_bmap bt_bmap; | 63 | struct nilfs_bmap bt_bmap; |
87 | |||
88 | /* B-tree-specific members */ | ||
89 | const struct nilfs_btree_operations *bt_ops; | ||
90 | }; | 64 | }; |
91 | 65 | ||
92 | 66 | ||