]> git.itanic.dy.fi Git - linux-stable/commitdiff
soc: bcm: brcmstb: pm: pm-arm: Fix refcount leak in brcmstb_pm_probe
authorMiaoqian Lin <linmq006@gmail.com>
Thu, 26 May 2022 07:53:22 +0000 (11:53 +0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 29 Jun 2022 06:59:54 +0000 (08:59 +0200)
commit 37d838de369b07b596c19ff3662bf0293fdb09ee upstream.

of_find_matching_node() returns a node pointer with refcount
incremented, we should use of_node_put() on it when not need anymore.
Add missing of_node_put() to avoid refcount leak.

In brcmstb_init_sram, it pass dn to of_address_to_resource(),
of_address_to_resource() will call of_find_device_by_node() to take
reference, so we should release the reference returned by
of_find_matching_node().

Fixes: 0b741b8234c8 ("soc: bcm: brcmstb: Add support for S2/S3/S5 suspend states (ARM)")
Signed-off-by: Miaoqian Lin <linmq006@gmail.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/soc/bcm/brcmstb/pm/pm-arm.c

index b1062334e608914eca43e6251d8ae5d95aa6c1d7..c6ec7d95bcfcc393629a21cd8ebb7dbb1d5b3a74 100644 (file)
@@ -780,6 +780,7 @@ static int brcmstb_pm_probe(struct platform_device *pdev)
        }
 
        ret = brcmstb_init_sram(dn);
+       of_node_put(dn);
        if (ret) {
                pr_err("error setting up SRAM for PM\n");
                return ret;