diff options
author | Paul Walmsley <paul@pwsan.com> | 2010-01-26 22:12:59 -0500 |
---|---|---|
committer | Paul Walmsley <paul@pwsan.com> | 2010-01-26 22:12:59 -0500 |
commit | 55ed96945b1f3d0f4ad21a27b32ce4bd99d8c268 (patch) | |
tree | 0bec60498742922a9c00f39ff63eb48549d391fc /arch/arm/mach-omap2/prcm.c | |
parent | 6b04e0d99d4113ede24e263e3df246a17f490339 (diff) |
OMAP2/3 clkdm/pwrdm: move wkdep/sleepdep handling from pwrdm to clkdm
Move clockdomain wakeup dependency and sleep dependency data
structures from the powerdomain layer to the clockdomain layer, where
they belong. These dependencies were originally placed in the
powerdomain layer due to unclear documentation; however, it is clear
now that these dependencies are between clockdomains. For OMAP2/3,
this is not such a big problem, but for OMAP4 this needs to be fixed.
Thanks to Benoît Cousson <b-cousson@ti.com> for his advice on this
patch.
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2/prcm.c')
-rw-r--r-- | arch/arm/mach-omap2/prcm.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/prcm.c b/arch/arm/mach-omap2/prcm.c index 82ad8f8ad83a..abafd2298ece 100644 --- a/arch/arm/mach-omap2/prcm.c +++ b/arch/arm/mach-omap2/prcm.c | |||
@@ -199,6 +199,18 @@ u32 prm_rmw_mod_reg_bits(u32 mask, u32 bits, s16 module, s16 idx) | |||
199 | return v; | 199 | return v; |
200 | } | 200 | } |
201 | 201 | ||
202 | /* Read a PRM register, AND it, and shift the result down to bit 0 */ | ||
203 | u32 prm_read_mod_bits_shift(s16 domain, s16 idx, u32 mask) | ||
204 | { | ||
205 | u32 v; | ||
206 | |||
207 | v = prm_read_mod_reg(domain, idx); | ||
208 | v &= mask; | ||
209 | v >>= __ffs(mask); | ||
210 | |||
211 | return v; | ||
212 | } | ||
213 | |||
202 | /* Read a register in a CM module */ | 214 | /* Read a register in a CM module */ |
203 | u32 cm_read_mod_reg(s16 module, u16 idx) | 215 | u32 cm_read_mod_reg(s16 module, u16 idx) |
204 | { | 216 | { |