]> git.baikalelectronics.ru Git - kernel.git/commit
ARM: OMAP2+: Fix dmtimer set source clock failure
authorJon Hunter <jon-hunter@ti.com>
Fri, 13 Jul 2012 20:12:03 +0000 (15:12 -0500)
committerTony Lindgren <tony@atomide.com>
Wed, 8 Aug 2012 06:45:54 +0000 (23:45 -0700)
commit04d8b51c23499450fd33df141f0d9e9cdcde5125
tree8fd899cb68b67eb24a74b9ad816f384713b81604
parente4f1f67f43a58df3611c006cfe0378f5ca8c33fd
ARM: OMAP2+: Fix dmtimer set source clock failure

Calling the dmtimer function omap_dm_timer_set_source() fails if following a
call to pm_runtime_put() to disable the timer. For example the following
sequence would fail to set the parent clock ...

omap_dm_timer_stop(gptimer);
omap_dm_timer_set_source(gptimer, OMAP_TIMER_SRC_32_KHZ);

The following error message would be seen ...

omap_dm_timer_set_source: failed to set timer_32k_ck as parent

The problem is that, by design, pm_runtime_put() simply decrements the usage
count and returns before the timer has actually been disabled. Therefore,
setting the parent clock failed because the timer was still active when the
trying to set the parent clock. Setting a parent clock will fail if the clock
you are setting the parent of has a non-zero usage count. To ensure that this
does not fail use pm_runtime_put_sync() when disabling the timer.

Note that this will not be seen on OMAP1 devices, because these devices do
not use the clock framework for dmtimers.

Signed-off-by: Jon Hunter <jon-hunter@ti.com>
Acked-by: Kevin Hilman <khilman@ti.com>
Cc: stable@vger.kernel.org
Signed-off-by: Tony Lindgren <tony@atomide.com>
arch/arm/plat-omap/dmtimer.c