* Dave Gerlach <d-gerlach@xxxxxx> [140710 19:59]: > From: Vaibhav Bedia <vaibhav.bedia@xxxxxx> > > OMAP timer code registers two timers - one as clocksource > and one as clockevent. Since AM33XX has only one usable timer > in the WKUP domain one of the timers needs suspend-resume > support to restore the configuration to pre-suspend state. > > commit adc78e6 (timekeeping: Add suspend and resume > of clock event devices) introduced .suspend and .resume > callbacks for clock event devices. Leverages these > callbacks to have AM33XX clockevent timer which is > in not in WKUP domain to behave properly across system > suspend. > > Signed-off-by: Vaibhav Bedia <vaibhav.bedia@xxxxxx> > Signed-off-by: Dave Gerlach <d-gerlach@xxxxxx> > --- > v3->v4: > Only use for am33xx soc now. > > arch/arm/mach-omap2/timer.c | 28 ++++++++++++++++++++++++++++ > 1 file changed, 28 insertions(+) > > diff --git a/arch/arm/mach-omap2/timer.c b/arch/arm/mach-omap2/timer.c > index 43d03fb..6fc1748 100644 > --- a/arch/arm/mach-omap2/timer.c > +++ b/arch/arm/mach-omap2/timer.c > @@ -128,6 +128,29 @@ static void omap2_gp_timer_set_mode(enum clock_event_mode mode, > } > } > > +static void omap_clkevt_suspend(struct clock_event_device *unused) > +{ > + struct omap_hwmod *oh; > + > + oh = omap_hwmod_lookup(clockevent_gpt.name); > + if (!oh) > + return; > + > + omap_hwmod_idle(oh); > +} > + > +static void omap_clkevt_resume(struct clock_event_device *unused) > +{ > + struct omap_hwmod *oh; > + > + oh = omap_hwmod_lookup(clockevent_gpt.name); > + if (!oh) > + return; > + > + omap_hwmod_enable(oh); > + __omap_dm_timer_int_enable(&clkev, OMAP_TIMER_INT_OVERFLOW); > +} > + This is going to make moving the timer code into drivers one step tougher to do. And you don't need to look up the hwmod entry every time, just initialize it during the init. > + if (soc_is_am33xx()) { > + clockevent_gpt.suspend = omap_clkevt_suspend; > + clockevent_gpt.resume = omap_clkevt_resume; > + } > + Maybe try to set up things so we initialize the SoC specific timer suspend and resume functions in mach-omap2/timer.c in a way where eventually the device driver can easily use them? Regards, Tony -- 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