hwmon: (coretemp) Allocate platform data with devm_kzalloc
authorGuenter Roeck <linux@roeck-us.net>
Sun, 16 Feb 2014 23:29:55 +0000 (15:29 -0800)
committerGuenter Roeck <linux@roeck-us.net>
Mon, 3 Mar 2014 16:01:05 +0000 (08:01 -0800)
This simplifies error handling.

Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Reviewed-by: Jean Delvare <jdelvare@suse.de>
Tested-by: Jean Delvare <jdelvare@suse.de>
drivers/hwmon/coretemp.c

index 3f87db26433dcaa1c906dad0fcf3696dd743ffd9..944f850d11187429f09d5a385f116d69727b3c5c 100644 (file)
@@ -582,22 +582,23 @@ static void coretemp_remove_core(struct platform_data *pdata,
 
 static int coretemp_probe(struct platform_device *pdev)
 {
+       struct device *dev = &pdev->dev;
        struct platform_data *pdata;
        int err;
 
        /* Initialize the per-package data structures */
-       pdata = kzalloc(sizeof(struct platform_data), GFP_KERNEL);
+       pdata = devm_kzalloc(dev, sizeof(struct platform_data), GFP_KERNEL);
        if (!pdata)
                return -ENOMEM;
 
-       err = create_name_attr(pdata, &pdev->dev);
+       err = create_name_attr(pdata, dev);
        if (err)
-               goto exit_free;
+               return err;
 
        pdata->phys_proc_id = pdev->id;
        platform_set_drvdata(pdev, pdata);
 
-       pdata->hwmon_dev = hwmon_device_register(&pdev->dev);
+       pdata->hwmon_dev = hwmon_device_register(dev);
        if (IS_ERR(pdata->hwmon_dev)) {
                err = PTR_ERR(pdata->hwmon_dev);
                dev_err(&pdev->dev, "Class registration failed (%d)\n", err);
@@ -607,8 +608,6 @@ static int coretemp_probe(struct platform_device *pdev)
 
 exit_name:
        device_remove_file(&pdev->dev, &pdata->name_attr);
-exit_free:
-       kfree(pdata);
        return err;
 }
 
@@ -623,7 +622,6 @@ static int coretemp_remove(struct platform_device *pdev)
 
        device_remove_file(&pdev->dev, &pdata->name_attr);
        hwmon_device_unregister(pdata->hwmon_dev);
-       kfree(pdata);
        return 0;
 }