Re: [PATCH] hwmon: Introduce the use of the managed version of kzalloc

From: Guenter Roeck
Date: Tue May 20 2014 - 11:51:57 EST


On Sun, May 18, 2014 at 12:02:56PM +0530, Himangi Saraogi wrote:
> This patch moves data allocated using kzalloc to managed data allocated
> using devm_kzalloc and cleans now unnecessary kfrees in probe and remove
> functions. Also, the unnecessary label out_free is removed.
>
> The following Coccinelle semantic patch was used for making the change:
>
> @platform@
> identifier p, probefn, removefn;
> @@
> struct platform_driver p = {
> .probe = probefn,
> .remove = removefn,
> };
>
> @prb@
> identifier platform.probefn, pdev;
> expression e, e1, e2;
> @@
> probefn(struct platform_device *pdev, ...) {
> <+...
> - e = kzalloc(e1, e2)
> + e = devm_kzalloc(&pdev->dev, e1, e2)
> ...
> ?-kfree(e);
> ...+>
> }
>
> @rem depends on prb@
> identifier platform.removefn;
> expression e;
> @@
> removefn(...) {
> <...
> - kfree(e);
> ...>
> }
>
> Signed-off-by: Himangi Saraogi <himangi774@xxxxxxxxx>
> ---
> Not compile tested.
>
> To send to: Jean Delvare <jdelvare@xxxxxxx>,Guenter Roeck <linux@xxxxxxxxxxxx>,
> lm-sensors@xxxxxxxxxxxxxx,linux-kernel@xxxxxxxxxxxxxxx
>
> drivers/hwmon/ultra45_env.c | 9 +++------
> 1 file changed, 3 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/hwmon/ultra45_env.c b/drivers/hwmon/ultra45_env.c
> index fb3e693..92564b8 100644
> --- a/drivers/hwmon/ultra45_env.c
> +++ b/drivers/hwmon/ultra45_env.c
> @@ -252,7 +252,7 @@ static const struct attribute_group env_group = {
>
> static int env_probe(struct platform_device *op)
> {
> - struct env *p = kzalloc(sizeof(*p), GFP_KERNEL);
> + struct env *p = devm_kzalloc(&op->dev, sizeof(*p), GFP_KERNEL);
> int err = -ENOMEM;
>
> if (!p)
> @@ -262,7 +262,7 @@ static int env_probe(struct platform_device *op)
>
> p->regs = of_ioremap(&op->resource[0], 0, REG_SIZE, "pic16f747");
> if (!p->regs)
> - goto out_free;
> + goto out;
>
> err = sysfs_create_group(&op->dev.kobj, &env_group);
> if (err)
> @@ -285,9 +285,7 @@ out_sysfs_remove_group:
>
> out_iounmap:
> of_iounmap(&op->resource[0], p->regs, REG_SIZE);
> -
> -out_free:
> - kfree(p);
> +
> goto out;
> }

This introduces a whitespace error, and results in really ugly code.

err = 0;

out:
return err;

out_sysfs_remove_group:
sysfs_remove_group(&op->dev.kobj, &env_group);

out_iounmap:
of_iounmap(&op->resource[0], p->regs, REG_SIZE);

goto out;
}

Ok, the code is already ugly, but it doesn't make sense to me
to spend time on it without cleaning it up.

Guenter
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/