aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2
diff options
context:
space:
mode:
authorPaul Walmsley <paul@pwsan.com>2010-12-21 23:05:15 -0500
committerPaul Walmsley <paul@pwsan.com>2010-12-21 23:05:15 -0500
commit1540f214065982e6cbc6b8da1fe65a15e358f7c5 (patch)
tree8a6c11fd7d07dd027ec14e5fe3403d2aaf0f02b0 /arch/arm/mach-omap2
parent55ae35073b1c76f24c3736cf797c40d9932b19aa (diff)
OMAP2+: clockdomain: move header file from plat-omap to mach-omap2
The OMAP clockdomain code and data is all OMAP2+-specific. This seems unlikely to change any time soon. Move plat-omap/include/plat/clockdomain.h to mach-omap2/clockdomain.h. The primary point of doing this is to remove the temptation for unrelated upper-layer code to access clockdomain code and data directly. DSPBridge also uses the clockdomain headers for some reason, so, modify it also. The DSPBridge code should not be including the clockdomain headers; these should be removed. Signed-off-by: Paul Walmsley <paul@pwsan.com> Cc: Kevin Hilman <khilman@deeprootsystems.com> Cc: Omar Ramirez Luna <omar.ramirez@ti.com> Cc: Felipe Contreras <felipe.contreras@gmail.com> Cc: Greg Kroah-Hartman <greg@kroah.com> Tested-by: Rajendra Nayak <rnayak@ti.com> Tested-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2')
-rw-r--r--arch/arm/mach-omap2/clock.c2
-rw-r--r--arch/arm/mach-omap2/clockdomain.c2
-rw-r--r--arch/arm/mach-omap2/clockdomain.h149
-rw-r--r--arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c2
-rw-r--r--arch/arm/mach-omap2/clockdomains44xx_data.c2
-rw-r--r--arch/arm/mach-omap2/cpuidle34xx.c2
-rw-r--r--arch/arm/mach-omap2/io.c2
-rw-r--r--arch/arm/mach-omap2/omap_hwmod.c2
-rw-r--r--arch/arm/mach-omap2/pm-debug.c2
-rw-r--r--arch/arm/mach-omap2/pm.c2
-rw-r--r--arch/arm/mach-omap2/pm24xx.c2
-rw-r--r--arch/arm/mach-omap2/pm34xx.c2
-rw-r--r--arch/arm/mach-omap2/powerdomain.c2
13 files changed, 161 insertions, 12 deletions
diff --git a/arch/arm/mach-omap2/clock.c b/arch/arm/mach-omap2/clock.c
index cda2f1da2e1f..2a2f15213add 100644
--- a/arch/arm/mach-omap2/clock.c
+++ b/arch/arm/mach-omap2/clock.c
@@ -24,7 +24,7 @@
24#include <linux/bitops.h> 24#include <linux/bitops.h>
25 25
26#include <plat/clock.h> 26#include <plat/clock.h>
27#include <plat/clockdomain.h> 27#include "clockdomain.h"
28#include <plat/cpu.h> 28#include <plat/cpu.h>
29#include <plat/prcm.h> 29#include <plat/prcm.h>
30 30
diff --git a/arch/arm/mach-omap2/clockdomain.c b/arch/arm/mach-omap2/clockdomain.c
index e5605c21ad38..650bf685dd99 100644
--- a/arch/arm/mach-omap2/clockdomain.c
+++ b/arch/arm/mach-omap2/clockdomain.c
@@ -35,7 +35,7 @@
35 35
36#include <plat/clock.h> 36#include <plat/clock.h>
37#include <plat/powerdomain.h> 37#include <plat/powerdomain.h>
38#include <plat/clockdomain.h> 38#include "clockdomain.h"
39#include <plat/prcm.h> 39#include <plat/prcm.h>
40 40
41/* clkdm_list contains all registered struct clockdomains */ 41/* clkdm_list contains all registered struct clockdomains */
diff --git a/arch/arm/mach-omap2/clockdomain.h b/arch/arm/mach-omap2/clockdomain.h
new file mode 100644
index 000000000000..372c64669868
--- /dev/null
+++ b/arch/arm/mach-omap2/clockdomain.h
@@ -0,0 +1,149 @@
1/*
2 * arch/arm/plat-omap/include/mach/clockdomain.h
3 *
4 * OMAP2/3 clockdomain framework functions
5 *
6 * Copyright (C) 2008 Texas Instruments, Inc.
7 * Copyright (C) 2008-2010 Nokia Corporation
8 *
9 * Paul Walmsley
10 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License version 2 as
13 * published by the Free Software Foundation.
14 */
15
16#ifndef __ARCH_ARM_MACH_OMAP2_CLOCKDOMAIN_H
17#define __ARCH_ARM_MACH_OMAP2_CLOCKDOMAIN_H
18
19#include <linux/init.h>
20
21#include <plat/powerdomain.h>
22#include <plat/clock.h>
23#include <plat/cpu.h>
24
25/* Clockdomain capability flags */
26#define CLKDM_CAN_FORCE_SLEEP (1 << 0)
27#define CLKDM_CAN_FORCE_WAKEUP (1 << 1)
28#define CLKDM_CAN_ENABLE_AUTO (1 << 2)
29#define CLKDM_CAN_DISABLE_AUTO (1 << 3)
30
31#define CLKDM_CAN_HWSUP (CLKDM_CAN_ENABLE_AUTO | CLKDM_CAN_DISABLE_AUTO)
32#define CLKDM_CAN_SWSUP (CLKDM_CAN_FORCE_SLEEP | CLKDM_CAN_FORCE_WAKEUP)
33#define CLKDM_CAN_HWSUP_SWSUP (CLKDM_CAN_SWSUP | CLKDM_CAN_HWSUP)
34
35/**
36 * struct clkdm_autodep - clkdm deps to add when entering/exiting hwsup mode
37 * @clkdm: clockdomain to add wkdep+sleepdep on - set name member only
38 * @omap_chip: OMAP chip types that this autodep is valid on
39 *
40 * A clockdomain that should have wkdeps and sleepdeps added when a
41 * clockdomain should stay active in hwsup mode; and conversely,
42 * removed when the clockdomain should be allowed to go inactive in
43 * hwsup mode.
44 *
45 * Autodeps are deprecated and should be removed after
46 * omap_hwmod-based fine-grained module idle control is added.
47 */
48struct clkdm_autodep {
49 union {
50 const char *name;
51 struct clockdomain *ptr;
52 } clkdm;
53 const struct omap_chip_id omap_chip;
54};
55
56/**
57 * struct clkdm_dep - encode dependencies between clockdomains
58 * @clkdm_name: clockdomain name
59 * @clkdm: pointer to the struct clockdomain of @clkdm_name
60 * @omap_chip: OMAP chip types that this dependency is valid on
61 * @wkdep_usecount: Number of wakeup dependencies causing this clkdm to wake
62 * @sleepdep_usecount: Number of sleep deps that could prevent clkdm from idle
63 *
64 * Statically defined. @clkdm is resolved from @clkdm_name at runtime and
65 * should not be pre-initialized.
66 *
67 * XXX Should also include hardware (fixed) dependencies.
68 */
69struct clkdm_dep {
70 const char *clkdm_name;
71 struct clockdomain *clkdm;
72 atomic_t wkdep_usecount;
73 atomic_t sleepdep_usecount;
74 const struct omap_chip_id omap_chip;
75};
76
77/**
78 * struct clockdomain - OMAP clockdomain
79 * @name: clockdomain name
80 * @pwrdm: powerdomain containing this clockdomain
81 * @clktrctrl_reg: CLKSTCTRL reg for the given clock domain
82 * @clktrctrl_mask: CLKTRCTRL/AUTOSTATE field mask in CM_CLKSTCTRL reg
83 * @flags: Clockdomain capability flags
84 * @dep_bit: Bit shift of this clockdomain's PM_WKDEP/CM_SLEEPDEP bit
85 * @prcm_partition: (OMAP4 only) PRCM partition ID for this clkdm's registers
86 * @cm_inst: (OMAP4 only) CM instance register offset
87 * @clkdm_offs: (OMAP4 only) CM clockdomain register offset
88 * @wkdep_srcs: Clockdomains that can be told to wake this powerdomain up
89 * @sleepdep_srcs: Clockdomains that can be told to keep this clkdm from inact
90 * @omap_chip: OMAP chip types that this clockdomain is valid on
91 * @usecount: Usecount tracking
92 * @node: list_head to link all clockdomains together
93 *
94 * @prcm_partition should be a macro from mach-omap2/prcm44xx.h (OMAP4 only)
95 * @cm_inst should be a macro ending in _INST from the OMAP4 CM instance
96 * definitions (OMAP4 only)
97 * @clkdm_offs should be a macro ending in _CDOFFS from the OMAP4 CM instance
98 * definitions (OMAP4 only)
99 */
100struct clockdomain {
101 const char *name;
102 union {
103 const char *name;
104 struct powerdomain *ptr;
105 } pwrdm;
106#if defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3)
107 const u16 clktrctrl_mask;
108#endif
109 const u8 flags;
110 const u8 dep_bit;
111 const u8 prcm_partition;
112 const s16 cm_inst;
113 const u16 clkdm_offs;
114 struct clkdm_dep *wkdep_srcs;
115 struct clkdm_dep *sleepdep_srcs;
116 const struct omap_chip_id omap_chip;
117 atomic_t usecount;
118 struct list_head node;
119};
120
121void clkdm_init(struct clockdomain **clkdms, struct clkdm_autodep *autodeps);
122struct clockdomain *clkdm_lookup(const char *name);
123
124int clkdm_for_each(int (*fn)(struct clockdomain *clkdm, void *user),
125 void *user);
126struct powerdomain *clkdm_get_pwrdm(struct clockdomain *clkdm);
127
128int clkdm_add_wkdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2);
129int clkdm_del_wkdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2);
130int clkdm_read_wkdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2);
131int clkdm_clear_all_wkdeps(struct clockdomain *clkdm);
132int clkdm_add_sleepdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2);
133int clkdm_del_sleepdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2);
134int clkdm_read_sleepdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2);
135int clkdm_clear_all_sleepdeps(struct clockdomain *clkdm);
136
137void omap2_clkdm_allow_idle(struct clockdomain *clkdm);
138void omap2_clkdm_deny_idle(struct clockdomain *clkdm);
139
140int omap2_clkdm_wakeup(struct clockdomain *clkdm);
141int omap2_clkdm_sleep(struct clockdomain *clkdm);
142
143int omap2_clkdm_clk_enable(struct clockdomain *clkdm, struct clk *clk);
144int omap2_clkdm_clk_disable(struct clockdomain *clkdm, struct clk *clk);
145
146extern void __init omap2_clockdomains_init(void);
147extern void __init omap44xx_clockdomains_init(void);
148
149#endif
diff --git a/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c b/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c
index 6e9ec49d637f..e4a7133ea3b3 100644
--- a/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c
+++ b/arch/arm/mach-omap2/clockdomains2xxx_3xxx_data.c
@@ -35,7 +35,7 @@
35#include <linux/kernel.h> 35#include <linux/kernel.h>
36#include <linux/io.h> 36#include <linux/io.h>
37 37
38#include <plat/clockdomain.h> 38#include "clockdomain.h"
39#include "prm2xxx_3xxx.h" 39#include "prm2xxx_3xxx.h"
40#include "cm2xxx_3xxx.h" 40#include "cm2xxx_3xxx.h"
41#include "cm-regbits-24xx.h" 41#include "cm-regbits-24xx.h"
diff --git a/arch/arm/mach-omap2/clockdomains44xx_data.c b/arch/arm/mach-omap2/clockdomains44xx_data.c
index 2d3d1ef23814..51920fc7fc52 100644
--- a/arch/arm/mach-omap2/clockdomains44xx_data.c
+++ b/arch/arm/mach-omap2/clockdomains44xx_data.c
@@ -26,7 +26,7 @@
26#include <linux/kernel.h> 26#include <linux/kernel.h>
27#include <linux/io.h> 27#include <linux/io.h>
28 28
29#include <plat/clockdomain.h> 29#include "clockdomain.h"
30#include "cm1_44xx.h" 30#include "cm1_44xx.h"
31#include "cm2_44xx.h" 31#include "cm2_44xx.h"
32 32
diff --git a/arch/arm/mach-omap2/cpuidle34xx.c b/arch/arm/mach-omap2/cpuidle34xx.c
index 0fb619c52588..f518270b3e83 100644
--- a/arch/arm/mach-omap2/cpuidle34xx.c
+++ b/arch/arm/mach-omap2/cpuidle34xx.c
@@ -28,7 +28,7 @@
28#include <plat/prcm.h> 28#include <plat/prcm.h>
29#include <plat/irqs.h> 29#include <plat/irqs.h>
30#include <plat/powerdomain.h> 30#include <plat/powerdomain.h>
31#include <plat/clockdomain.h> 31#include "clockdomain.h"
32#include <plat/serial.h> 32#include <plat/serial.h>
33 33
34#include "pm.h" 34#include "pm.h"
diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c
index ba766576e03e..545182d9faa6 100644
--- a/arch/arm/mach-omap2/io.c
+++ b/arch/arm/mach-omap2/io.c
@@ -41,7 +41,7 @@
41#include <plat/omap-pm.h> 41#include <plat/omap-pm.h>
42#include <plat/powerdomain.h> 42#include <plat/powerdomain.h>
43 43
44#include <plat/clockdomain.h> 44#include "clockdomain.h"
45#include <plat/omap_hwmod.h> 45#include <plat/omap_hwmod.h>
46#include <plat/multi.h> 46#include <plat/multi.h>
47 47
diff --git a/arch/arm/mach-omap2/omap_hwmod.c b/arch/arm/mach-omap2/omap_hwmod.c
index 1312ce2913a5..e1358ba51395 100644
--- a/arch/arm/mach-omap2/omap_hwmod.c
+++ b/arch/arm/mach-omap2/omap_hwmod.c
@@ -139,7 +139,7 @@
139 139
140#include <plat/common.h> 140#include <plat/common.h>
141#include <plat/cpu.h> 141#include <plat/cpu.h>
142#include <plat/clockdomain.h> 142#include "clockdomain.h"
143#include <plat/powerdomain.h> 143#include <plat/powerdomain.h>
144#include <plat/clock.h> 144#include <plat/clock.h>
145#include <plat/omap_hwmod.h> 145#include <plat/omap_hwmod.h>
diff --git a/arch/arm/mach-omap2/pm-debug.c b/arch/arm/mach-omap2/pm-debug.c
index 1a4efb5e435a..3f989896a36c 100644
--- a/arch/arm/mach-omap2/pm-debug.c
+++ b/arch/arm/mach-omap2/pm-debug.c
@@ -30,7 +30,7 @@
30#include <plat/clock.h> 30#include <plat/clock.h>
31#include <plat/board.h> 31#include <plat/board.h>
32#include <plat/powerdomain.h> 32#include <plat/powerdomain.h>
33#include <plat/clockdomain.h> 33#include "clockdomain.h"
34#include <plat/dmtimer.h> 34#include <plat/dmtimer.h>
35 35
36#include "cm2xxx_3xxx.h" 36#include "cm2xxx_3xxx.h"
diff --git a/arch/arm/mach-omap2/pm.c b/arch/arm/mach-omap2/pm.c
index 6ec2ee12272a..24228e9dd496 100644
--- a/arch/arm/mach-omap2/pm.c
+++ b/arch/arm/mach-omap2/pm.c
@@ -19,7 +19,7 @@
19#include <plat/common.h> 19#include <plat/common.h>
20 20
21#include <plat/powerdomain.h> 21#include <plat/powerdomain.h>
22#include <plat/clockdomain.h> 22#include "clockdomain.h"
23 23
24static struct omap_device_pm_latency *pm_lats; 24static struct omap_device_pm_latency *pm_lats;
25 25
diff --git a/arch/arm/mach-omap2/pm24xx.c b/arch/arm/mach-omap2/pm24xx.c
index bf0c36b239f9..f6aef7687b8a 100644
--- a/arch/arm/mach-omap2/pm24xx.c
+++ b/arch/arm/mach-omap2/pm24xx.c
@@ -51,7 +51,7 @@
51#include "control.h" 51#include "control.h"
52 52
53#include <plat/powerdomain.h> 53#include <plat/powerdomain.h>
54#include <plat/clockdomain.h> 54#include "clockdomain.h"
55 55
56#ifdef CONFIG_SUSPEND 56#ifdef CONFIG_SUSPEND
57static suspend_state_t suspend_state = PM_SUSPEND_ON; 57static suspend_state_t suspend_state = PM_SUSPEND_ON;
diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c
index 1ca6ef4c25b3..0fae3d6b76e8 100644
--- a/arch/arm/mach-omap2/pm34xx.c
+++ b/arch/arm/mach-omap2/pm34xx.c
@@ -31,7 +31,7 @@
31#include <linux/console.h> 31#include <linux/console.h>
32 32
33#include <plat/sram.h> 33#include <plat/sram.h>
34#include <plat/clockdomain.h> 34#include "clockdomain.h"
35#include <plat/powerdomain.h> 35#include <plat/powerdomain.h>
36#include <plat/serial.h> 36#include <plat/serial.h>
37#include <plat/sdrc.h> 37#include <plat/sdrc.h>
diff --git a/arch/arm/mach-omap2/powerdomain.c b/arch/arm/mach-omap2/powerdomain.c
index a76ad3f0ca65..7eb7ba49d6bf 100644
--- a/arch/arm/mach-omap2/powerdomain.c
+++ b/arch/arm/mach-omap2/powerdomain.c
@@ -27,7 +27,7 @@
27 27
28#include <plat/cpu.h> 28#include <plat/cpu.h>
29#include <plat/powerdomain.h> 29#include <plat/powerdomain.h>
30#include <plat/clockdomain.h> 30#include "clockdomain.h"
31#include <plat/prcm.h> 31#include <plat/prcm.h>
32 32
33#include "pm.h" 33#include "pm.h"