diff options
Diffstat (limited to 'fs/nilfs2/btree.c')
-rw-r--r-- | fs/nilfs2/btree.c | 52 |
1 files changed, 15 insertions, 37 deletions
diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c index 20e3fd0f4d4..24395e6d29d 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 | ||