aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorTao Ma <tao.ma@oracle.com>2009-08-17 23:22:25 -0400
committerJoel Becker <joel.becker@oracle.com>2009-09-22 23:09:31 -0400
commitfe924415957e60471536762172d127e85519ef78 (patch)
treec26f47180bbc14fda78dae0cb3d40287d6dafd18 /fs
parent555936bfcb1af26c6919d6cedb83710bb03d4322 (diff)
ocfs2: Add refcount b-tree as a new extent tree.
Add refcount b-tree as a new extent tree so that it can use the b-tree to store and maniuplate ocfs2_refcount_rec. Signed-off-by: Tao Ma <tao.ma@oracle.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/ocfs2/alloc.c54
-rw-r--r--fs/ocfs2/alloc.h3
2 files changed, 57 insertions, 0 deletions
diff --git a/fs/ocfs2/alloc.c b/fs/ocfs2/alloc.c
index 14b9106849ca..a6296560a5cb 100644
--- a/fs/ocfs2/alloc.c
+++ b/fs/ocfs2/alloc.c
@@ -385,6 +385,52 @@ static struct ocfs2_extent_tree_operations ocfs2_dx_root_et_ops = {
385 .eo_fill_root_el = ocfs2_dx_root_fill_root_el, 385 .eo_fill_root_el = ocfs2_dx_root_fill_root_el,
386}; 386};
387 387
388static void ocfs2_refcount_tree_fill_root_el(struct ocfs2_extent_tree *et)
389{
390 struct ocfs2_refcount_block *rb = et->et_object;
391
392 et->et_root_el = &rb->rf_list;
393}
394
395static void ocfs2_refcount_tree_set_last_eb_blk(struct ocfs2_extent_tree *et,
396 u64 blkno)
397{
398 struct ocfs2_refcount_block *rb = et->et_object;
399
400 rb->rf_last_eb_blk = cpu_to_le64(blkno);
401}
402
403static u64 ocfs2_refcount_tree_get_last_eb_blk(struct ocfs2_extent_tree *et)
404{
405 struct ocfs2_refcount_block *rb = et->et_object;
406
407 return le64_to_cpu(rb->rf_last_eb_blk);
408}
409
410static void ocfs2_refcount_tree_update_clusters(struct ocfs2_extent_tree *et,
411 u32 clusters)
412{
413 struct ocfs2_refcount_block *rb = et->et_object;
414
415 le32_add_cpu(&rb->rf_clusters, clusters);
416}
417
418static enum ocfs2_contig_type
419ocfs2_refcount_tree_extent_contig(struct ocfs2_extent_tree *et,
420 struct ocfs2_extent_rec *ext,
421 struct ocfs2_extent_rec *insert_rec)
422{
423 return CONTIG_NONE;
424}
425
426static struct ocfs2_extent_tree_operations ocfs2_refcount_tree_et_ops = {
427 .eo_set_last_eb_blk = ocfs2_refcount_tree_set_last_eb_blk,
428 .eo_get_last_eb_blk = ocfs2_refcount_tree_get_last_eb_blk,
429 .eo_update_clusters = ocfs2_refcount_tree_update_clusters,
430 .eo_fill_root_el = ocfs2_refcount_tree_fill_root_el,
431 .eo_extent_contig = ocfs2_refcount_tree_extent_contig,
432};
433
388static void __ocfs2_init_extent_tree(struct ocfs2_extent_tree *et, 434static void __ocfs2_init_extent_tree(struct ocfs2_extent_tree *et,
389 struct ocfs2_caching_info *ci, 435 struct ocfs2_caching_info *ci,
390 struct buffer_head *bh, 436 struct buffer_head *bh,
@@ -439,6 +485,14 @@ void ocfs2_init_dx_root_extent_tree(struct ocfs2_extent_tree *et,
439 NULL, &ocfs2_dx_root_et_ops); 485 NULL, &ocfs2_dx_root_et_ops);
440} 486}
441 487
488void ocfs2_init_refcount_extent_tree(struct ocfs2_extent_tree *et,
489 struct ocfs2_caching_info *ci,
490 struct buffer_head *bh)
491{
492 __ocfs2_init_extent_tree(et, ci, bh, ocfs2_journal_access_rb,
493 NULL, &ocfs2_refcount_tree_et_ops);
494}
495
442static inline void ocfs2_et_set_last_eb_blk(struct ocfs2_extent_tree *et, 496static inline void ocfs2_et_set_last_eb_blk(struct ocfs2_extent_tree *et,
443 u64 new_last_eb_blk) 497 u64 new_last_eb_blk)
444{ 498{
diff --git a/fs/ocfs2/alloc.h b/fs/ocfs2/alloc.h
index bcf6aa42ae53..df0e778a2b68 100644
--- a/fs/ocfs2/alloc.h
+++ b/fs/ocfs2/alloc.h
@@ -80,6 +80,9 @@ void ocfs2_init_xattr_value_extent_tree(struct ocfs2_extent_tree *et,
80void ocfs2_init_dx_root_extent_tree(struct ocfs2_extent_tree *et, 80void ocfs2_init_dx_root_extent_tree(struct ocfs2_extent_tree *et,
81 struct ocfs2_caching_info *ci, 81 struct ocfs2_caching_info *ci,
82 struct buffer_head *bh); 82 struct buffer_head *bh);
83void ocfs2_init_refcount_extent_tree(struct ocfs2_extent_tree *et,
84 struct ocfs2_caching_info *ci,
85 struct buffer_head *bh);
83 86
84/* 87/*
85 * Read an extent block into *bh. If *bh is NULL, a bh will be 88 * Read an extent block into *bh. If *bh is NULL, a bh will be