[<prev] [next>] [day] [month] [year] [list]
Message-Id: <20251026-b4-dwc3-apple-reset-array-fix-v1-1-ccdbacd63f78@kernel.org>
Date: Sun, 26 Oct 2025 12:21:36 +0000
From: Sven Peter <sven@...nel.org>
To: Janne Grunau <j@...nau.net>, Neal Gompa <neal@...pa.dev>,
Thinh Nguyen <Thinh.Nguyen@...opsys.com>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Philipp Zabel <p.zabel@...gutronix.de>
Cc: asahi@...ts.linux.dev, linux-arm-kernel@...ts.infradead.org,
linux-usb@...r.kernel.org, linux-kernel@...r.kernel.org,
Sven Peter <sven@...nel.org>
Subject: [PATCH usb-next] usb: dwc3: apple: Only support a single reset
controller
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@...gutronix.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@...nel.org>
---
I was planning to submit a v3 with this fixed but didn't find the time
before v2 was picked up.
---
drivers/usb/dwc3/dwc3-apple.c | 28 ++++++++++++++--------------
1 file changed, 14 insertions(+), 14 deletions(-)
diff --git a/drivers/usb/dwc3/dwc3-apple.c b/drivers/usb/dwc3/dwc3-apple.c
index 6e41bd0e34f461b0c3db9b8a646116458ff816b6..cc47cad232e397ac4498b09165dfdb5bd215ded7 100644
--- a/drivers/usb/dwc3/dwc3-apple.c
+++ b/drivers/usb/dwc3/dwc3-apple.c
@@ -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;
}
---
base-commit: be83d83664e9f6fa035e96fb9187f9e7898659e4
change-id: 20251022-b4-dwc3-apple-reset-array-fix-a61cd29bdd16
Best regards,
--
Sven Peter <sven@...nel.org>
Powered by blists - more mailing lists