Re: [PATCH 4/5] powerpc-pseries: Return directly after a failed kzalloc_node() in iommu_pseries_alloc_group()

From: Michal SuchÃnek
Date: Thu Oct 19 2017 - 08:39:58 EST


On Thu, 19 Oct 2017 14:04:43 +0200
SF Markus Elfring <elfring@xxxxxxxxxxxxxxxxxxxxx> wrote:

> >> @@ -61,7 +61,7 @@ static struct iommu_table_group
> >> *iommu_pseries_alloc_group(int node) table_group =
> >> kzalloc_node(sizeof(*table_group), GFP_KERNEL, node); if
> >> (!table_group)
> >> - goto fail_exit;
> >> + return NULL;
> >>
> >> tbl = kzalloc_node(sizeof(*tbl), GFP_KERNEL, node);
> >> if (!tbl)
> >
> > I have seen quite a few fixes that do inverse of this patch after a
> > piece of code allocating some extra piece of memory was added before
> > code that just returns on fail because it is the first allocation in
> > the function.
> >
> > This is not useful.
>
> How do you think about an information from the section â7)
> Centralized exiting of functionsâ in the document âcoding-style.rstâ
> then?
>
> ââ
> If there is no cleanup needed then just return directly.
> ââ

There is also stated benefit

"
- errors by not updating individual exit points when making
modifications are prevented
"

which is furthered by using the common cleanup even in case no cleanup
is required but running the cleanup does not cause any harm.

Thanks

Michal