ARM: OMAP4: hwmod: Fix SOFTRESET logic for OMAP4
Commit 313a76e
(ARM: OMAP2+: hwmod: Fix SOFTRESET logic) introduced
softreset bit cleaning right after set one. It is caused L3 error for
OMAP4 ISS because ISS register write occurs when ISS reset process is in
progress. Avoid this situation by cleaning softreset bit later, when reset
process is successfully finished.
Signed-off-by: Illia Smyrnov <illia.smyrnov@globallogic.com>
Reviewed-by: Grygorii Strashko <grygorii.strashko@ti.com>
Acked-by: Roger Quadros <rogerq@ti.com>
Signed-off-by: Paul Walmsley <paul@pwsan.com>
This commit is contained in:
parent
c317d0f241
commit
01142519ff
|
@ -1947,29 +1947,31 @@ static int _ocp_softreset(struct omap_hwmod *oh)
|
||||||
goto dis_opt_clks;
|
goto dis_opt_clks;
|
||||||
|
|
||||||
_write_sysconfig(v, oh);
|
_write_sysconfig(v, oh);
|
||||||
|
|
||||||
|
if (oh->class->sysc->srst_udelay)
|
||||||
|
udelay(oh->class->sysc->srst_udelay);
|
||||||
|
|
||||||
|
c = _wait_softreset_complete(oh);
|
||||||
|
if (c == MAX_MODULE_SOFTRESET_WAIT) {
|
||||||
|
pr_warning("omap_hwmod: %s: softreset failed (waited %d usec)\n",
|
||||||
|
oh->name, MAX_MODULE_SOFTRESET_WAIT);
|
||||||
|
ret = -ETIMEDOUT;
|
||||||
|
goto dis_opt_clks;
|
||||||
|
} else {
|
||||||
|
pr_debug("omap_hwmod: %s: softreset in %d usec\n", oh->name, c);
|
||||||
|
}
|
||||||
|
|
||||||
ret = _clear_softreset(oh, &v);
|
ret = _clear_softreset(oh, &v);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto dis_opt_clks;
|
goto dis_opt_clks;
|
||||||
|
|
||||||
_write_sysconfig(v, oh);
|
_write_sysconfig(v, oh);
|
||||||
|
|
||||||
if (oh->class->sysc->srst_udelay)
|
|
||||||
udelay(oh->class->sysc->srst_udelay);
|
|
||||||
|
|
||||||
c = _wait_softreset_complete(oh);
|
|
||||||
if (c == MAX_MODULE_SOFTRESET_WAIT)
|
|
||||||
pr_warning("omap_hwmod: %s: softreset failed (waited %d usec)\n",
|
|
||||||
oh->name, MAX_MODULE_SOFTRESET_WAIT);
|
|
||||||
else
|
|
||||||
pr_debug("omap_hwmod: %s: softreset in %d usec\n", oh->name, c);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* XXX add _HWMOD_STATE_WEDGED for modules that don't come back from
|
* XXX add _HWMOD_STATE_WEDGED for modules that don't come back from
|
||||||
* _wait_target_ready() or _reset()
|
* _wait_target_ready() or _reset()
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ret = (c == MAX_MODULE_SOFTRESET_WAIT) ? -ETIMEDOUT : 0;
|
|
||||||
|
|
||||||
dis_opt_clks:
|
dis_opt_clks:
|
||||||
if (oh->flags & HWMOD_CONTROL_OPT_CLKS_IN_RESET)
|
if (oh->flags & HWMOD_CONTROL_OPT_CLKS_IN_RESET)
|
||||||
_disable_optional_clocks(oh);
|
_disable_optional_clocks(oh);
|
||||||
|
|
Loading…
Reference in New Issue