Commit e1f67b26 authored by Danesh Petigara's avatar Danesh Petigara Committed by Greg Kroah-Hartman

usb: bdc: Halt controller on suspend

[ Upstream commit 5fc453d7 ]

GISB bus error kernel panics have been observed during S2 transition
tests on the 7271t platform. The errors are a result of the BDC
interrupt handler trying to access BDC register space after the
system's suspend callbacks have completed.

Adding a suspend hook to the BDC driver that halts the controller before
S2 entry thus preventing unwanted access to the BDC register space during
this transition.
Signed-off-by: default avatarDanesh Petigara <danesh.petigara@broadcom.com>
Signed-off-by: default avatarAl Cooper <alcooperx@gmail.com>
Acked-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarFelipe Balbi <balbi@kernel.org>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
parent 469ea9a2
...@@ -608,9 +608,14 @@ static int bdc_remove(struct platform_device *pdev) ...@@ -608,9 +608,14 @@ static int bdc_remove(struct platform_device *pdev)
static int bdc_suspend(struct device *dev) static int bdc_suspend(struct device *dev)
{ {
struct bdc *bdc = dev_get_drvdata(dev); struct bdc *bdc = dev_get_drvdata(dev);
int ret;
clk_disable_unprepare(bdc->clk); /* Halt the controller */
return 0; ret = bdc_stop(bdc);
if (!ret)
clk_disable_unprepare(bdc->clk);
return ret;
} }
static int bdc_resume(struct device *dev) static int bdc_resume(struct device *dev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment