diff options
author | Rajendra Nayak <rnayak@ti.com> | 2011-02-25 18:06:47 -0500 |
---|---|---|
committer | Paul Walmsley <paul@pwsan.com> | 2011-02-25 18:06:47 -0500 |
commit | 32d4034eea9c5c2b2edc365e1a0787c8f5b84c3c (patch) | |
tree | 688c5a025999ec237ea6d5c8fbae2f018095fc82 | |
parent | 3673d1ef5dc94d8b942c33fe1895a0ff52efbc3c (diff) |
OMAP: clockdomain: Infrastructure to put arch specific code
Put infrastructure in place, so arch specific func pointers
can be hooked up to the platform-independent part of the
framework.
This is in preparation of splitting the clockdomain framework into
platform-independent part (for all omaps) and platform-specific
parts.
Signed-off-by: Rajendra Nayak <rnayak@ti.com>
Signed-off-by: Paul Walmsley <paul@pwsan.com>
-rw-r--r-- | arch/arm/mach-omap2/clockdomain.c | 10 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clockdomain.h | 37 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clockdomains44xx_data.c | 2 |
4 files changed, 47 insertions, 4 deletions
diff --git a/arch/arm/mach-omap2/clockdomain.c b/arch/arm/mach-omap2/clockdomain.c index 58e42f76603f..f70b06ae8664 100644 --- a/arch/arm/mach-omap2/clockdomain.c +++ b/arch/arm/mach-omap2/clockdomain.c | |||
@@ -44,6 +44,7 @@ static LIST_HEAD(clkdm_list); | |||
44 | /* array of clockdomain deps to be added/removed when clkdm in hwsup mode */ | 44 | /* array of clockdomain deps to be added/removed when clkdm in hwsup mode */ |
45 | static struct clkdm_autodep *autodeps; | 45 | static struct clkdm_autodep *autodeps; |
46 | 46 | ||
47 | static struct clkdm_ops *arch_clkdm; | ||
47 | 48 | ||
48 | /* Private functions */ | 49 | /* Private functions */ |
49 | 50 | ||
@@ -292,6 +293,7 @@ static void _disable_hwsup(struct clockdomain *clkdm) | |||
292 | * clkdm_init - set up the clockdomain layer | 293 | * clkdm_init - set up the clockdomain layer |
293 | * @clkdms: optional pointer to an array of clockdomains to register | 294 | * @clkdms: optional pointer to an array of clockdomains to register |
294 | * @init_autodeps: optional pointer to an array of autodeps to register | 295 | * @init_autodeps: optional pointer to an array of autodeps to register |
296 | * @custom_funcs: func pointers for arch specfic implementations | ||
295 | * | 297 | * |
296 | * Set up internal state. If a pointer to an array of clockdomains | 298 | * Set up internal state. If a pointer to an array of clockdomains |
297 | * @clkdms was supplied, loop through the list of clockdomains, | 299 | * @clkdms was supplied, loop through the list of clockdomains, |
@@ -300,12 +302,18 @@ static void _disable_hwsup(struct clockdomain *clkdm) | |||
300 | * @init_autodeps was provided, register those. No return value. | 302 | * @init_autodeps was provided, register those. No return value. |
301 | */ | 303 | */ |
302 | void clkdm_init(struct clockdomain **clkdms, | 304 | void clkdm_init(struct clockdomain **clkdms, |
303 | struct clkdm_autodep *init_autodeps) | 305 | struct clkdm_autodep *init_autodeps, |
306 | struct clkdm_ops *custom_funcs) | ||
304 | { | 307 | { |
305 | struct clockdomain **c = NULL; | 308 | struct clockdomain **c = NULL; |
306 | struct clockdomain *clkdm; | 309 | struct clockdomain *clkdm; |
307 | struct clkdm_autodep *autodep = NULL; | 310 | struct clkdm_autodep *autodep = NULL; |
308 | 311 | ||
312 | if (!custom_funcs) | ||
313 | WARN(1, "No custom clkdm functions registered\n"); | ||
314 | else | ||
315 | arch_clkdm = custom_funcs; | ||
316 | |||
309 | if (clkdms) | 317 | if (clkdms) |
310 | for (c = clkdms; *c; c++) | 318 | for (c = clkdms; *c; c++) |
311 | _clkdm_register(*c); | 319 | _clkdm_register(*c); |
diff --git a/arch/arm/mach-omap2/clockdomain.h b/arch/arm/mach-omap2/clockdomain.h index 9b459c26fb85..71ad265cf133 100644 --- a/arch/arm/mach-omap2/clockdomain.h +++ b/arch/arm/mach-omap2/clockdomain.h | |||
@@ -116,7 +116,42 @@ struct clockdomain { | |||
116 | struct list_head node; | 116 | struct list_head node; |
117 | }; | 117 | }; |
118 | 118 | ||
119 | void clkdm_init(struct clockdomain **clkdms, struct clkdm_autodep *autodeps); | 119 | /** |
120 | * struct clkdm_ops - Arch specfic function implementations | ||
121 | * @clkdm_add_wkdep: Add a wakeup dependency between clk domains | ||
122 | * @clkdm_del_wkdep: Delete a wakeup dependency between clk domains | ||
123 | * @clkdm_read_wkdep: Read wakeup dependency state between clk domains | ||
124 | * @clkdm_clear_all_wkdeps: Remove all wakeup dependencies from the clk domain | ||
125 | * @clkdm_add_sleepdep: Add a sleep dependency between clk domains | ||
126 | * @clkdm_del_sleepdep: Delete a sleep dependency between clk domains | ||
127 | * @clkdm_read_sleepdep: Read sleep dependency state between clk domains | ||
128 | * @clkdm_clear_all_sleepdeps: Remove all sleep dependencies from the clk domain | ||
129 | * @clkdm_sleep: Force a clockdomain to sleep | ||
130 | * @clkdm_wakeup: Force a clockdomain to wakeup | ||
131 | * @clkdm_allow_idle: Enable hw supervised idle transitions for clock domain | ||
132 | * @clkdm_deny_idle: Disable hw supervised idle transitions for clock domain | ||
133 | * @clkdm_clk_enable: Put the clkdm in right state for a clock enable | ||
134 | * @clkdm_clk_disable: Put the clkdm in right state for a clock disable | ||
135 | */ | ||
136 | struct clkdm_ops { | ||
137 | int (*clkdm_add_wkdep)(struct clockdomain *clkdm1, struct clockdomain *clkdm2); | ||
138 | int (*clkdm_del_wkdep)(struct clockdomain *clkdm1, struct clockdomain *clkdm2); | ||
139 | int (*clkdm_read_wkdep)(struct clockdomain *clkdm1, struct clockdomain *clkdm2); | ||
140 | int (*clkdm_clear_all_wkdeps)(struct clockdomain *clkdm); | ||
141 | int (*clkdm_add_sleepdep)(struct clockdomain *clkdm1, struct clockdomain *clkdm2); | ||
142 | int (*clkdm_del_sleepdep)(struct clockdomain *clkdm1, struct clockdomain *clkdm2); | ||
143 | int (*clkdm_read_sleepdep)(struct clockdomain *clkdm1, struct clockdomain *clkdm2); | ||
144 | int (*clkdm_clear_all_sleepdeps)(struct clockdomain *clkdm); | ||
145 | int (*clkdm_sleep)(struct clockdomain *clkdm); | ||
146 | int (*clkdm_wakeup)(struct clockdomain *clkdm); | ||
147 | void (*clkdm_allow_idle)(struct clockdomain *clkdm); | ||
148 | void (*clkdm_deny_idle)(struct clockdomain *clkdm); | ||
149 | int (*clkdm_clk_enable)(struct clockdomain *clkdm); | ||
150 | int (*clkdm_clk_disable)(struct clockdomain *clkdm); | ||
151 | }; | ||
152 | |||
153 | void clkdm_init(struct clockdomain **clkdms, struct clkdm_autodep *autodeps, | ||
154 | struct clkdm_ops *custom_funcs); | ||
120 | struct clockdomain *clkdm_lookup(const char *name); | 155 | struct clockdomain *clkdm_lookup(const char *name); |
121 | 156 | ||
122 | int clkdm_for_each(int (*fn)(struct clockdomain *clkdm, void *user), | 157 | int clkdm_for_each(int (*fn)(struct clockdomain *clkdm, void *user), |
diff --git a/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c b/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c index e6f0d18d5e8d..e2a959eab312 100644 --- a/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c +++ b/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c | |||
@@ -856,5 +856,5 @@ static struct clockdomain *clockdomains_omap2[] __initdata = { | |||
856 | 856 | ||
857 | void __init omap2_clockdomains_init(void) | 857 | void __init omap2_clockdomains_init(void) |
858 | { | 858 | { |
859 | clkdm_init(clockdomains_omap2, clkdm_autodeps); | 859 | clkdm_init(clockdomains_omap2, clkdm_autodeps, NULL); |
860 | } | 860 | } |
diff --git a/arch/arm/mach-omap2/clockdomains44xx_data.c b/arch/arm/mach-omap2/clockdomains44xx_data.c index 10622c914abc..a5000d473d45 100644 --- a/arch/arm/mach-omap2/clockdomains44xx_data.c +++ b/arch/arm/mach-omap2/clockdomains44xx_data.c | |||
@@ -305,5 +305,5 @@ static struct clockdomain *clockdomains_omap44xx[] __initdata = { | |||
305 | 305 | ||
306 | void __init omap44xx_clockdomains_init(void) | 306 | void __init omap44xx_clockdomains_init(void) |
307 | { | 307 | { |
308 | clkdm_init(clockdomains_omap44xx, NULL); | 308 | clkdm_init(clockdomains_omap44xx, NULL, NULL); |
309 | } | 309 | } |