]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
usb: typec: intel_pmc_mux: Defer probe if SCU IPC isn't present
authorTomasz Michalec <tmichalec@google.com>
Tue, 10 Jun 2025 15:40:58 +0000 (17:40 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 19 Jun 2025 10:28:06 +0000 (12:28 +0200)
If pmc_usb_probe is called before SCU IPC is registered, pmc_usb_probe
will fail.

Return -EPROBE_DEFER when pmc_usb_probe doesn't get SCU IPC device, so
the probe function can be called again after SCU IPC is initialized.

Signed-off-by: Tomasz Michalec <tmichalec@google.com>
Reviewed-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Link: https://lore.kernel.org/r/20250610154058.1859812-1-tmichalec@google.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/typec/mux/intel_pmc_mux.c

index 65dda9183e6fb61b6d726aa0ea739e48a15b0dca..1698428654abbe6fefb9f7c700e782bff251e216 100644 (file)
@@ -754,7 +754,7 @@ static int pmc_usb_probe(struct platform_device *pdev)
 
        pmc->ipc = devm_intel_scu_ipc_dev_get(&pdev->dev);
        if (!pmc->ipc)
-               return -ENODEV;
+               return -EPROBE_DEFER;
 
        pmc->dev = &pdev->dev;