]> git.baikalelectronics.ru Git - kernel.git/commitdiff
powerpc/82xx: Use common error handling code in pq2ads_pci_init_irq()
authorMarkus Elfring <elfring@users.sourceforge.net>
Tue, 27 Aug 2019 07:19:32 +0000 (09:19 +0200)
committerMichael Ellerman <mpe@ellerman.id.au>
Sun, 31 Jan 2021 11:35:50 +0000 (22:35 +1100)
Adjust jump targets so that a bit of exception handling can be better
reused at the end of this function.

This issue was detected by using the Coccinelle software.

Signed-off-by: Markus Elfring <elfring@users.sourceforge.net>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/1a4bafee-562f-5eb4-d2bd-34704f8c5ab3@web.de
arch/powerpc/platforms/82xx/pq2ads-pci-pic.c

index 6cc054db70434742f66ff5c9e2f441b50944d0e6..f82f75a6085cf8b0a419351221bb5e54ef092442 100644 (file)
@@ -129,13 +129,11 @@ int __init pq2ads_pci_init_irq(void)
        irq = irq_of_parse_and_map(np, 0);
        if (!irq) {
                printk(KERN_ERR "No interrupt in pci pic node.\n");
-               of_node_put(np);
-               goto out;
+               goto out_put_node;
        }
 
        priv = kzalloc(sizeof(*priv), GFP_KERNEL);
        if (!priv) {
-               of_node_put(np);
                ret = -ENOMEM;
                goto out_unmap_irq;
        }
@@ -160,17 +158,17 @@ int __init pq2ads_pci_init_irq(void)
        priv->host = host;
        irq_set_handler_data(irq, priv);
        irq_set_chained_handler(irq, pq2ads_pci_irq_demux);
-
-       of_node_put(np);
-       return 0;
+       ret = 0;
+       goto out_put_node;
 
 out_unmap_regs:
        iounmap(priv->regs);
 out_free_kmalloc:
        kfree(priv);
-       of_node_put(np);
 out_unmap_irq:
        irq_dispose_mapping(irq);
+out_put_node:
+       of_node_put(np);
 out:
        return ret;
 }