powerpc/82xx: Use common error handling code in pq2ads_pci_init_irq()

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
This commit is contained in:
Markus Elfring 2019-08-27 09:19:32 +02:00 committed by Michael Ellerman
parent 60aece4164
commit c0cff7a177

View File

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