usb: dwc3: imx8mp: request irq after initializing dwc3
authorNadezda Lutovinova <lutovinova@ispras.ru>
Thu, 19 Aug 2021 15:48:18 +0000 (18:48 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 26 Aug 2021 11:10:56 +0000 (13:10 +0200)
If IRQ occurs between calling  devm_request_threaded_irq() and
initializing dwc3_imx->dwc3, then null pointer dereference occurs
since dwc3_imx->dwc3 is used in dwc3_imx8mp_interrupt().

The patch puts registration of the interrupt handler after
initializing of neccesery data.

Found by Linux Driver Verification project (linuxtesting.org).

Reviewed-by: Fabio Estevam <festevam@gmail.com>
Acked-by: Felipe Balbi <balbi@kernel.org>
Signed-off-by: Nadezda Lutovinova <lutovinova@ispras.ru>
Link: https://lore.kernel.org/r/20210819154818.18334-1-lutovinova@ispras.ru
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/dwc3/dwc3-imx8mp.c

index 756faa4..d328d20 100644 (file)
@@ -152,13 +152,6 @@ static int dwc3_imx8mp_probe(struct platform_device *pdev)
        }
        dwc3_imx->irq = irq;
 
-       err = devm_request_threaded_irq(dev, irq, NULL, dwc3_imx8mp_interrupt,
-                                       IRQF_ONESHOT, dev_name(dev), dwc3_imx);
-       if (err) {
-               dev_err(dev, "failed to request IRQ #%d --> %d\n", irq, err);
-               goto disable_clks;
-       }
-
        pm_runtime_set_active(dev);
        pm_runtime_enable(dev);
        err = pm_runtime_get_sync(dev);
@@ -186,6 +179,13 @@ static int dwc3_imx8mp_probe(struct platform_device *pdev)
        }
        of_node_put(dwc3_np);
 
+       err = devm_request_threaded_irq(dev, irq, NULL, dwc3_imx8mp_interrupt,
+                                       IRQF_ONESHOT, dev_name(dev), dwc3_imx);
+       if (err) {
+               dev_err(dev, "failed to request IRQ #%d --> %d\n", irq, err);
+               goto depopulate;
+       }
+
        device_set_wakeup_capable(dev, true);
        pm_runtime_put(dev);