[Ocfs2-tools-devel] [RFC 3/4] dx_dirs v1: add indexed dir code for extent_tree

Tao Ma tao.ma at oracle.com
Sun Dec 20 20:51:26 PST 2009



Coly Li wrote:
> This patch adds indexed dirs related code to libocfs2/extent_tree.c and libocfs2/extent_tree.h.
> 
> Signed-off-by: Coly Li <coly.li at suse.de>
> ---
> diff --git a/libocfs2/extent_tree.c b/libocfs2/extent_tree.c
> index 499ce1b..e5d13f3 100644
> --- a/libocfs2/extent_tree.c
> +++ b/libocfs2/extent_tree.c
> @@ -23,6 +23,7 @@
>  #include "ocfs2/byteorder.h"
>  #include "ocfs2/ocfs2.h"
>  #include "extent_tree.h"
> +#include "dealloc.h"
> 
>  static void ocfs2_dinode_set_last_eb_blk(struct ocfs2_extent_tree *et,
>  					 uint64_t blkno)
> @@ -60,6 +61,49 @@ static struct ocfs2_extent_tree_operations ocfs2_dinode_et_ops = {
>  	.eo_fill_root_el	= ocfs2_dinode_fill_root_el,
>  };
> 
> +static void ocfs2_dx_root_set_last_eb_blk (struct ocfs2_extent_tree *et,
> +						uint64_t blkno)
> +{
> +	struct ocfs2_dx_root_block *dx_root = et->et_object;
> +	dx_root->dr_last_eb_blk = blkno;
> +}
> +
> +static uint64_t ocfs2_dx_root_get_last_eb_blk (struct ocfs2_extent_tree *et)
> +{
> +	struct ocfs2_dx_root_block *dx_root = et->et_object;
> +	return dx_root->dr_last_eb_blk;
> +}
> +
> +static void ocfs2_dx_root_update_clusters(struct ocfs2_extent_tree *et,
> +					uint32_t clusters)
> +{
> +	struct ocfs2_dx_root_block *dx_root = et->et_object;
> +	dx_root->dr_clusters += clusters;
> +}
> +
> +static int ocfs2_dx_root_sanity_check(struct ocfs2_extent_tree *et)
> +{
> +	struct ocfs2_dx_root_block *dx_root = (struct ocfs2_dx_root_block *)et->et_object;
> +	assert(OCFS2_IS_VALID_DX_ROOT(dx_root));
> +
> +	return 0;
> +}
> +
> +static void ocfs2_dx_root_fill_root_el (struct ocfs2_extent_tree *et)
> +{
> +	struct ocfs2_dx_root_block *dx_root = et->et_object;
> +
> +	et->et_root_el = &dx_root->dr_list;
> +}
> +
> +static struct ocfs2_extent_tree_operations ocfs2_dx_root_et_ops = {
> +	.eo_set_last_eb_blk	= ocfs2_dx_root_set_last_eb_blk,
> +	.eo_get_last_eb_blk	= ocfs2_dx_root_get_last_eb_blk,
> +	.eo_update_clusters	= ocfs2_dx_root_update_clusters,
> +	.eo_sanity_check	= ocfs2_dx_root_sanity_check,
> +	.eo_fill_root_el	= ocfs2_dx_root_fill_root_el,
> +};
> +
>  static void __ocfs2_init_extent_tree(struct ocfs2_extent_tree *et,
>  				     ocfs2_filesys *fs,
>  				     char *buf,
> @@ -90,6 +134,15 @@ void ocfs2_init_dinode_extent_tree(struct ocfs2_extent_tree *et,
>  				 buf, &ocfs2_dinode_et_ops);
>  }
> 
> +void ocfs2_init_dx_root_extent_tree(struct ocfs2_extent_tree *et,
> +				    ocfs2_filesys *fs,
> +				    char *buf, uint64_t blkno)
> +{
> +	__ocfs2_init_extent_tree(et, fs, buf, blkno,
> +				NULL,
> +				NULL, &ocfs2_dx_root_et_ops);
> +}
> +
yeah, your indexed dir extent tree works well by now.
>  static inline void ocfs2_et_set_last_eb_blk(struct ocfs2_extent_tree *et,
>  					    uint64_t new_last_eb_blk)
>  {
> @@ -4072,3 +4125,53 @@ out:
>  	ocfs2_free_path(path);
>  	return ret;
>  }
> +
> +
> +int ocfs2_remove_btree_range(ocfs2_filesys *fs, struct ocfs2_dinode *di,
> +				struct ocfs2_extent_tree *et, uint32_t cpos,
> +				uint32_t p_cpos, uint32_t len)
We don't need this function in user space. Just create the function like 
I mentioned in the previous e-mail(in libocfs2/truncate.c).
remove_btree_range is powerful in the kernel, but we can use 
ocfs2_remove_extent and ocfs2_free_clusters which is much simpler to 
handle than adding truncate logs.

Regards,
Tao
> +{
> +	int ret;
> +	uint64_t p_blkno = ocfs2_clusters_to_blocks(fs, p_cpos);
> +	uint64_t blkno;
> +	char *tmp_di_buf = NULL;
> +	struct ocfs2_truncate_log *tl;
> +	struct ocfs2_dinode *tmp_di;
> +
> +	ret = ocfs2_lookup_system_inode(fs, TRUNCATE_LOG_SYSTEM_INODE,
> +			di->i_suballoc_slot, &blkno);
> +	if (ret)
> +		goto out;
> +	ret = ocfs2_malloc_block(fs->fs_io, &tmp_di_buf);
> +	if (ret)
> +		goto out;
> +	ret = ocfs2_read_inode(fs, blkno, tmp_di_buf);
> +	if (ret)
> +		goto out;
> +
> +	tmp_di = (struct ocfs2_dinode *)tmp_di_buf;
> +	tl = &tmp_di->id2.i_dealloc;
> +
> +	if (ocfs2_truncate_log_needs_flush(tl)) {
> +		ret = ocfs2_flush_truncate_log(fs, tl);
> +		if (ret) {
> +		       goto out;
> +		}
> +	}
> +
> +	ret = ocfs2_remove_extent(fs, et, cpos, len);
> +	if (ret) {
> +		printf ("error\n");
> +		goto out;
> +	}
> +
> +	ocfs2_et_update_clusters(et, -len);
> +	ret = ocfs2_truncate_log_append(fs, tmp_di, tl, p_blkno, len);
> +	if (ret)
> +		printf("truncate_log_append error\n");
> +out:
> +	if (tmp_di_buf)
> +		ocfs2_free(&tmp_di_buf);
> +	return ret;
> +}
> +
> diff --git a/libocfs2/extent_tree.h b/libocfs2/extent_tree.h
> index 4e6e091..651d382 100644
> --- a/libocfs2/extent_tree.h
> +++ b/libocfs2/extent_tree.h
> @@ -109,3 +109,10 @@ int ocfs2_change_extent_flag(ocfs2_filesys *fs,
>  int ocfs2_remove_extent(ocfs2_filesys *fs,
>  			struct ocfs2_extent_tree *et,
>  			uint32_t cpos, uint32_t len);
> +void ocfs2_init_dx_root_extent_tree(struct ocfs2_extent_tree *et,
> +				ocfs2_filesys *fs,
> +				char *buf, uint64_t blkno);
> +int ocfs2_remove_btree_range(ocfs2_filesys *fs, struct ocfs2_dinode *di,
> +				struct ocfs2_extent_tree *et, uint32_t cpos,
> +				uint32_t p_cpos, uint32_t len);
> +



More information about the Ocfs2-tools-devel mailing list