]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
usb: dwc3: apple: Only support a single reset controller
authorSven Peter <sven@kernel.org>
Sun, 26 Oct 2025 12:21:36 +0000 (12:21 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 28 Oct 2025 14:35:21 +0000 (15:35 +0100)
As pointed out by Philipp, Apple's dwc3 controller only uses a single
reset line and there's thus no need to use reset controller array
functions. The only functional change here is replacing
devm_reset_control_array_get_exclusive with
devm_reset_control_get_exclusive. The rest are only cosmetic changes
to replace "resets" with "reset".

Reported-by: Philipp Zabel <p.zabel@pengutronix.de>
Closes: https://lore.kernel.org/asahi/47112ace39ea096242e68659d67a401e931abf3a.camel@pengutronix.de/
Fixes: 0ec946d32ef7 ("usb: dwc3: Add Apple Silicon DWC3 glue layer driver")
Signed-off-by: Sven Peter <sven@kernel.org>
Link: https://patch.msgid.link/20251026-b4-dwc3-apple-reset-array-fix-v1-1-ccdbacd63f78@kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/dwc3/dwc3-apple.c

index 6e41bd0e34f461b0c3db9b8a646116458ff816b6..cc47cad232e397ac4498b09165dfdb5bd215ded7 100644 (file)
@@ -81,7 +81,7 @@ enum dwc3_apple_state {
  * @dev: Pointer to the device structure
  * @mmio_resource: Resource to be passed to dwc3_core_probe
  * @apple_regs: Apple-specific DWC3 registers
- * @resets: Reset control
+ * @reset: Reset control
  * @role_sw: USB role switch
  * @lock: Mutex for synchronizing access
  * @state: Current state of the controller, see documentation for the enum for details
@@ -93,7 +93,7 @@ struct dwc3_apple {
        struct resource *mmio_resource;
        void __iomem *apple_regs;
 
-       struct reset_control *resets;
+       struct reset_control *reset;
        struct usb_role_switch *role_sw;
 
        struct mutex lock;
@@ -237,9 +237,9 @@ static int dwc3_apple_init(struct dwc3_apple *appledwc, enum dwc3_apple_state st
 
        lockdep_assert_held(&appledwc->lock);
 
-       ret = reset_control_deassert(appledwc->resets);
+       ret = reset_control_deassert(appledwc->reset);
        if (ret) {
-               dev_err(appledwc->dev, "Failed to deassert resets, err=%d\n", ret);
+               dev_err(appledwc->dev, "Failed to deassert reset, err=%d\n", ret);
                return ret;
        }
 
@@ -288,9 +288,9 @@ static int dwc3_apple_init(struct dwc3_apple *appledwc, enum dwc3_apple_state st
 core_exit:
        dwc3_core_exit(&appledwc->dwc);
 reset_assert:
-       ret_reset = reset_control_assert(appledwc->resets);
+       ret_reset = reset_control_assert(appledwc->reset);
        if (ret_reset)
-               dev_warn(appledwc->dev, "Failed to assert resets, err=%d\n", ret_reset);
+               dev_warn(appledwc->dev, "Failed to assert reset, err=%d\n", ret_reset);
 
        return ret;
 }
@@ -323,9 +323,9 @@ static int dwc3_apple_exit(struct dwc3_apple *appledwc)
        dwc3_core_exit(&appledwc->dwc);
        appledwc->state = DWC3_APPLE_NO_CABLE;
 
-       ret = reset_control_assert(appledwc->resets);
+       ret = reset_control_assert(appledwc->reset);
        if (ret) {
-               dev_err(appledwc->dev, "Failed to assert resets, err=%d\n", ret);
+               dev_err(appledwc->dev, "Failed to assert reset, err=%d\n", ret);
                return ret;
        }
 
@@ -411,14 +411,14 @@ static int dwc3_apple_probe(struct platform_device *pdev)
        appledwc->dev = &pdev->dev;
        mutex_init(&appledwc->lock);
 
-       appledwc->resets = devm_reset_control_array_get_exclusive(dev);
-       if (IS_ERR(appledwc->resets))
-               return dev_err_probe(&pdev->dev, PTR_ERR(appledwc->resets),
-                                    "Failed to get resets\n");
+       appledwc->reset = devm_reset_control_get_exclusive(dev, NULL);
+       if (IS_ERR(appledwc->reset))
+               return dev_err_probe(&pdev->dev, PTR_ERR(appledwc->reset),
+                                    "Failed to get reset control\n");
 
-       ret = reset_control_assert(appledwc->resets);
+       ret = reset_control_assert(appledwc->reset);
        if (ret) {
-               dev_err(&pdev->dev, "Failed to assert resets, err=%d\n", ret);
+               dev_err(&pdev->dev, "Failed to assert reset, err=%d\n", ret);
                return ret;
        }