ARM: davinci: PM: Free resources in error handling path in 'davinci_pm_init'
authorChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Sat, 13 May 2017 11:40:05 +0000 (13:40 +0200)
committerSekhar Nori <nsekhar@ti.com>
Wed, 17 May 2017 09:21:49 +0000 (14:51 +0530)
If 'sram_alloc' fails, we need to free already allocated resources.

Fixes: aa9aa1ec2df6 ("ARM: davinci: PM: rework init, remove platform device")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: Sekhar Nori <nsekhar@ti.com>
arch/arm/mach-davinci/pm.c

index efb80354f3034d856ab259bb1568dab41173d3b3..d282b0783ecfc3c39abfde594e27164348379754 100644 (file)
@@ -153,7 +153,8 @@ int __init davinci_pm_init(void)
        davinci_sram_suspend = sram_alloc(davinci_cpu_suspend_sz, NULL);
        if (!davinci_sram_suspend) {
                pr_err("PM: cannot allocate SRAM memory\n");
-               return -ENOMEM;
+               ret = -ENOMEM;
+               goto no_sram_mem;
        }
 
        davinci_sram_push(davinci_sram_suspend, davinci_cpu_suspend,
@@ -161,6 +162,8 @@ int __init davinci_pm_init(void)
 
        suspend_set_ops(&davinci_pm_ops);
 
+no_sram_mem:
+       iounmap(pm_config.ddrpsc_reg_base);
 no_ddrpsc_mem:
        iounmap(pm_config.ddrpll_reg_base);
 no_ddrpll_mem: