[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20140520155138.GA23434@roeck-us.net>
Date: Tue, 20 May 2014 08:51:38 -0700
From: Guenter Roeck <linux@...ck-us.net>
To: Himangi Saraogi <himangi774@...il.com>
Cc: Jean Delvare <jdelvare@...e.de>, lm-sensors@...sensors.org,
linux-kernel@...r.kernel.org, julia.lawall@...6.fr
Subject: Re: [PATCH] hwmon: Introduce the use of the managed version of
kzalloc
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@...il.com>
> ---
> Not compile tested.
>
> To send to: Jean Delvare <jdelvare@...e.de>,Guenter Roeck <linux@...ck-us.net>,
> lm-sensors@...sensors.org,linux-kernel@...r.kernel.org
>
> 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@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists