[Ocfs2-devel] [PATCH] ocfs2: return error while ocfs2_figure_merge_contig_type failing
Xue jiufei
xuejiufei at huawei.com
Tue Apr 21 17:19:01 PDT 2015
On 2015/4/21 10:22, Joseph Qi wrote:
> On 2015/4/17 17:09, Xue jiufei wrote:
>> Now function ocfs2_figure_merge_contig_type() still return CONTIG_NONE
>> when some error occurs which will cause unpredictable error.
>> So return error while ocfs2_figure_merge_contig_type failing.
>>
>> Signed-off-by: joyce.xue <xuejiufei at huawei.com>
>> ---
>> fs/ocfs2/alloc.c | 22 +++++++++++++++-------
>> 1 file changed, 15 insertions(+), 7 deletions(-)
>>
>> diff --git a/fs/ocfs2/alloc.c b/fs/ocfs2/alloc.c
>> index 044158b..aa039f2 100644
>> --- a/fs/ocfs2/alloc.c
>> +++ b/fs/ocfs2/alloc.c
>> @@ -4313,11 +4313,11 @@ out:
>> return ret;
>> }
>>
>> -static enum ocfs2_contig_type
>> -ocfs2_figure_merge_contig_type(struct ocfs2_extent_tree *et,
>> +int ocfs2_figure_merge_contig_type(struct ocfs2_extent_tree *et,
> It can still be static.
yes, that's right. Thanks for your advice. I will send version 2 later.
>
>> struct ocfs2_path *path,
>> struct ocfs2_extent_list *el, int index,
>> - struct ocfs2_extent_rec *split_rec)
>> + struct ocfs2_extent_rec *split_rec,
>> + struct ocfs2_merge_ctxt *ctxt)
>> {
>> int status;
>> enum ocfs2_contig_type ret = CONTIG_NONE;
>> @@ -4431,12 +4431,15 @@ ocfs2_figure_merge_contig_type(struct ocfs2_extent_tree *et,
>> }
>>
>> out:
>> + if (status == 0)
>> + ctxt->c_contig_type = ret;
>> +
>> if (left_path)
>> ocfs2_free_path(left_path);
>> if (right_path)
>> ocfs2_free_path(right_path);
>>
>> - return ret;
>> + return status;
>> }
>>
>> static void ocfs2_figure_contig_type(struct ocfs2_extent_tree *et,
>> @@ -5042,9 +5045,14 @@ int ocfs2_split_extent(handle_t *handle,
>> goto out;
>> }
>>
>> - ctxt.c_contig_type = ocfs2_figure_merge_contig_type(et, path, el,
>> - split_index,
>> - split_rec);
>> + ret = ocfs2_figure_merge_contig_type(et, path, el,
>> + split_index,
>> + split_rec,
>> + &ctxt);
>> + if (ret) {
>> + mlog_errno(ret);
>> + goto out;
>> + }
>>
>> /*
>> * The core merge / split code wants to know how much room is
>>
>
>
>
> .
>
More information about the Ocfs2-devel
mailing list