]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
PM / devfreq: Fix memory leak when fail to register device
authorChanwoo Choi <cw00.choi@samsung.com>
Thu, 24 Aug 2017 01:42:48 +0000 (10:42 +0900)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 27 Sep 2017 12:43:20 +0000 (14:43 +0200)
commit 9e14de1077e9c34f141cf98bdba60cdd5193d962 upstream.

When the devfreq_add_device fails to register deivce, the memory
leak of devfreq instance happen. So, this patch fix the memory
leak issue. Before freeing the devfreq instance checks whether
devfreq instance is NULL or not because the device_unregister()
frees the devfreq instance when jumping to the 'err_init'.
It is to prevent the duplicate the kfee(devfreq).

Fixes: ac4b281176a5 ("PM / devfreq: fix duplicated kfree on devfreq pointer")
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/devfreq/devfreq.c

index dea04871b50d1011916307168750a82d05d535f5..a1c4ee818614d2aaf403aa11f33724771bb1821e 100644 (file)
@@ -564,7 +564,7 @@ struct devfreq *devfreq_add_device(struct device *dev,
        err = device_register(&devfreq->dev);
        if (err) {
                mutex_unlock(&devfreq->lock);
-               goto err_out;
+               goto err_dev;
        }
 
        devfreq->trans_table =  devm_kzalloc(&devfreq->dev,
@@ -610,6 +610,9 @@ err_init:
        mutex_unlock(&devfreq_list_lock);
 
        device_unregister(&devfreq->dev);
+err_dev:
+       if (devfreq)
+               kfree(devfreq);
 err_out:
        return ERR_PTR(err);
 }