"ext Tomi Valkeinen" <tomi.valkeinen@xxxxxxxxx> writes: > Hi, > > On Mon, 2008-12-08 at 02:24 -0700, ext Paul Walmsley wrote: >> Hi Tomi, >> >> On Mon, 8 Dec 2008, Tomi Valkeinen wrote: >> >> > On Sat, 2008-12-06 at 16:51 -0700, ext Paul Walmsley wrote: >> > > Hi Tomi, >> > > >> > > nice test case. >> > > >> > > On Fri, 5 Dec 2008, Tomi.Valkeinen@xxxxxxxxx wrote: >> > > >> > > > I have had strange clk_enable() crashes with DSS2, and now I managed to >> > > > isolate it. With the included patch, on OMAP3 SDP board, with default >> > > > kernel config, I always get the crash below. In this example case it >> > > > happens at specific time on boot, but with DSS2 it happens randomly at >> > > > runtime, when I enable the DSS clocks. >> > > >> >> At this point my guess would be that it is a DSS driver problem, but I >> don't think it is clear yet. >> > > I don't know much about power and clock domains, but I believe I found > the reason and fix for this. At least this should point to the right > direction. > > It looks to me that when I do clk_enable() to a clock which is inside a > turned off powerdomain, clk_enable() function will return before the > powerdomain is fully turned on. Reading PM_PWSTST_DSS shows that the > powerdomain is still in transition state. > > The following change waits until the powerdomain has finished the > transition. At least it fixed the problem for me, and other things seem > to be still working =). > > > diff --git a/arch/arm/mach-omap2/clockdomain.c b/arch/arm/mach-omap2/clockdomain.c > index fa62f14..f713d0b 100644 > --- a/arch/arm/mach-omap2/clockdomain.c > +++ b/arch/arm/mach-omap2/clockdomain.c > @@ -567,6 +567,8 @@ int omap2_clkdm_clk_enable(struct clockdomain *clkdm, struct clk *clk) > else > omap2_clkdm_wakeup(clkdm); > > + pwrdm_wait_transition(clkdm->pwrdm.ptr); > + Altough this patch is fixing the problem, I'll guess it's because of delay it causes rather than waiting for PM_PWSTST_DSS. omap2_clkdm_clk_enable alone doesn't switch pwrdm to on. This is because clockdomain/powerdomains are controlled by HW (hw supervised). I think the right answer is to use ST_*_IDLE & ST_*_STDBY bits in omap2_clk_wait_ready. > return 0; > } > > > -- > To unsubscribe from this list: send the line "unsubscribe linux-omap" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- Jouni Högander -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html