lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
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