From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753146AbaFDLkV (ORCPT ); Wed, 4 Jun 2014 07:40:21 -0400 Received: from mail.dev.rtsoft.ru ([213.79.90.226]:58913 "EHLO dev.rtsoft.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752730AbaFDLgH (ORCPT ); Wed, 4 Jun 2014 07:36:07 -0400 From: nyushchenko@dev.rtsoft.ru To: Grant Likely , Rob Herring , Benjamin Herrenschmidt , Thomas Gleixner , devicetree@vger.kernel.org Cc: linux-kernel@vger.kernel.org, lugovskoy@dev.rtsoft.ru, Nikita Yushchenko Subject: [PATCH 20/21] usb: use devm_irq_of_parse_and_map() where appropriate Date: Wed, 4 Jun 2014 15:13:20 +0400 Message-Id: <1401880402-30091-21-git-send-email-nyushchenko@dev.rtsoft.ru> X-Mailer: git-send-email 1.7.10.4 In-Reply-To: <1401880402-30091-1-git-send-email-nyushchenko@dev.rtsoft.ru> References: <1401880402-30091-1-git-send-email-nyushchenko@dev.rtsoft.ru> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Nikita Yushchenko This avoids leak of IRQ mapping on error paths, and makes it possible to use devm_request_irq() without facing unmap-while-handler-installed issues. Signed-off-by: Nikita Yushchenko --- drivers/usb/gadget/gr_udc.c | 17 +++++++++++------ drivers/usb/host/ehci-grlib.c | 11 ++++------- drivers/usb/host/ehci-orion.c | 3 ++- drivers/usb/host/ehci-ppc-of.c | 11 ++++------- drivers/usb/host/ehci-xilinx-of.c | 8 ++++---- drivers/usb/host/ohci-ppc-of.c | 7 ++----- 6 files changed, 27 insertions(+), 30 deletions(-) diff --git a/drivers/usb/gadget/gr_udc.c b/drivers/usb/gadget/gr_udc.c index f984ee7..0a3e586 100644 --- a/drivers/usb/gadget/gr_udc.c +++ b/drivers/usb/gadget/gr_udc.c @@ -2108,19 +2108,24 @@ static int gr_probe(struct platform_device *ofdev) if (IS_ERR(regs)) return PTR_ERR(regs); - dev->irq = irq_of_parse_and_map(dev->dev->of_node, 0); - if (!dev->irq) { + dev->irq = devm_irq_of_parse_and_map(dev->dev, dev->dev->of_node, 0); + if (dev->irq <= 0) { dev_err(dev->dev, "No irq found\n"); return -ENODEV; } /* Some core configurations has separate irqs for IN and OUT events */ - dev->irqi = irq_of_parse_and_map(dev->dev->of_node, 1); + dev->irqi = devm_irq_of_parse_and_map(dev->dev, dev->dev->of_node, 1); + if (dev->irqi < 0) { + dev_err(dev->dev, "could not locate irq\n"); + return dev->irqi; + } if (dev->irqi) { - dev->irqo = irq_of_parse_and_map(dev->dev->of_node, 2); - if (!dev->irqo) { + dev->irqo = devm_irq_of_parse_and_map(dev->dev, + dev->dev->of_node, 2); + if (dev->irqo <= 0) { dev_err(dev->dev, "Found irqi but not irqo\n"); - return -ENODEV; + return dev->irqo ? dev->irqo : -ENODEV; } } diff --git a/drivers/usb/host/ehci-grlib.c b/drivers/usb/host/ehci-grlib.c index 495b6fb..666c03e 100644 --- a/drivers/usb/host/ehci-grlib.c +++ b/drivers/usb/host/ehci-grlib.c @@ -111,11 +111,11 @@ static int ehci_hcd_grlib_probe(struct platform_device *op) hcd->rsrc_start = res.start; hcd->rsrc_len = resource_size(&res); - irq = irq_of_parse_and_map(dn, 0); - if (irq == NO_IRQ) { - dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", + irq = devm_irq_of_parse_and_map(&op->dev, dn, 0); + if (irq <= 0) { + dev_err(&op->dev, "%s: devm_irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_irq; } @@ -145,7 +145,6 @@ static int ehci_hcd_grlib_probe(struct platform_device *op) return 0; err_ioremap: - irq_dispose_mapping(irq); err_irq: usb_put_hcd(hcd); @@ -161,8 +160,6 @@ static int ehci_hcd_grlib_remove(struct platform_device *op) usb_remove_hcd(hcd); - irq_dispose_mapping(hcd->irq); - usb_put_hcd(hcd); return 0; diff --git a/drivers/usb/host/ehci-orion.c b/drivers/usb/host/ehci-orion.c index 30d35e5..c88177b 100644 --- a/drivers/usb/host/ehci-orion.c +++ b/drivers/usb/host/ehci-orion.c @@ -155,7 +155,8 @@ static int ehci_orion_drv_probe(struct platform_device *pdev) pr_debug("Initializing Orion-SoC USB Host Controller\n"); if (pdev->dev.of_node) - irq = irq_of_parse_and_map(pdev->dev.of_node, 0); + irq = devm_irq_of_parse_and_map(&pdev->dev, + pdev->dev.of_node, 0); else irq = platform_get_irq(pdev, 0); if (irq <= 0) { diff --git a/drivers/usb/host/ehci-ppc-of.c b/drivers/usb/host/ehci-ppc-of.c index 5479247..cc64210 100644 --- a/drivers/usb/host/ehci-ppc-of.c +++ b/drivers/usb/host/ehci-ppc-of.c @@ -117,11 +117,11 @@ static int ehci_hcd_ppc_of_probe(struct platform_device *op) hcd->rsrc_start = res.start; hcd->rsrc_len = resource_size(&res); - irq = irq_of_parse_and_map(dn, 0); - if (irq == NO_IRQ) { - dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", + irq = devm_irq_of_parse_and_map(&op->dev, dn, 0); + if (irq <= 0) { + dev_err(&op->dev, "%s: devm_irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_irq; } @@ -174,7 +174,6 @@ static int ehci_hcd_ppc_of_probe(struct platform_device *op) return 0; err_ioremap: - irq_dispose_mapping(irq); err_irq: usb_put_hcd(hcd); @@ -194,8 +193,6 @@ static int ehci_hcd_ppc_of_remove(struct platform_device *op) usb_remove_hcd(hcd); - irq_dispose_mapping(hcd->irq); - /* use request_mem_region to test if the ohci driver is loaded. if so * ensure the ohci core is operational. */ diff --git a/drivers/usb/host/ehci-xilinx-of.c b/drivers/usb/host/ehci-xilinx-of.c index fe57710..6c6f8c7 100644 --- a/drivers/usb/host/ehci-xilinx-of.c +++ b/drivers/usb/host/ehci-xilinx-of.c @@ -153,11 +153,11 @@ static int ehci_hcd_xilinx_of_probe(struct platform_device *op) hcd->rsrc_start = res.start; hcd->rsrc_len = resource_size(&res); - irq = irq_of_parse_and_map(dn, 0); - if (!irq) { - dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", + irq = devm_irq_of_parse_and_map(&op->dev, dn, 0); + if (irq <= 0) { + dev_err(&op->dev, "%s: devm_irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_irq; } diff --git a/drivers/usb/host/ohci-ppc-of.c b/drivers/usb/host/ohci-ppc-of.c index 965e3e9..fcdd23a 100644 --- a/drivers/usb/host/ohci-ppc-of.c +++ b/drivers/usb/host/ohci-ppc-of.c @@ -121,11 +121,11 @@ static int ohci_hcd_ppc_of_probe(struct platform_device *op) goto err_rmr; } - irq = irq_of_parse_and_map(dn, 0); + irq = devm_irq_of_parse_and_map(*op->dev, dn, 0); if (irq == NO_IRQ) { dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_rmr; } @@ -170,7 +170,6 @@ static int ohci_hcd_ppc_of_probe(struct platform_device *op) pr_debug("%s: cannot get ehci offset from fdt\n", __FILE__); } - irq_dispose_mapping(irq); err_rmr: usb_put_hcd(hcd); @@ -185,8 +184,6 @@ static int ohci_hcd_ppc_of_remove(struct platform_device *op) usb_remove_hcd(hcd); - irq_dispose_mapping(hcd->irq); - usb_put_hcd(hcd); return 0; -- 1.7.10.4 From mboxrd@z Thu Jan 1 00:00:00 1970 From: nyushchenko-jFhMxQ4mL6a2X5qOxWx28w@public.gmane.org Subject: [PATCH 20/21] usb: use devm_irq_of_parse_and_map() where appropriate Date: Wed, 4 Jun 2014 15:13:20 +0400 Message-ID: <1401880402-30091-21-git-send-email-nyushchenko@dev.rtsoft.ru> References: <1401880402-30091-1-git-send-email-nyushchenko@dev.rtsoft.ru> Return-path: In-Reply-To: <1401880402-30091-1-git-send-email-nyushchenko-jFhMxQ4mL6a2X5qOxWx28w@public.gmane.org> Sender: devicetree-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Grant Likely , Rob Herring , Benjamin Herrenschmidt , Thomas Gleixner , devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org Cc: linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, lugovskoy-jFhMxQ4mL6a2X5qOxWx28w@public.gmane.org, Nikita Yushchenko List-Id: devicetree@vger.kernel.org From: Nikita Yushchenko This avoids leak of IRQ mapping on error paths, and makes it possible to use devm_request_irq() without facing unmap-while-handler-installed issues. Signed-off-by: Nikita Yushchenko --- drivers/usb/gadget/gr_udc.c | 17 +++++++++++------ drivers/usb/host/ehci-grlib.c | 11 ++++------- drivers/usb/host/ehci-orion.c | 3 ++- drivers/usb/host/ehci-ppc-of.c | 11 ++++------- drivers/usb/host/ehci-xilinx-of.c | 8 ++++---- drivers/usb/host/ohci-ppc-of.c | 7 ++----- 6 files changed, 27 insertions(+), 30 deletions(-) diff --git a/drivers/usb/gadget/gr_udc.c b/drivers/usb/gadget/gr_udc.c index f984ee7..0a3e586 100644 --- a/drivers/usb/gadget/gr_udc.c +++ b/drivers/usb/gadget/gr_udc.c @@ -2108,19 +2108,24 @@ static int gr_probe(struct platform_device *ofdev) if (IS_ERR(regs)) return PTR_ERR(regs); - dev->irq = irq_of_parse_and_map(dev->dev->of_node, 0); - if (!dev->irq) { + dev->irq = devm_irq_of_parse_and_map(dev->dev, dev->dev->of_node, 0); + if (dev->irq <= 0) { dev_err(dev->dev, "No irq found\n"); return -ENODEV; } /* Some core configurations has separate irqs for IN and OUT events */ - dev->irqi = irq_of_parse_and_map(dev->dev->of_node, 1); + dev->irqi = devm_irq_of_parse_and_map(dev->dev, dev->dev->of_node, 1); + if (dev->irqi < 0) { + dev_err(dev->dev, "could not locate irq\n"); + return dev->irqi; + } if (dev->irqi) { - dev->irqo = irq_of_parse_and_map(dev->dev->of_node, 2); - if (!dev->irqo) { + dev->irqo = devm_irq_of_parse_and_map(dev->dev, + dev->dev->of_node, 2); + if (dev->irqo <= 0) { dev_err(dev->dev, "Found irqi but not irqo\n"); - return -ENODEV; + return dev->irqo ? dev->irqo : -ENODEV; } } diff --git a/drivers/usb/host/ehci-grlib.c b/drivers/usb/host/ehci-grlib.c index 495b6fb..666c03e 100644 --- a/drivers/usb/host/ehci-grlib.c +++ b/drivers/usb/host/ehci-grlib.c @@ -111,11 +111,11 @@ static int ehci_hcd_grlib_probe(struct platform_device *op) hcd->rsrc_start = res.start; hcd->rsrc_len = resource_size(&res); - irq = irq_of_parse_and_map(dn, 0); - if (irq == NO_IRQ) { - dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", + irq = devm_irq_of_parse_and_map(&op->dev, dn, 0); + if (irq <= 0) { + dev_err(&op->dev, "%s: devm_irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_irq; } @@ -145,7 +145,6 @@ static int ehci_hcd_grlib_probe(struct platform_device *op) return 0; err_ioremap: - irq_dispose_mapping(irq); err_irq: usb_put_hcd(hcd); @@ -161,8 +160,6 @@ static int ehci_hcd_grlib_remove(struct platform_device *op) usb_remove_hcd(hcd); - irq_dispose_mapping(hcd->irq); - usb_put_hcd(hcd); return 0; diff --git a/drivers/usb/host/ehci-orion.c b/drivers/usb/host/ehci-orion.c index 30d35e5..c88177b 100644 --- a/drivers/usb/host/ehci-orion.c +++ b/drivers/usb/host/ehci-orion.c @@ -155,7 +155,8 @@ static int ehci_orion_drv_probe(struct platform_device *pdev) pr_debug("Initializing Orion-SoC USB Host Controller\n"); if (pdev->dev.of_node) - irq = irq_of_parse_and_map(pdev->dev.of_node, 0); + irq = devm_irq_of_parse_and_map(&pdev->dev, + pdev->dev.of_node, 0); else irq = platform_get_irq(pdev, 0); if (irq <= 0) { diff --git a/drivers/usb/host/ehci-ppc-of.c b/drivers/usb/host/ehci-ppc-of.c index 5479247..cc64210 100644 --- a/drivers/usb/host/ehci-ppc-of.c +++ b/drivers/usb/host/ehci-ppc-of.c @@ -117,11 +117,11 @@ static int ehci_hcd_ppc_of_probe(struct platform_device *op) hcd->rsrc_start = res.start; hcd->rsrc_len = resource_size(&res); - irq = irq_of_parse_and_map(dn, 0); - if (irq == NO_IRQ) { - dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", + irq = devm_irq_of_parse_and_map(&op->dev, dn, 0); + if (irq <= 0) { + dev_err(&op->dev, "%s: devm_irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_irq; } @@ -174,7 +174,6 @@ static int ehci_hcd_ppc_of_probe(struct platform_device *op) return 0; err_ioremap: - irq_dispose_mapping(irq); err_irq: usb_put_hcd(hcd); @@ -194,8 +193,6 @@ static int ehci_hcd_ppc_of_remove(struct platform_device *op) usb_remove_hcd(hcd); - irq_dispose_mapping(hcd->irq); - /* use request_mem_region to test if the ohci driver is loaded. if so * ensure the ohci core is operational. */ diff --git a/drivers/usb/host/ehci-xilinx-of.c b/drivers/usb/host/ehci-xilinx-of.c index fe57710..6c6f8c7 100644 --- a/drivers/usb/host/ehci-xilinx-of.c +++ b/drivers/usb/host/ehci-xilinx-of.c @@ -153,11 +153,11 @@ static int ehci_hcd_xilinx_of_probe(struct platform_device *op) hcd->rsrc_start = res.start; hcd->rsrc_len = resource_size(&res); - irq = irq_of_parse_and_map(dn, 0); - if (!irq) { - dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", + irq = devm_irq_of_parse_and_map(&op->dev, dn, 0); + if (irq <= 0) { + dev_err(&op->dev, "%s: devm_irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_irq; } diff --git a/drivers/usb/host/ohci-ppc-of.c b/drivers/usb/host/ohci-ppc-of.c index 965e3e9..fcdd23a 100644 --- a/drivers/usb/host/ohci-ppc-of.c +++ b/drivers/usb/host/ohci-ppc-of.c @@ -121,11 +121,11 @@ static int ohci_hcd_ppc_of_probe(struct platform_device *op) goto err_rmr; } - irq = irq_of_parse_and_map(dn, 0); + irq = devm_irq_of_parse_and_map(*op->dev, dn, 0); if (irq == NO_IRQ) { dev_err(&op->dev, "%s: irq_of_parse_and_map failed\n", __FILE__); - rv = -EBUSY; + rv = irq ? irq : -EINVAL; goto err_rmr; } @@ -170,7 +170,6 @@ static int ohci_hcd_ppc_of_probe(struct platform_device *op) pr_debug("%s: cannot get ehci offset from fdt\n", __FILE__); } - irq_dispose_mapping(irq); err_rmr: usb_put_hcd(hcd); @@ -185,8 +184,6 @@ static int ohci_hcd_ppc_of_remove(struct platform_device *op) usb_remove_hcd(hcd); - irq_dispose_mapping(hcd->irq); - usb_put_hcd(hcd); return 0; -- 1.7.10.4 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html