summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSven Peter <sven@kernel.org>2025-10-26 12:21:36 +0000
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2025-10-28 15:35:21 +0100
commit7915d513e22db3226bfc7d5428b6dd6faa3ce181 (patch)
tree0e993db751bd7d09c5385c1f6538f3f4c0648e81
parentabf640a2436f3cd21f3d63eeccb332b4056adb9e (diff)
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@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>
-rw-r--r--drivers/usb/dwc3/dwc3-apple.c28
1 files changed, 14 insertions, 14 deletions
diff --git a/drivers/usb/dwc3/dwc3-apple.c b/drivers/usb/dwc3/dwc3-apple.c
index 6e41bd0e34f4..cc47cad232e3 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;
}