diff options
author | Russell King <rmk@dyn-67.arm.linux.org.uk> | 2009-01-31 05:05:51 -0500 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2009-02-08 12:50:42 -0500 |
commit | 3f0a820c4c0b4670fb5f164baa5582e23c2ef118 (patch) | |
tree | 6af02e1456c0316791ab95e7da9c09496f29c232 | |
parent | b5088c0d90b898802318c62caf2320a53df6ce57 (diff) |
[ARM] omap: create a proper tree of clocks
Traditionally, we've tracked the parent/child relationships between
clk structures by setting the child's parent member to point at the
upstream clock. As a result, when decending the tree, we have had
to scan all clocks to find the children.
Avoid this wasteful scanning by keeping a list of the clock's children.
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
-rw-r--r-- | arch/arm/mach-omap1/clock.c | 3 | ||||
-rw-r--r-- | arch/arm/mach-omap1/clock.h | 7 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clock.c | 4 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clock24xx.c | 3 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clock24xx.h | 28 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clock34xx.c | 3 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clock34xx.h | 96 | ||||
-rw-r--r-- | arch/arm/plat-omap/clock.c | 51 | ||||
-rw-r--r-- | arch/arm/plat-omap/include/mach/clock.h | 7 |
9 files changed, 74 insertions, 128 deletions
diff --git a/arch/arm/mach-omap1/clock.c b/arch/arm/mach-omap1/clock.c index 1e477af666ee..ccf989f4aa7d 100644 --- a/arch/arm/mach-omap1/clock.c +++ b/arch/arm/mach-omap1/clock.c | |||
@@ -782,6 +782,9 @@ int __init omap1_clk_init(void) | |||
782 | /* By default all idlect1 clocks are allowed to idle */ | 782 | /* By default all idlect1 clocks are allowed to idle */ |
783 | arm_idlect1_mask = ~0; | 783 | arm_idlect1_mask = ~0; |
784 | 784 | ||
785 | for (c = omap_clks; c < omap_clks + ARRAY_SIZE(omap_clks); c++) | ||
786 | clk_init_one(c->lk.clk); | ||
787 | |||
785 | cpu_mask = 0; | 788 | cpu_mask = 0; |
786 | if (cpu_is_omap16xx()) | 789 | if (cpu_is_omap16xx()) |
787 | cpu_mask |= CK_16XX; | 790 | cpu_mask |= CK_16XX; |
diff --git a/arch/arm/mach-omap1/clock.h b/arch/arm/mach-omap1/clock.h index 1b4dd056d9bd..28bc74e93e8d 100644 --- a/arch/arm/mach-omap1/clock.h +++ b/arch/arm/mach-omap1/clock.h | |||
@@ -155,7 +155,6 @@ static struct clk ck_dpll1 = { | |||
155 | .name = "ck_dpll1", | 155 | .name = "ck_dpll1", |
156 | .ops = &clkops_null, | 156 | .ops = &clkops_null, |
157 | .parent = &ck_ref, | 157 | .parent = &ck_ref, |
158 | .flags = RATE_PROPAGATES, | ||
159 | }; | 158 | }; |
160 | 159 | ||
161 | static struct arm_idlect1_clk ck_dpll1out = { | 160 | static struct arm_idlect1_clk ck_dpll1out = { |
@@ -163,8 +162,7 @@ static struct arm_idlect1_clk ck_dpll1out = { | |||
163 | .name = "ck_dpll1out", | 162 | .name = "ck_dpll1out", |
164 | .ops = &clkops_generic, | 163 | .ops = &clkops_generic, |
165 | .parent = &ck_dpll1, | 164 | .parent = &ck_dpll1, |
166 | .flags = CLOCK_IDLE_CONTROL | | 165 | .flags = CLOCK_IDLE_CONTROL | ENABLE_REG_32BIT, |
167 | ENABLE_REG_32BIT | RATE_PROPAGATES, | ||
168 | .enable_reg = OMAP1_IO_ADDRESS(ARM_IDLECT2), | 166 | .enable_reg = OMAP1_IO_ADDRESS(ARM_IDLECT2), |
169 | .enable_bit = EN_CKOUT_ARM, | 167 | .enable_bit = EN_CKOUT_ARM, |
170 | .recalc = &followparent_recalc, | 168 | .recalc = &followparent_recalc, |
@@ -187,7 +185,6 @@ static struct clk arm_ck = { | |||
187 | .name = "arm_ck", | 185 | .name = "arm_ck", |
188 | .ops = &clkops_null, | 186 | .ops = &clkops_null, |
189 | .parent = &ck_dpll1, | 187 | .parent = &ck_dpll1, |
190 | .flags = RATE_PROPAGATES, | ||
191 | .rate_offset = CKCTL_ARMDIV_OFFSET, | 188 | .rate_offset = CKCTL_ARMDIV_OFFSET, |
192 | .recalc = &omap1_ckctl_recalc, | 189 | .recalc = &omap1_ckctl_recalc, |
193 | .round_rate = omap1_clk_round_rate_ckctl_arm, | 190 | .round_rate = omap1_clk_round_rate_ckctl_arm, |
@@ -328,7 +325,7 @@ static struct arm_idlect1_clk tc_ck = { | |||
328 | .name = "tc_ck", | 325 | .name = "tc_ck", |
329 | .ops = &clkops_null, | 326 | .ops = &clkops_null, |
330 | .parent = &ck_dpll1, | 327 | .parent = &ck_dpll1, |
331 | .flags = RATE_PROPAGATES | CLOCK_IDLE_CONTROL, | 328 | .flags = CLOCK_IDLE_CONTROL, |
332 | .rate_offset = CKCTL_TCDIV_OFFSET, | 329 | .rate_offset = CKCTL_TCDIV_OFFSET, |
333 | .recalc = &omap1_ckctl_recalc, | 330 | .recalc = &omap1_ckctl_recalc, |
334 | .round_rate = omap1_clk_round_rate_ckctl_arm, | 331 | .round_rate = omap1_clk_round_rate_ckctl_arm, |
diff --git a/arch/arm/mach-omap2/clock.c b/arch/arm/mach-omap2/clock.c index 478ca660fffd..38a7898d0ce3 100644 --- a/arch/arm/mach-omap2/clock.c +++ b/arch/arm/mach-omap2/clock.c | |||
@@ -175,7 +175,7 @@ void omap2_init_clksel_parent(struct clk *clk) | |||
175 | clk->name, clks->parent->name, | 175 | clk->name, clks->parent->name, |
176 | ((clk->parent) ? | 176 | ((clk->parent) ? |
177 | clk->parent->name : "NULL")); | 177 | clk->parent->name : "NULL")); |
178 | clk->parent = clks->parent; | 178 | clk_reparent(clk, clks->parent); |
179 | }; | 179 | }; |
180 | found = 1; | 180 | found = 1; |
181 | } | 181 | } |
@@ -780,7 +780,7 @@ int omap2_clk_set_parent(struct clk *clk, struct clk *new_parent) | |||
780 | if (clk->usecount > 0) | 780 | if (clk->usecount > 0) |
781 | _omap2_clk_enable(clk); | 781 | _omap2_clk_enable(clk); |
782 | 782 | ||
783 | clk->parent = new_parent; | 783 | clk_reparent(clk, new_parent); |
784 | 784 | ||
785 | /* CLKSEL clocks follow their parents' rates, divided by a divisor */ | 785 | /* CLKSEL clocks follow their parents' rates, divided by a divisor */ |
786 | clk->rate = new_parent->rate; | 786 | clk->rate = new_parent->rate; |
diff --git a/arch/arm/mach-omap2/clock24xx.c b/arch/arm/mach-omap2/clock24xx.c index 4564ae32ae02..1a885976c257 100644 --- a/arch/arm/mach-omap2/clock24xx.c +++ b/arch/arm/mach-omap2/clock24xx.c | |||
@@ -718,6 +718,9 @@ int __init omap2_clk_init(void) | |||
718 | omap2_sys_clk_recalc(&sys_ck); | 718 | omap2_sys_clk_recalc(&sys_ck); |
719 | propagate_rate(&sys_ck); | 719 | propagate_rate(&sys_ck); |
720 | 720 | ||
721 | for (c = omap24xx_clks; c < omap24xx_clks + ARRAY_SIZE(omap24xx_clks); c++) | ||
722 | clk_init_one(c->lk.clk); | ||
723 | |||
721 | cpu_mask = 0; | 724 | cpu_mask = 0; |
722 | if (cpu_is_omap2420()) | 725 | if (cpu_is_omap2420()) |
723 | cpu_mask |= CK_242X; | 726 | cpu_mask |= CK_242X; |
diff --git a/arch/arm/mach-omap2/clock24xx.h b/arch/arm/mach-omap2/clock24xx.h index 7731ab6acd18..759489822ee9 100644 --- a/arch/arm/mach-omap2/clock24xx.h +++ b/arch/arm/mach-omap2/clock24xx.h | |||
@@ -621,7 +621,7 @@ static struct clk func_32k_ck = { | |||
621 | .name = "func_32k_ck", | 621 | .name = "func_32k_ck", |
622 | .ops = &clkops_null, | 622 | .ops = &clkops_null, |
623 | .rate = 32000, | 623 | .rate = 32000, |
624 | .flags = RATE_FIXED | RATE_PROPAGATES, | 624 | .flags = RATE_FIXED, |
625 | .clkdm_name = "wkup_clkdm", | 625 | .clkdm_name = "wkup_clkdm", |
626 | }; | 626 | }; |
627 | 627 | ||
@@ -629,7 +629,6 @@ static struct clk func_32k_ck = { | |||
629 | static struct clk osc_ck = { /* (*12, *13, 19.2, *26, 38.4)MHz */ | 629 | static struct clk osc_ck = { /* (*12, *13, 19.2, *26, 38.4)MHz */ |
630 | .name = "osc_ck", | 630 | .name = "osc_ck", |
631 | .ops = &clkops_oscck, | 631 | .ops = &clkops_oscck, |
632 | .flags = RATE_PROPAGATES, | ||
633 | .clkdm_name = "wkup_clkdm", | 632 | .clkdm_name = "wkup_clkdm", |
634 | .recalc = &omap2_osc_clk_recalc, | 633 | .recalc = &omap2_osc_clk_recalc, |
635 | }; | 634 | }; |
@@ -639,7 +638,6 @@ static struct clk sys_ck = { /* (*12, *13, 19.2, 26, 38.4)MHz */ | |||
639 | .name = "sys_ck", /* ~ ref_clk also */ | 638 | .name = "sys_ck", /* ~ ref_clk also */ |
640 | .ops = &clkops_null, | 639 | .ops = &clkops_null, |
641 | .parent = &osc_ck, | 640 | .parent = &osc_ck, |
642 | .flags = RATE_PROPAGATES, | ||
643 | .clkdm_name = "wkup_clkdm", | 641 | .clkdm_name = "wkup_clkdm", |
644 | .recalc = &omap2_sys_clk_recalc, | 642 | .recalc = &omap2_sys_clk_recalc, |
645 | }; | 643 | }; |
@@ -648,7 +646,7 @@ static struct clk alt_ck = { /* Typical 54M or 48M, may not exist */ | |||
648 | .name = "alt_ck", | 646 | .name = "alt_ck", |
649 | .ops = &clkops_null, | 647 | .ops = &clkops_null, |
650 | .rate = 54000000, | 648 | .rate = 54000000, |
651 | .flags = RATE_FIXED | RATE_PROPAGATES, | 649 | .flags = RATE_FIXED, |
652 | .clkdm_name = "wkup_clkdm", | 650 | .clkdm_name = "wkup_clkdm", |
653 | }; | 651 | }; |
654 | 652 | ||
@@ -680,7 +678,6 @@ static struct clk dpll_ck = { | |||
680 | .ops = &clkops_null, | 678 | .ops = &clkops_null, |
681 | .parent = &sys_ck, /* Can be func_32k also */ | 679 | .parent = &sys_ck, /* Can be func_32k also */ |
682 | .dpll_data = &dpll_dd, | 680 | .dpll_data = &dpll_dd, |
683 | .flags = RATE_PROPAGATES, | ||
684 | .clkdm_name = "wkup_clkdm", | 681 | .clkdm_name = "wkup_clkdm", |
685 | .recalc = &omap2_dpllcore_recalc, | 682 | .recalc = &omap2_dpllcore_recalc, |
686 | .set_rate = &omap2_reprogram_dpllcore, | 683 | .set_rate = &omap2_reprogram_dpllcore, |
@@ -691,7 +688,7 @@ static struct clk apll96_ck = { | |||
691 | .ops = &clkops_fixed, | 688 | .ops = &clkops_fixed, |
692 | .parent = &sys_ck, | 689 | .parent = &sys_ck, |
693 | .rate = 96000000, | 690 | .rate = 96000000, |
694 | .flags = RATE_FIXED | RATE_PROPAGATES | ENABLE_ON_INIT, | 691 | .flags = RATE_FIXED | ENABLE_ON_INIT, |
695 | .clkdm_name = "wkup_clkdm", | 692 | .clkdm_name = "wkup_clkdm", |
696 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 693 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
697 | .enable_bit = OMAP24XX_EN_96M_PLL_SHIFT, | 694 | .enable_bit = OMAP24XX_EN_96M_PLL_SHIFT, |
@@ -702,7 +699,7 @@ static struct clk apll54_ck = { | |||
702 | .ops = &clkops_fixed, | 699 | .ops = &clkops_fixed, |
703 | .parent = &sys_ck, | 700 | .parent = &sys_ck, |
704 | .rate = 54000000, | 701 | .rate = 54000000, |
705 | .flags = RATE_FIXED | RATE_PROPAGATES | ENABLE_ON_INIT, | 702 | .flags = RATE_FIXED | ENABLE_ON_INIT, |
706 | .clkdm_name = "wkup_clkdm", | 703 | .clkdm_name = "wkup_clkdm", |
707 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 704 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
708 | .enable_bit = OMAP24XX_EN_54M_PLL_SHIFT, | 705 | .enable_bit = OMAP24XX_EN_54M_PLL_SHIFT, |
@@ -734,7 +731,6 @@ static struct clk func_54m_ck = { | |||
734 | .name = "func_54m_ck", | 731 | .name = "func_54m_ck", |
735 | .ops = &clkops_null, | 732 | .ops = &clkops_null, |
736 | .parent = &apll54_ck, /* can also be alt_clk */ | 733 | .parent = &apll54_ck, /* can also be alt_clk */ |
737 | .flags = RATE_PROPAGATES, | ||
738 | .clkdm_name = "wkup_clkdm", | 734 | .clkdm_name = "wkup_clkdm", |
739 | .init = &omap2_init_clksel_parent, | 735 | .init = &omap2_init_clksel_parent, |
740 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | 736 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), |
@@ -747,7 +743,6 @@ static struct clk core_ck = { | |||
747 | .name = "core_ck", | 743 | .name = "core_ck", |
748 | .ops = &clkops_null, | 744 | .ops = &clkops_null, |
749 | .parent = &dpll_ck, /* can also be 32k */ | 745 | .parent = &dpll_ck, /* can also be 32k */ |
750 | .flags = RATE_PROPAGATES, | ||
751 | .clkdm_name = "wkup_clkdm", | 746 | .clkdm_name = "wkup_clkdm", |
752 | .recalc = &followparent_recalc, | 747 | .recalc = &followparent_recalc, |
753 | }; | 748 | }; |
@@ -774,7 +769,6 @@ static struct clk func_96m_ck = { | |||
774 | .name = "func_96m_ck", | 769 | .name = "func_96m_ck", |
775 | .ops = &clkops_null, | 770 | .ops = &clkops_null, |
776 | .parent = &apll96_ck, | 771 | .parent = &apll96_ck, |
777 | .flags = RATE_PROPAGATES, | ||
778 | .clkdm_name = "wkup_clkdm", | 772 | .clkdm_name = "wkup_clkdm", |
779 | .init = &omap2_init_clksel_parent, | 773 | .init = &omap2_init_clksel_parent, |
780 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | 774 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), |
@@ -807,7 +801,6 @@ static struct clk func_48m_ck = { | |||
807 | .name = "func_48m_ck", | 801 | .name = "func_48m_ck", |
808 | .ops = &clkops_null, | 802 | .ops = &clkops_null, |
809 | .parent = &apll96_ck, /* 96M or Alt */ | 803 | .parent = &apll96_ck, /* 96M or Alt */ |
810 | .flags = RATE_PROPAGATES, | ||
811 | .clkdm_name = "wkup_clkdm", | 804 | .clkdm_name = "wkup_clkdm", |
812 | .init = &omap2_init_clksel_parent, | 805 | .init = &omap2_init_clksel_parent, |
813 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | 806 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), |
@@ -823,7 +816,6 @@ static struct clk func_12m_ck = { | |||
823 | .ops = &clkops_null, | 816 | .ops = &clkops_null, |
824 | .parent = &func_48m_ck, | 817 | .parent = &func_48m_ck, |
825 | .fixed_div = 4, | 818 | .fixed_div = 4, |
826 | .flags = RATE_PROPAGATES, | ||
827 | .clkdm_name = "wkup_clkdm", | 819 | .clkdm_name = "wkup_clkdm", |
828 | .recalc = &omap2_fixed_divisor_recalc, | 820 | .recalc = &omap2_fixed_divisor_recalc, |
829 | }; | 821 | }; |
@@ -876,7 +868,6 @@ static struct clk sys_clkout_src = { | |||
876 | .name = "sys_clkout_src", | 868 | .name = "sys_clkout_src", |
877 | .ops = &clkops_omap2_dflt, | 869 | .ops = &clkops_omap2_dflt, |
878 | .parent = &func_54m_ck, | 870 | .parent = &func_54m_ck, |
879 | .flags = RATE_PROPAGATES, | ||
880 | .clkdm_name = "wkup_clkdm", | 871 | .clkdm_name = "wkup_clkdm", |
881 | .enable_reg = OMAP24XX_PRCM_CLKOUT_CTRL, | 872 | .enable_reg = OMAP24XX_PRCM_CLKOUT_CTRL, |
882 | .enable_bit = OMAP24XX_CLKOUT_EN_SHIFT, | 873 | .enable_bit = OMAP24XX_CLKOUT_EN_SHIFT, |
@@ -921,7 +912,6 @@ static struct clk sys_clkout2_src = { | |||
921 | .name = "sys_clkout2_src", | 912 | .name = "sys_clkout2_src", |
922 | .ops = &clkops_omap2_dflt, | 913 | .ops = &clkops_omap2_dflt, |
923 | .parent = &func_54m_ck, | 914 | .parent = &func_54m_ck, |
924 | .flags = RATE_PROPAGATES, | ||
925 | .clkdm_name = "wkup_clkdm", | 915 | .clkdm_name = "wkup_clkdm", |
926 | .enable_reg = OMAP24XX_PRCM_CLKOUT_CTRL, | 916 | .enable_reg = OMAP24XX_PRCM_CLKOUT_CTRL, |
927 | .enable_bit = OMAP2420_CLKOUT2_EN_SHIFT, | 917 | .enable_bit = OMAP2420_CLKOUT2_EN_SHIFT, |
@@ -992,7 +982,7 @@ static struct clk mpu_ck = { /* Control cpu */ | |||
992 | .name = "mpu_ck", | 982 | .name = "mpu_ck", |
993 | .ops = &clkops_null, | 983 | .ops = &clkops_null, |
994 | .parent = &core_ck, | 984 | .parent = &core_ck, |
995 | .flags = DELAYED_APP | CONFIG_PARTICIPANT | RATE_PROPAGATES, | 985 | .flags = DELAYED_APP | CONFIG_PARTICIPANT, |
996 | .clkdm_name = "mpu_clkdm", | 986 | .clkdm_name = "mpu_clkdm", |
997 | .init = &omap2_init_clksel_parent, | 987 | .init = &omap2_init_clksel_parent, |
998 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, CM_CLKSEL), | 988 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, CM_CLKSEL), |
@@ -1034,7 +1024,7 @@ static struct clk dsp_fck = { | |||
1034 | .name = "dsp_fck", | 1024 | .name = "dsp_fck", |
1035 | .ops = &clkops_omap2_dflt_wait, | 1025 | .ops = &clkops_omap2_dflt_wait, |
1036 | .parent = &core_ck, | 1026 | .parent = &core_ck, |
1037 | .flags = DELAYED_APP | CONFIG_PARTICIPANT | RATE_PROPAGATES, | 1027 | .flags = DELAYED_APP | CONFIG_PARTICIPANT, |
1038 | .clkdm_name = "dsp_clkdm", | 1028 | .clkdm_name = "dsp_clkdm", |
1039 | .enable_reg = OMAP_CM_REGADDR(OMAP24XX_DSP_MOD, CM_FCLKEN), | 1029 | .enable_reg = OMAP_CM_REGADDR(OMAP24XX_DSP_MOD, CM_FCLKEN), |
1040 | .enable_bit = OMAP24XX_CM_FCLKEN_DSP_EN_DSP_SHIFT, | 1030 | .enable_bit = OMAP24XX_CM_FCLKEN_DSP_EN_DSP_SHIFT, |
@@ -1102,7 +1092,7 @@ static struct clk iva1_ifck = { | |||
1102 | .name = "iva1_ifck", | 1092 | .name = "iva1_ifck", |
1103 | .ops = &clkops_omap2_dflt_wait, | 1093 | .ops = &clkops_omap2_dflt_wait, |
1104 | .parent = &core_ck, | 1094 | .parent = &core_ck, |
1105 | .flags = CONFIG_PARTICIPANT | RATE_PROPAGATES | DELAYED_APP, | 1095 | .flags = CONFIG_PARTICIPANT | DELAYED_APP, |
1106 | .clkdm_name = "iva1_clkdm", | 1096 | .clkdm_name = "iva1_clkdm", |
1107 | .enable_reg = OMAP_CM_REGADDR(OMAP24XX_DSP_MOD, CM_FCLKEN), | 1097 | .enable_reg = OMAP_CM_REGADDR(OMAP24XX_DSP_MOD, CM_FCLKEN), |
1108 | .enable_bit = OMAP2420_EN_IVA_COP_SHIFT, | 1098 | .enable_bit = OMAP2420_EN_IVA_COP_SHIFT, |
@@ -1165,7 +1155,7 @@ static struct clk core_l3_ck = { /* Used for ick and fck, interconnect */ | |||
1165 | .name = "core_l3_ck", | 1155 | .name = "core_l3_ck", |
1166 | .ops = &clkops_null, | 1156 | .ops = &clkops_null, |
1167 | .parent = &core_ck, | 1157 | .parent = &core_ck, |
1168 | .flags = DELAYED_APP | CONFIG_PARTICIPANT | RATE_PROPAGATES, | 1158 | .flags = DELAYED_APP | CONFIG_PARTICIPANT, |
1169 | .clkdm_name = "core_l3_clkdm", | 1159 | .clkdm_name = "core_l3_clkdm", |
1170 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL1), | 1160 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL1), |
1171 | .clksel_mask = OMAP24XX_CLKSEL_L3_MASK, | 1161 | .clksel_mask = OMAP24XX_CLKSEL_L3_MASK, |
@@ -1227,7 +1217,7 @@ static struct clk l4_ck = { /* used both as an ick and fck */ | |||
1227 | .name = "l4_ck", | 1217 | .name = "l4_ck", |
1228 | .ops = &clkops_null, | 1218 | .ops = &clkops_null, |
1229 | .parent = &core_l3_ck, | 1219 | .parent = &core_l3_ck, |
1230 | .flags = DELAYED_APP | RATE_PROPAGATES, | 1220 | .flags = DELAYED_APP, |
1231 | .clkdm_name = "core_l4_clkdm", | 1221 | .clkdm_name = "core_l4_clkdm", |
1232 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL1), | 1222 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL1), |
1233 | .clksel_mask = OMAP24XX_CLKSEL_L4_MASK, | 1223 | .clksel_mask = OMAP24XX_CLKSEL_L4_MASK, |
diff --git a/arch/arm/mach-omap2/clock34xx.c b/arch/arm/mach-omap2/clock34xx.c index 75eb2546bb06..a853b1e149ee 100644 --- a/arch/arm/mach-omap2/clock34xx.c +++ b/arch/arm/mach-omap2/clock34xx.c | |||
@@ -904,6 +904,9 @@ int __init omap2_clk_init(void) | |||
904 | clk_init(&omap2_clk_functions); | 904 | clk_init(&omap2_clk_functions); |
905 | 905 | ||
906 | for (c = omap34xx_clks; c < omap34xx_clks + ARRAY_SIZE(omap34xx_clks); c++) | 906 | for (c = omap34xx_clks; c < omap34xx_clks + ARRAY_SIZE(omap34xx_clks); c++) |
907 | clk_init_one(c->lk.clk); | ||
908 | |||
909 | for (c = omap34xx_clks; c < omap34xx_clks + ARRAY_SIZE(omap34xx_clks); c++) | ||
907 | if (c->cpu & cpu_clkflg) { | 910 | if (c->cpu & cpu_clkflg) { |
908 | clkdev_add(&c->lk); | 911 | clkdev_add(&c->lk); |
909 | clk_register(c->lk.clk); | 912 | clk_register(c->lk.clk); |
diff --git a/arch/arm/mach-omap2/clock34xx.h b/arch/arm/mach-omap2/clock34xx.h index 681acf0427c1..2138a58f6346 100644 --- a/arch/arm/mach-omap2/clock34xx.h +++ b/arch/arm/mach-omap2/clock34xx.h | |||
@@ -60,14 +60,14 @@ static struct clk omap_32k_fck = { | |||
60 | .name = "omap_32k_fck", | 60 | .name = "omap_32k_fck", |
61 | .ops = &clkops_null, | 61 | .ops = &clkops_null, |
62 | .rate = 32768, | 62 | .rate = 32768, |
63 | .flags = RATE_FIXED | RATE_PROPAGATES, | 63 | .flags = RATE_FIXED, |
64 | }; | 64 | }; |
65 | 65 | ||
66 | static struct clk secure_32k_fck = { | 66 | static struct clk secure_32k_fck = { |
67 | .name = "secure_32k_fck", | 67 | .name = "secure_32k_fck", |
68 | .ops = &clkops_null, | 68 | .ops = &clkops_null, |
69 | .rate = 32768, | 69 | .rate = 32768, |
70 | .flags = RATE_FIXED | RATE_PROPAGATES, | 70 | .flags = RATE_FIXED, |
71 | }; | 71 | }; |
72 | 72 | ||
73 | /* Virtual source clocks for osc_sys_ck */ | 73 | /* Virtual source clocks for osc_sys_ck */ |
@@ -75,42 +75,42 @@ static struct clk virt_12m_ck = { | |||
75 | .name = "virt_12m_ck", | 75 | .name = "virt_12m_ck", |
76 | .ops = &clkops_null, | 76 | .ops = &clkops_null, |
77 | .rate = 12000000, | 77 | .rate = 12000000, |
78 | .flags = RATE_FIXED | RATE_PROPAGATES, | 78 | .flags = RATE_FIXED, |
79 | }; | 79 | }; |
80 | 80 | ||
81 | static struct clk virt_13m_ck = { | 81 | static struct clk virt_13m_ck = { |
82 | .name = "virt_13m_ck", | 82 | .name = "virt_13m_ck", |
83 | .ops = &clkops_null, | 83 | .ops = &clkops_null, |
84 | .rate = 13000000, | 84 | .rate = 13000000, |
85 | .flags = RATE_FIXED | RATE_PROPAGATES, | 85 | .flags = RATE_FIXED, |
86 | }; | 86 | }; |
87 | 87 | ||
88 | static struct clk virt_16_8m_ck = { | 88 | static struct clk virt_16_8m_ck = { |
89 | .name = "virt_16_8m_ck", | 89 | .name = "virt_16_8m_ck", |
90 | .ops = &clkops_null, | 90 | .ops = &clkops_null, |
91 | .rate = 16800000, | 91 | .rate = 16800000, |
92 | .flags = RATE_FIXED | RATE_PROPAGATES, | 92 | .flags = RATE_FIXED, |
93 | }; | 93 | }; |
94 | 94 | ||
95 | static struct clk virt_19_2m_ck = { | 95 | static struct clk virt_19_2m_ck = { |
96 | .name = "virt_19_2m_ck", | 96 | .name = "virt_19_2m_ck", |
97 | .ops = &clkops_null, | 97 | .ops = &clkops_null, |
98 | .rate = 19200000, | 98 | .rate = 19200000, |
99 | .flags = RATE_FIXED | RATE_PROPAGATES, | 99 | .flags = RATE_FIXED, |
100 | }; | 100 | }; |
101 | 101 | ||
102 | static struct clk virt_26m_ck = { | 102 | static struct clk virt_26m_ck = { |
103 | .name = "virt_26m_ck", | 103 | .name = "virt_26m_ck", |
104 | .ops = &clkops_null, | 104 | .ops = &clkops_null, |
105 | .rate = 26000000, | 105 | .rate = 26000000, |
106 | .flags = RATE_FIXED | RATE_PROPAGATES, | 106 | .flags = RATE_FIXED, |
107 | }; | 107 | }; |
108 | 108 | ||
109 | static struct clk virt_38_4m_ck = { | 109 | static struct clk virt_38_4m_ck = { |
110 | .name = "virt_38_4m_ck", | 110 | .name = "virt_38_4m_ck", |
111 | .ops = &clkops_null, | 111 | .ops = &clkops_null, |
112 | .rate = 38400000, | 112 | .rate = 38400000, |
113 | .flags = RATE_FIXED | RATE_PROPAGATES, | 113 | .flags = RATE_FIXED, |
114 | }; | 114 | }; |
115 | 115 | ||
116 | static const struct clksel_rate osc_sys_12m_rates[] = { | 116 | static const struct clksel_rate osc_sys_12m_rates[] = { |
@@ -163,7 +163,7 @@ static struct clk osc_sys_ck = { | |||
163 | .clksel_mask = OMAP3430_SYS_CLKIN_SEL_MASK, | 163 | .clksel_mask = OMAP3430_SYS_CLKIN_SEL_MASK, |
164 | .clksel = osc_sys_clksel, | 164 | .clksel = osc_sys_clksel, |
165 | /* REVISIT: deal with autoextclkmode? */ | 165 | /* REVISIT: deal with autoextclkmode? */ |
166 | .flags = RATE_FIXED | RATE_PROPAGATES, | 166 | .flags = RATE_FIXED, |
167 | .recalc = &omap2_clksel_recalc, | 167 | .recalc = &omap2_clksel_recalc, |
168 | }; | 168 | }; |
169 | 169 | ||
@@ -188,21 +188,18 @@ static struct clk sys_ck = { | |||
188 | .clksel_reg = OMAP3430_PRM_CLKSRC_CTRL, | 188 | .clksel_reg = OMAP3430_PRM_CLKSRC_CTRL, |
189 | .clksel_mask = OMAP_SYSCLKDIV_MASK, | 189 | .clksel_mask = OMAP_SYSCLKDIV_MASK, |
190 | .clksel = sys_clksel, | 190 | .clksel = sys_clksel, |
191 | .flags = RATE_PROPAGATES, | ||
192 | .recalc = &omap2_clksel_recalc, | 191 | .recalc = &omap2_clksel_recalc, |
193 | }; | 192 | }; |
194 | 193 | ||
195 | static struct clk sys_altclk = { | 194 | static struct clk sys_altclk = { |
196 | .name = "sys_altclk", | 195 | .name = "sys_altclk", |
197 | .ops = &clkops_null, | 196 | .ops = &clkops_null, |
198 | .flags = RATE_PROPAGATES, | ||
199 | }; | 197 | }; |
200 | 198 | ||
201 | /* Optional external clock input for some McBSPs */ | 199 | /* Optional external clock input for some McBSPs */ |
202 | static struct clk mcbsp_clks = { | 200 | static struct clk mcbsp_clks = { |
203 | .name = "mcbsp_clks", | 201 | .name = "mcbsp_clks", |
204 | .ops = &clkops_null, | 202 | .ops = &clkops_null, |
205 | .flags = RATE_PROPAGATES, | ||
206 | }; | 203 | }; |
207 | 204 | ||
208 | /* PRM EXTERNAL CLOCK OUTPUT */ | 205 | /* PRM EXTERNAL CLOCK OUTPUT */ |
@@ -279,7 +276,6 @@ static struct clk dpll1_ck = { | |||
279 | .ops = &clkops_null, | 276 | .ops = &clkops_null, |
280 | .parent = &sys_ck, | 277 | .parent = &sys_ck, |
281 | .dpll_data = &dpll1_dd, | 278 | .dpll_data = &dpll1_dd, |
282 | .flags = RATE_PROPAGATES, | ||
283 | .round_rate = &omap2_dpll_round_rate, | 279 | .round_rate = &omap2_dpll_round_rate, |
284 | .set_rate = &omap3_noncore_dpll_set_rate, | 280 | .set_rate = &omap3_noncore_dpll_set_rate, |
285 | .clkdm_name = "dpll1_clkdm", | 281 | .clkdm_name = "dpll1_clkdm", |
@@ -294,7 +290,6 @@ static struct clk dpll1_x2_ck = { | |||
294 | .name = "dpll1_x2_ck", | 290 | .name = "dpll1_x2_ck", |
295 | .ops = &clkops_null, | 291 | .ops = &clkops_null, |
296 | .parent = &dpll1_ck, | 292 | .parent = &dpll1_ck, |
297 | .flags = RATE_PROPAGATES, | ||
298 | .clkdm_name = "dpll1_clkdm", | 293 | .clkdm_name = "dpll1_clkdm", |
299 | .recalc = &omap3_clkoutx2_recalc, | 294 | .recalc = &omap3_clkoutx2_recalc, |
300 | }; | 295 | }; |
@@ -317,7 +312,6 @@ static struct clk dpll1_x2m2_ck = { | |||
317 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_CLKSEL2_PLL), | 312 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_CLKSEL2_PLL), |
318 | .clksel_mask = OMAP3430_MPU_DPLL_CLKOUT_DIV_MASK, | 313 | .clksel_mask = OMAP3430_MPU_DPLL_CLKOUT_DIV_MASK, |
319 | .clksel = div16_dpll1_x2m2_clksel, | 314 | .clksel = div16_dpll1_x2m2_clksel, |
320 | .flags = RATE_PROPAGATES, | ||
321 | .clkdm_name = "dpll1_clkdm", | 315 | .clkdm_name = "dpll1_clkdm", |
322 | .recalc = &omap2_clksel_recalc, | 316 | .recalc = &omap2_clksel_recalc, |
323 | }; | 317 | }; |
@@ -353,7 +347,6 @@ static struct clk dpll2_ck = { | |||
353 | .ops = &clkops_noncore_dpll_ops, | 347 | .ops = &clkops_noncore_dpll_ops, |
354 | .parent = &sys_ck, | 348 | .parent = &sys_ck, |
355 | .dpll_data = &dpll2_dd, | 349 | .dpll_data = &dpll2_dd, |
356 | .flags = RATE_PROPAGATES, | ||
357 | .round_rate = &omap2_dpll_round_rate, | 350 | .round_rate = &omap2_dpll_round_rate, |
358 | .set_rate = &omap3_noncore_dpll_set_rate, | 351 | .set_rate = &omap3_noncore_dpll_set_rate, |
359 | .clkdm_name = "dpll2_clkdm", | 352 | .clkdm_name = "dpll2_clkdm", |
@@ -378,7 +371,6 @@ static struct clk dpll2_m2_ck = { | |||
378 | OMAP3430_CM_CLKSEL2_PLL), | 371 | OMAP3430_CM_CLKSEL2_PLL), |
379 | .clksel_mask = OMAP3430_IVA2_DPLL_CLKOUT_DIV_MASK, | 372 | .clksel_mask = OMAP3430_IVA2_DPLL_CLKOUT_DIV_MASK, |
380 | .clksel = div16_dpll2_m2x2_clksel, | 373 | .clksel = div16_dpll2_m2x2_clksel, |
381 | .flags = RATE_PROPAGATES, | ||
382 | .clkdm_name = "dpll2_clkdm", | 374 | .clkdm_name = "dpll2_clkdm", |
383 | .recalc = &omap2_clksel_recalc, | 375 | .recalc = &omap2_clksel_recalc, |
384 | }; | 376 | }; |
@@ -413,7 +405,6 @@ static struct clk dpll3_ck = { | |||
413 | .ops = &clkops_null, | 405 | .ops = &clkops_null, |
414 | .parent = &sys_ck, | 406 | .parent = &sys_ck, |
415 | .dpll_data = &dpll3_dd, | 407 | .dpll_data = &dpll3_dd, |
416 | .flags = RATE_PROPAGATES, | ||
417 | .round_rate = &omap2_dpll_round_rate, | 408 | .round_rate = &omap2_dpll_round_rate, |
418 | .clkdm_name = "dpll3_clkdm", | 409 | .clkdm_name = "dpll3_clkdm", |
419 | .recalc = &omap3_dpll_recalc, | 410 | .recalc = &omap3_dpll_recalc, |
@@ -427,7 +418,6 @@ static struct clk dpll3_x2_ck = { | |||
427 | .name = "dpll3_x2_ck", | 418 | .name = "dpll3_x2_ck", |
428 | .ops = &clkops_null, | 419 | .ops = &clkops_null, |
429 | .parent = &dpll3_ck, | 420 | .parent = &dpll3_ck, |
430 | .flags = RATE_PROPAGATES, | ||
431 | .clkdm_name = "dpll3_clkdm", | 421 | .clkdm_name = "dpll3_clkdm", |
432 | .recalc = &omap3_clkoutx2_recalc, | 422 | .recalc = &omap3_clkoutx2_recalc, |
433 | }; | 423 | }; |
@@ -481,7 +471,6 @@ static struct clk dpll3_m2_ck = { | |||
481 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | 471 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), |
482 | .clksel_mask = OMAP3430_CORE_DPLL_CLKOUT_DIV_MASK, | 472 | .clksel_mask = OMAP3430_CORE_DPLL_CLKOUT_DIV_MASK, |
483 | .clksel = div31_dpll3m2_clksel, | 473 | .clksel = div31_dpll3m2_clksel, |
484 | .flags = RATE_PROPAGATES, | ||
485 | .clkdm_name = "dpll3_clkdm", | 474 | .clkdm_name = "dpll3_clkdm", |
486 | .round_rate = &omap2_clksel_round_rate, | 475 | .round_rate = &omap2_clksel_round_rate, |
487 | .set_rate = &omap3_core_dpll_m2_set_rate, | 476 | .set_rate = &omap3_core_dpll_m2_set_rate, |
@@ -501,7 +490,6 @@ static struct clk core_ck = { | |||
501 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), | 490 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), |
502 | .clksel_mask = OMAP3430_ST_CORE_CLK_MASK, | 491 | .clksel_mask = OMAP3430_ST_CORE_CLK_MASK, |
503 | .clksel = core_ck_clksel, | 492 | .clksel = core_ck_clksel, |
504 | .flags = RATE_PROPAGATES, | ||
505 | .recalc = &omap2_clksel_recalc, | 493 | .recalc = &omap2_clksel_recalc, |
506 | }; | 494 | }; |
507 | 495 | ||
@@ -518,7 +506,6 @@ static struct clk dpll3_m2x2_ck = { | |||
518 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), | 506 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), |
519 | .clksel_mask = OMAP3430_ST_CORE_CLK_MASK, | 507 | .clksel_mask = OMAP3430_ST_CORE_CLK_MASK, |
520 | .clksel = dpll3_m2x2_ck_clksel, | 508 | .clksel = dpll3_m2x2_ck_clksel, |
521 | .flags = RATE_PROPAGATES, | ||
522 | .clkdm_name = "dpll3_clkdm", | 509 | .clkdm_name = "dpll3_clkdm", |
523 | .recalc = &omap2_clksel_recalc, | 510 | .recalc = &omap2_clksel_recalc, |
524 | }; | 511 | }; |
@@ -538,7 +525,6 @@ static struct clk dpll3_m3_ck = { | |||
538 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | 525 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), |
539 | .clksel_mask = OMAP3430_DIV_DPLL3_MASK, | 526 | .clksel_mask = OMAP3430_DIV_DPLL3_MASK, |
540 | .clksel = div16_dpll3_clksel, | 527 | .clksel = div16_dpll3_clksel, |
541 | .flags = RATE_PROPAGATES, | ||
542 | .clkdm_name = "dpll3_clkdm", | 528 | .clkdm_name = "dpll3_clkdm", |
543 | .recalc = &omap2_clksel_recalc, | 529 | .recalc = &omap2_clksel_recalc, |
544 | }; | 530 | }; |
@@ -550,7 +536,7 @@ static struct clk dpll3_m3x2_ck = { | |||
550 | .parent = &dpll3_m3_ck, | 536 | .parent = &dpll3_m3_ck, |
551 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 537 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
552 | .enable_bit = OMAP3430_PWRDN_EMU_CORE_SHIFT, | 538 | .enable_bit = OMAP3430_PWRDN_EMU_CORE_SHIFT, |
553 | .flags = RATE_PROPAGATES | INVERT_ENABLE, | 539 | .flags = INVERT_ENABLE, |
554 | .clkdm_name = "dpll3_clkdm", | 540 | .clkdm_name = "dpll3_clkdm", |
555 | .recalc = &omap3_clkoutx2_recalc, | 541 | .recalc = &omap3_clkoutx2_recalc, |
556 | }; | 542 | }; |
@@ -569,7 +555,6 @@ static struct clk emu_core_alwon_ck = { | |||
569 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), | 555 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), |
570 | .clksel_mask = OMAP3430_ST_CORE_CLK_MASK, | 556 | .clksel_mask = OMAP3430_ST_CORE_CLK_MASK, |
571 | .clksel = emu_core_alwon_ck_clksel, | 557 | .clksel = emu_core_alwon_ck_clksel, |
572 | .flags = RATE_PROPAGATES, | ||
573 | .clkdm_name = "dpll3_clkdm", | 558 | .clkdm_name = "dpll3_clkdm", |
574 | .recalc = &omap2_clksel_recalc, | 559 | .recalc = &omap2_clksel_recalc, |
575 | }; | 560 | }; |
@@ -603,7 +588,6 @@ static struct clk dpll4_ck = { | |||
603 | .ops = &clkops_noncore_dpll_ops, | 588 | .ops = &clkops_noncore_dpll_ops, |
604 | .parent = &sys_ck, | 589 | .parent = &sys_ck, |
605 | .dpll_data = &dpll4_dd, | 590 | .dpll_data = &dpll4_dd, |
606 | .flags = RATE_PROPAGATES, | ||
607 | .round_rate = &omap2_dpll_round_rate, | 591 | .round_rate = &omap2_dpll_round_rate, |
608 | .set_rate = &omap3_dpll4_set_rate, | 592 | .set_rate = &omap3_dpll4_set_rate, |
609 | .clkdm_name = "dpll4_clkdm", | 593 | .clkdm_name = "dpll4_clkdm", |
@@ -619,7 +603,6 @@ static struct clk dpll4_x2_ck = { | |||
619 | .name = "dpll4_x2_ck", | 603 | .name = "dpll4_x2_ck", |
620 | .ops = &clkops_null, | 604 | .ops = &clkops_null, |
621 | .parent = &dpll4_ck, | 605 | .parent = &dpll4_ck, |
622 | .flags = RATE_PROPAGATES, | ||
623 | .clkdm_name = "dpll4_clkdm", | 606 | .clkdm_name = "dpll4_clkdm", |
624 | .recalc = &omap3_clkoutx2_recalc, | 607 | .recalc = &omap3_clkoutx2_recalc, |
625 | }; | 608 | }; |
@@ -638,7 +621,6 @@ static struct clk dpll4_m2_ck = { | |||
638 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, OMAP3430_CM_CLKSEL3), | 621 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, OMAP3430_CM_CLKSEL3), |
639 | .clksel_mask = OMAP3430_DIV_96M_MASK, | 622 | .clksel_mask = OMAP3430_DIV_96M_MASK, |
640 | .clksel = div16_dpll4_clksel, | 623 | .clksel = div16_dpll4_clksel, |
641 | .flags = RATE_PROPAGATES, | ||
642 | .clkdm_name = "dpll4_clkdm", | 624 | .clkdm_name = "dpll4_clkdm", |
643 | .recalc = &omap2_clksel_recalc, | 625 | .recalc = &omap2_clksel_recalc, |
644 | }; | 626 | }; |
@@ -650,7 +632,7 @@ static struct clk dpll4_m2x2_ck = { | |||
650 | .parent = &dpll4_m2_ck, | 632 | .parent = &dpll4_m2_ck, |
651 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 633 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
652 | .enable_bit = OMAP3430_PWRDN_96M_SHIFT, | 634 | .enable_bit = OMAP3430_PWRDN_96M_SHIFT, |
653 | .flags = RATE_PROPAGATES | INVERT_ENABLE, | 635 | .flags = INVERT_ENABLE, |
654 | .clkdm_name = "dpll4_clkdm", | 636 | .clkdm_name = "dpll4_clkdm", |
655 | .recalc = &omap3_clkoutx2_recalc, | 637 | .recalc = &omap3_clkoutx2_recalc, |
656 | }; | 638 | }; |
@@ -675,7 +657,6 @@ static struct clk omap_96m_alwon_fck = { | |||
675 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), | 657 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), |
676 | .clksel_mask = OMAP3430_ST_PERIPH_CLK_MASK, | 658 | .clksel_mask = OMAP3430_ST_PERIPH_CLK_MASK, |
677 | .clksel = omap_96m_alwon_fck_clksel, | 659 | .clksel = omap_96m_alwon_fck_clksel, |
678 | .flags = RATE_PROPAGATES, | ||
679 | .recalc = &omap2_clksel_recalc, | 660 | .recalc = &omap2_clksel_recalc, |
680 | }; | 661 | }; |
681 | 662 | ||
@@ -683,7 +664,6 @@ static struct clk cm_96m_fck = { | |||
683 | .name = "cm_96m_fck", | 664 | .name = "cm_96m_fck", |
684 | .ops = &clkops_null, | 665 | .ops = &clkops_null, |
685 | .parent = &omap_96m_alwon_fck, | 666 | .parent = &omap_96m_alwon_fck, |
686 | .flags = RATE_PROPAGATES, | ||
687 | .recalc = &followparent_recalc, | 667 | .recalc = &followparent_recalc, |
688 | }; | 668 | }; |
689 | 669 | ||
@@ -711,7 +691,6 @@ static struct clk omap_96m_fck = { | |||
711 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | 691 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), |
712 | .clksel_mask = OMAP3430_SOURCE_96M_MASK, | 692 | .clksel_mask = OMAP3430_SOURCE_96M_MASK, |
713 | .clksel = omap_96m_fck_clksel, | 693 | .clksel = omap_96m_fck_clksel, |
714 | .flags = RATE_PROPAGATES, | ||
715 | .recalc = &omap2_clksel_recalc, | 694 | .recalc = &omap2_clksel_recalc, |
716 | }; | 695 | }; |
717 | 696 | ||
@@ -724,7 +703,6 @@ static struct clk dpll4_m3_ck = { | |||
724 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_CLKSEL), | 703 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_CLKSEL), |
725 | .clksel_mask = OMAP3430_CLKSEL_TV_MASK, | 704 | .clksel_mask = OMAP3430_CLKSEL_TV_MASK, |
726 | .clksel = div16_dpll4_clksel, | 705 | .clksel = div16_dpll4_clksel, |
727 | .flags = RATE_PROPAGATES, | ||
728 | .clkdm_name = "dpll4_clkdm", | 706 | .clkdm_name = "dpll4_clkdm", |
729 | .recalc = &omap2_clksel_recalc, | 707 | .recalc = &omap2_clksel_recalc, |
730 | }; | 708 | }; |
@@ -737,7 +715,7 @@ static struct clk dpll4_m3x2_ck = { | |||
737 | .init = &omap2_init_clksel_parent, | 715 | .init = &omap2_init_clksel_parent, |
738 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 716 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
739 | .enable_bit = OMAP3430_PWRDN_TV_SHIFT, | 717 | .enable_bit = OMAP3430_PWRDN_TV_SHIFT, |
740 | .flags = RATE_PROPAGATES | INVERT_ENABLE, | 718 | .flags = INVERT_ENABLE, |
741 | .clkdm_name = "dpll4_clkdm", | 719 | .clkdm_name = "dpll4_clkdm", |
742 | .recalc = &omap3_clkoutx2_recalc, | 720 | .recalc = &omap3_clkoutx2_recalc, |
743 | }; | 721 | }; |
@@ -756,7 +734,6 @@ static struct clk virt_omap_54m_fck = { | |||
756 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), | 734 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), |
757 | .clksel_mask = OMAP3430_ST_PERIPH_CLK_MASK, | 735 | .clksel_mask = OMAP3430_ST_PERIPH_CLK_MASK, |
758 | .clksel = virt_omap_54m_fck_clksel, | 736 | .clksel = virt_omap_54m_fck_clksel, |
759 | .flags = RATE_PROPAGATES, | ||
760 | .recalc = &omap2_clksel_recalc, | 737 | .recalc = &omap2_clksel_recalc, |
761 | }; | 738 | }; |
762 | 739 | ||
@@ -783,7 +760,6 @@ static struct clk omap_54m_fck = { | |||
783 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | 760 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), |
784 | .clksel_mask = OMAP3430_SOURCE_54M_MASK, | 761 | .clksel_mask = OMAP3430_SOURCE_54M_MASK, |
785 | .clksel = omap_54m_clksel, | 762 | .clksel = omap_54m_clksel, |
786 | .flags = RATE_PROPAGATES, | ||
787 | .recalc = &omap2_clksel_recalc, | 763 | .recalc = &omap2_clksel_recalc, |
788 | }; | 764 | }; |
789 | 765 | ||
@@ -810,7 +786,6 @@ static struct clk omap_48m_fck = { | |||
810 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | 786 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), |
811 | .clksel_mask = OMAP3430_SOURCE_48M_MASK, | 787 | .clksel_mask = OMAP3430_SOURCE_48M_MASK, |
812 | .clksel = omap_48m_clksel, | 788 | .clksel = omap_48m_clksel, |
813 | .flags = RATE_PROPAGATES, | ||
814 | .recalc = &omap2_clksel_recalc, | 789 | .recalc = &omap2_clksel_recalc, |
815 | }; | 790 | }; |
816 | 791 | ||
@@ -819,7 +794,6 @@ static struct clk omap_12m_fck = { | |||
819 | .ops = &clkops_null, | 794 | .ops = &clkops_null, |
820 | .parent = &omap_48m_fck, | 795 | .parent = &omap_48m_fck, |
821 | .fixed_div = 4, | 796 | .fixed_div = 4, |
822 | .flags = RATE_PROPAGATES, | ||
823 | .recalc = &omap2_fixed_divisor_recalc, | 797 | .recalc = &omap2_fixed_divisor_recalc, |
824 | }; | 798 | }; |
825 | 799 | ||
@@ -832,7 +806,6 @@ static struct clk dpll4_m4_ck = { | |||
832 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_CLKSEL), | 806 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_CLKSEL), |
833 | .clksel_mask = OMAP3430_CLKSEL_DSS1_MASK, | 807 | .clksel_mask = OMAP3430_CLKSEL_DSS1_MASK, |
834 | .clksel = div16_dpll4_clksel, | 808 | .clksel = div16_dpll4_clksel, |
835 | .flags = RATE_PROPAGATES, | ||
836 | .clkdm_name = "dpll4_clkdm", | 809 | .clkdm_name = "dpll4_clkdm", |
837 | .recalc = &omap2_clksel_recalc, | 810 | .recalc = &omap2_clksel_recalc, |
838 | .set_rate = &omap2_clksel_set_rate, | 811 | .set_rate = &omap2_clksel_set_rate, |
@@ -846,7 +819,7 @@ static struct clk dpll4_m4x2_ck = { | |||
846 | .parent = &dpll4_m4_ck, | 819 | .parent = &dpll4_m4_ck, |
847 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 820 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
848 | .enable_bit = OMAP3430_PWRDN_CAM_SHIFT, | 821 | .enable_bit = OMAP3430_PWRDN_CAM_SHIFT, |
849 | .flags = RATE_PROPAGATES | INVERT_ENABLE, | 822 | .flags = INVERT_ENABLE, |
850 | .clkdm_name = "dpll4_clkdm", | 823 | .clkdm_name = "dpll4_clkdm", |
851 | .recalc = &omap3_clkoutx2_recalc, | 824 | .recalc = &omap3_clkoutx2_recalc, |
852 | }; | 825 | }; |
@@ -860,7 +833,6 @@ static struct clk dpll4_m5_ck = { | |||
860 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_CAM_MOD, CM_CLKSEL), | 833 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_CAM_MOD, CM_CLKSEL), |
861 | .clksel_mask = OMAP3430_CLKSEL_CAM_MASK, | 834 | .clksel_mask = OMAP3430_CLKSEL_CAM_MASK, |
862 | .clksel = div16_dpll4_clksel, | 835 | .clksel = div16_dpll4_clksel, |
863 | .flags = RATE_PROPAGATES, | ||
864 | .clkdm_name = "dpll4_clkdm", | 836 | .clkdm_name = "dpll4_clkdm", |
865 | .recalc = &omap2_clksel_recalc, | 837 | .recalc = &omap2_clksel_recalc, |
866 | }; | 838 | }; |
@@ -872,7 +844,7 @@ static struct clk dpll4_m5x2_ck = { | |||
872 | .parent = &dpll4_m5_ck, | 844 | .parent = &dpll4_m5_ck, |
873 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 845 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
874 | .enable_bit = OMAP3430_PWRDN_CAM_SHIFT, | 846 | .enable_bit = OMAP3430_PWRDN_CAM_SHIFT, |
875 | .flags = RATE_PROPAGATES | INVERT_ENABLE, | 847 | .flags = INVERT_ENABLE, |
876 | .clkdm_name = "dpll4_clkdm", | 848 | .clkdm_name = "dpll4_clkdm", |
877 | .recalc = &omap3_clkoutx2_recalc, | 849 | .recalc = &omap3_clkoutx2_recalc, |
878 | }; | 850 | }; |
@@ -886,7 +858,6 @@ static struct clk dpll4_m6_ck = { | |||
886 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | 858 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), |
887 | .clksel_mask = OMAP3430_DIV_DPLL4_MASK, | 859 | .clksel_mask = OMAP3430_DIV_DPLL4_MASK, |
888 | .clksel = div16_dpll4_clksel, | 860 | .clksel = div16_dpll4_clksel, |
889 | .flags = RATE_PROPAGATES, | ||
890 | .clkdm_name = "dpll4_clkdm", | 861 | .clkdm_name = "dpll4_clkdm", |
891 | .recalc = &omap2_clksel_recalc, | 862 | .recalc = &omap2_clksel_recalc, |
892 | }; | 863 | }; |
@@ -899,7 +870,7 @@ static struct clk dpll4_m6x2_ck = { | |||
899 | .init = &omap2_init_clksel_parent, | 870 | .init = &omap2_init_clksel_parent, |
900 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), | 871 | .enable_reg = OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN), |
901 | .enable_bit = OMAP3430_PWRDN_EMU_PERIPH_SHIFT, | 872 | .enable_bit = OMAP3430_PWRDN_EMU_PERIPH_SHIFT, |
902 | .flags = RATE_PROPAGATES | INVERT_ENABLE, | 873 | .flags = INVERT_ENABLE, |
903 | .clkdm_name = "dpll4_clkdm", | 874 | .clkdm_name = "dpll4_clkdm", |
904 | .recalc = &omap3_clkoutx2_recalc, | 875 | .recalc = &omap3_clkoutx2_recalc, |
905 | }; | 876 | }; |
@@ -908,7 +879,6 @@ static struct clk emu_per_alwon_ck = { | |||
908 | .name = "emu_per_alwon_ck", | 879 | .name = "emu_per_alwon_ck", |
909 | .ops = &clkops_null, | 880 | .ops = &clkops_null, |
910 | .parent = &dpll4_m6x2_ck, | 881 | .parent = &dpll4_m6x2_ck, |
911 | .flags = RATE_PROPAGATES, | ||
912 | .clkdm_name = "dpll4_clkdm", | 882 | .clkdm_name = "dpll4_clkdm", |
913 | .recalc = &followparent_recalc, | 883 | .recalc = &followparent_recalc, |
914 | }; | 884 | }; |
@@ -943,7 +913,6 @@ static struct clk dpll5_ck = { | |||
943 | .ops = &clkops_noncore_dpll_ops, | 913 | .ops = &clkops_noncore_dpll_ops, |
944 | .parent = &sys_ck, | 914 | .parent = &sys_ck, |
945 | .dpll_data = &dpll5_dd, | 915 | .dpll_data = &dpll5_dd, |
946 | .flags = RATE_PROPAGATES, | ||
947 | .round_rate = &omap2_dpll_round_rate, | 916 | .round_rate = &omap2_dpll_round_rate, |
948 | .set_rate = &omap3_noncore_dpll_set_rate, | 917 | .set_rate = &omap3_noncore_dpll_set_rate, |
949 | .clkdm_name = "dpll5_clkdm", | 918 | .clkdm_name = "dpll5_clkdm", |
@@ -963,7 +932,6 @@ static struct clk dpll5_m2_ck = { | |||
963 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, OMAP3430ES2_CM_CLKSEL5), | 932 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, OMAP3430ES2_CM_CLKSEL5), |
964 | .clksel_mask = OMAP3430ES2_DIV_120M_MASK, | 933 | .clksel_mask = OMAP3430ES2_DIV_120M_MASK, |
965 | .clksel = div16_dpll5_clksel, | 934 | .clksel = div16_dpll5_clksel, |
966 | .flags = RATE_PROPAGATES, | ||
967 | .clkdm_name = "dpll5_clkdm", | 935 | .clkdm_name = "dpll5_clkdm", |
968 | .recalc = &omap2_clksel_recalc, | 936 | .recalc = &omap2_clksel_recalc, |
969 | }; | 937 | }; |
@@ -982,7 +950,6 @@ static struct clk omap_120m_fck = { | |||
982 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST2), | 950 | .clksel_reg = OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST2), |
983 | .clksel_mask = OMAP3430ES2_ST_PERIPH2_CLK_MASK, | 951 | .clksel_mask = OMAP3430ES2_ST_PERIPH2_CLK_MASK, |
984 | .clksel = omap_120m_fck_clksel, | 952 | .clksel = omap_120m_fck_clksel, |
985 | .flags = RATE_PROPAGATES, | ||
986 | .recalc = &omap2_clksel_recalc, | 953 | .recalc = &omap2_clksel_recalc, |
987 | }; | 954 | }; |
988 | 955 | ||
@@ -1025,7 +992,6 @@ static struct clk clkout2_src_ck = { | |||
1025 | .clksel_reg = OMAP3430_CM_CLKOUT_CTRL, | 992 | .clksel_reg = OMAP3430_CM_CLKOUT_CTRL, |
1026 | .clksel_mask = OMAP3430_CLKOUT2SOURCE_MASK, | 993 | .clksel_mask = OMAP3430_CLKOUT2SOURCE_MASK, |
1027 | .clksel = clkout2_src_clksel, | 994 | .clksel = clkout2_src_clksel, |
1028 | .flags = RATE_PROPAGATES, | ||
1029 | .clkdm_name = "core_clkdm", | 995 | .clkdm_name = "core_clkdm", |
1030 | .recalc = &omap2_clksel_recalc, | 996 | .recalc = &omap2_clksel_recalc, |
1031 | }; | 997 | }; |
@@ -1060,7 +1026,6 @@ static struct clk corex2_fck = { | |||
1060 | .name = "corex2_fck", | 1026 | .name = "corex2_fck", |
1061 | .ops = &clkops_null, | 1027 | .ops = &clkops_null, |
1062 | .parent = &dpll3_m2x2_ck, | 1028 | .parent = &dpll3_m2x2_ck, |
1063 | .flags = RATE_PROPAGATES, | ||
1064 | .recalc = &followparent_recalc, | 1029 | .recalc = &followparent_recalc, |
1065 | }; | 1030 | }; |
1066 | 1031 | ||
@@ -1090,7 +1055,6 @@ static struct clk dpll1_fck = { | |||
1090 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_CLKSEL1_PLL), | 1055 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_CLKSEL1_PLL), |
1091 | .clksel_mask = OMAP3430_MPU_CLK_SRC_MASK, | 1056 | .clksel_mask = OMAP3430_MPU_CLK_SRC_MASK, |
1092 | .clksel = div4_core_clksel, | 1057 | .clksel = div4_core_clksel, |
1093 | .flags = RATE_PROPAGATES, | ||
1094 | .recalc = &omap2_clksel_recalc, | 1058 | .recalc = &omap2_clksel_recalc, |
1095 | }; | 1059 | }; |
1096 | 1060 | ||
@@ -1114,7 +1078,6 @@ static struct clk mpu_ck = { | |||
1114 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_IDLEST_PLL), | 1078 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_IDLEST_PLL), |
1115 | .clksel_mask = OMAP3430_ST_MPU_CLK_MASK, | 1079 | .clksel_mask = OMAP3430_ST_MPU_CLK_MASK, |
1116 | .clksel = mpu_clksel, | 1080 | .clksel = mpu_clksel, |
1117 | .flags = RATE_PROPAGATES, | ||
1118 | .clkdm_name = "mpu_clkdm", | 1081 | .clkdm_name = "mpu_clkdm", |
1119 | .recalc = &omap2_clksel_recalc, | 1082 | .recalc = &omap2_clksel_recalc, |
1120 | }; | 1083 | }; |
@@ -1139,7 +1102,6 @@ static struct clk arm_fck = { | |||
1139 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_IDLEST_PLL), | 1102 | .clksel_reg = OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_IDLEST_PLL), |
1140 | .clksel_mask = OMAP3430_ST_MPU_CLK_MASK, | 1103 | .clksel_mask = OMAP3430_ST_MPU_CLK_MASK, |
1141 | .clksel = arm_fck_clksel, | 1104 | .clksel = arm_fck_clksel, |
1142 | .flags = RATE_PROPAGATES, | ||
1143 | .recalc = &omap2_clksel_recalc, | 1105 | .recalc = &omap2_clksel_recalc, |
1144 | }; | 1106 | }; |
1145 | 1107 | ||
@@ -1153,7 +1115,6 @@ static struct clk emu_mpu_alwon_ck = { | |||
1153 | .name = "emu_mpu_alwon_ck", | 1115 | .name = "emu_mpu_alwon_ck", |
1154 | .ops = &clkops_null, | 1116 | .ops = &clkops_null, |
1155 | .parent = &mpu_ck, | 1117 | .parent = &mpu_ck, |
1156 | .flags = RATE_PROPAGATES, | ||
1157 | .recalc = &followparent_recalc, | 1118 | .recalc = &followparent_recalc, |
1158 | }; | 1119 | }; |
1159 | 1120 | ||
@@ -1165,7 +1126,6 @@ static struct clk dpll2_fck = { | |||
1165 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_IVA2_MOD, OMAP3430_CM_CLKSEL1_PLL), | 1126 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_IVA2_MOD, OMAP3430_CM_CLKSEL1_PLL), |
1166 | .clksel_mask = OMAP3430_IVA2_CLK_SRC_MASK, | 1127 | .clksel_mask = OMAP3430_IVA2_CLK_SRC_MASK, |
1167 | .clksel = div4_core_clksel, | 1128 | .clksel = div4_core_clksel, |
1168 | .flags = RATE_PROPAGATES, | ||
1169 | .recalc = &omap2_clksel_recalc, | 1129 | .recalc = &omap2_clksel_recalc, |
1170 | }; | 1130 | }; |
1171 | 1131 | ||
@@ -1193,7 +1153,6 @@ static struct clk iva2_ck = { | |||
1193 | OMAP3430_CM_IDLEST_PLL), | 1153 | OMAP3430_CM_IDLEST_PLL), |
1194 | .clksel_mask = OMAP3430_ST_IVA2_CLK_MASK, | 1154 | .clksel_mask = OMAP3430_ST_IVA2_CLK_MASK, |
1195 | .clksel = iva2_clksel, | 1155 | .clksel = iva2_clksel, |
1196 | .flags = RATE_PROPAGATES, | ||
1197 | .clkdm_name = "iva2_clkdm", | 1156 | .clkdm_name = "iva2_clkdm", |
1198 | .recalc = &omap2_clksel_recalc, | 1157 | .recalc = &omap2_clksel_recalc, |
1199 | }; | 1158 | }; |
@@ -1213,7 +1172,6 @@ static struct clk l3_ick = { | |||
1213 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), | 1172 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), |
1214 | .clksel_mask = OMAP3430_CLKSEL_L3_MASK, | 1173 | .clksel_mask = OMAP3430_CLKSEL_L3_MASK, |
1215 | .clksel = div2_core_clksel, | 1174 | .clksel = div2_core_clksel, |
1216 | .flags = RATE_PROPAGATES, | ||
1217 | .clkdm_name = "core_l3_clkdm", | 1175 | .clkdm_name = "core_l3_clkdm", |
1218 | .recalc = &omap2_clksel_recalc, | 1176 | .recalc = &omap2_clksel_recalc, |
1219 | }; | 1177 | }; |
@@ -1231,7 +1189,6 @@ static struct clk l4_ick = { | |||
1231 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), | 1189 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), |
1232 | .clksel_mask = OMAP3430_CLKSEL_L4_MASK, | 1190 | .clksel_mask = OMAP3430_CLKSEL_L4_MASK, |
1233 | .clksel = div2_l3_clksel, | 1191 | .clksel = div2_l3_clksel, |
1234 | .flags = RATE_PROPAGATES, | ||
1235 | .clkdm_name = "core_l4_clkdm", | 1192 | .clkdm_name = "core_l4_clkdm", |
1236 | .recalc = &omap2_clksel_recalc, | 1193 | .recalc = &omap2_clksel_recalc, |
1237 | 1194 | ||
@@ -1281,7 +1238,6 @@ static struct clk gfx_l3_fck = { | |||
1281 | .clksel_reg = OMAP_CM_REGADDR(GFX_MOD, CM_CLKSEL), | 1238 | .clksel_reg = OMAP_CM_REGADDR(GFX_MOD, CM_CLKSEL), |
1282 | .clksel_mask = OMAP_CLKSEL_GFX_MASK, | 1239 | .clksel_mask = OMAP_CLKSEL_GFX_MASK, |
1283 | .clksel = gfx_l3_clksel, | 1240 | .clksel = gfx_l3_clksel, |
1284 | .flags = RATE_PROPAGATES, | ||
1285 | .clkdm_name = "gfx_3430es1_clkdm", | 1241 | .clkdm_name = "gfx_3430es1_clkdm", |
1286 | .recalc = &omap2_clksel_recalc, | 1242 | .recalc = &omap2_clksel_recalc, |
1287 | }; | 1243 | }; |
@@ -1440,7 +1396,6 @@ static struct clk core_96m_fck = { | |||
1440 | .name = "core_96m_fck", | 1396 | .name = "core_96m_fck", |
1441 | .ops = &clkops_null, | 1397 | .ops = &clkops_null, |
1442 | .parent = &omap_96m_fck, | 1398 | .parent = &omap_96m_fck, |
1443 | .flags = RATE_PROPAGATES, | ||
1444 | .clkdm_name = "core_l4_clkdm", | 1399 | .clkdm_name = "core_l4_clkdm", |
1445 | .recalc = &followparent_recalc, | 1400 | .recalc = &followparent_recalc, |
1446 | }; | 1401 | }; |
@@ -1574,7 +1529,6 @@ static struct clk core_48m_fck = { | |||
1574 | .name = "core_48m_fck", | 1529 | .name = "core_48m_fck", |
1575 | .ops = &clkops_null, | 1530 | .ops = &clkops_null, |
1576 | .parent = &omap_48m_fck, | 1531 | .parent = &omap_48m_fck, |
1577 | .flags = RATE_PROPAGATES, | ||
1578 | .clkdm_name = "core_l4_clkdm", | 1532 | .clkdm_name = "core_l4_clkdm", |
1579 | .recalc = &followparent_recalc, | 1533 | .recalc = &followparent_recalc, |
1580 | }; | 1534 | }; |
@@ -1652,7 +1606,6 @@ static struct clk core_12m_fck = { | |||
1652 | .name = "core_12m_fck", | 1606 | .name = "core_12m_fck", |
1653 | .ops = &clkops_null, | 1607 | .ops = &clkops_null, |
1654 | .parent = &omap_12m_fck, | 1608 | .parent = &omap_12m_fck, |
1655 | .flags = RATE_PROPAGATES, | ||
1656 | .clkdm_name = "core_l4_clkdm", | 1609 | .clkdm_name = "core_l4_clkdm", |
1657 | .recalc = &followparent_recalc, | 1610 | .recalc = &followparent_recalc, |
1658 | }; | 1611 | }; |
@@ -1692,7 +1645,6 @@ static struct clk ssi_ssr_fck = { | |||
1692 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), | 1645 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), |
1693 | .clksel_mask = OMAP3430_CLKSEL_SSI_MASK, | 1646 | .clksel_mask = OMAP3430_CLKSEL_SSI_MASK, |
1694 | .clksel = ssi_ssr_clksel, | 1647 | .clksel = ssi_ssr_clksel, |
1695 | .flags = RATE_PROPAGATES, | ||
1696 | .clkdm_name = "core_l4_clkdm", | 1648 | .clkdm_name = "core_l4_clkdm", |
1697 | .recalc = &omap2_clksel_recalc, | 1649 | .recalc = &omap2_clksel_recalc, |
1698 | }; | 1650 | }; |
@@ -1718,7 +1670,6 @@ static struct clk core_l3_ick = { | |||
1718 | .ops = &clkops_null, | 1670 | .ops = &clkops_null, |
1719 | .parent = &l3_ick, | 1671 | .parent = &l3_ick, |
1720 | .init = &omap2_init_clk_clkdm, | 1672 | .init = &omap2_init_clk_clkdm, |
1721 | .flags = RATE_PROPAGATES, | ||
1722 | .clkdm_name = "core_l3_clkdm", | 1673 | .clkdm_name = "core_l3_clkdm", |
1723 | .recalc = &followparent_recalc, | 1674 | .recalc = &followparent_recalc, |
1724 | }; | 1675 | }; |
@@ -1759,7 +1710,6 @@ static struct clk security_l3_ick = { | |||
1759 | .name = "security_l3_ick", | 1710 | .name = "security_l3_ick", |
1760 | .ops = &clkops_null, | 1711 | .ops = &clkops_null, |
1761 | .parent = &l3_ick, | 1712 | .parent = &l3_ick, |
1762 | .flags = RATE_PROPAGATES, | ||
1763 | .recalc = &followparent_recalc, | 1713 | .recalc = &followparent_recalc, |
1764 | }; | 1714 | }; |
1765 | 1715 | ||
@@ -1779,7 +1729,6 @@ static struct clk core_l4_ick = { | |||
1779 | .ops = &clkops_null, | 1729 | .ops = &clkops_null, |
1780 | .parent = &l4_ick, | 1730 | .parent = &l4_ick, |
1781 | .init = &omap2_init_clk_clkdm, | 1731 | .init = &omap2_init_clk_clkdm, |
1782 | .flags = RATE_PROPAGATES, | ||
1783 | .clkdm_name = "core_l4_clkdm", | 1732 | .clkdm_name = "core_l4_clkdm", |
1784 | .recalc = &followparent_recalc, | 1733 | .recalc = &followparent_recalc, |
1785 | }; | 1734 | }; |
@@ -2062,7 +2011,6 @@ static struct clk ssi_l4_ick = { | |||
2062 | .name = "ssi_l4_ick", | 2011 | .name = "ssi_l4_ick", |
2063 | .ops = &clkops_null, | 2012 | .ops = &clkops_null, |
2064 | .parent = &l4_ick, | 2013 | .parent = &l4_ick, |
2065 | .flags = RATE_PROPAGATES, | ||
2066 | .clkdm_name = "core_l4_clkdm", | 2014 | .clkdm_name = "core_l4_clkdm", |
2067 | .recalc = &followparent_recalc, | 2015 | .recalc = &followparent_recalc, |
2068 | }; | 2016 | }; |
@@ -2106,7 +2054,6 @@ static struct clk security_l4_ick2 = { | |||
2106 | .name = "security_l4_ick2", | 2054 | .name = "security_l4_ick2", |
2107 | .ops = &clkops_null, | 2055 | .ops = &clkops_null, |
2108 | .parent = &l4_ick, | 2056 | .parent = &l4_ick, |
2109 | .flags = RATE_PROPAGATES, | ||
2110 | .recalc = &followparent_recalc, | 2057 | .recalc = &followparent_recalc, |
2111 | }; | 2058 | }; |
2112 | 2059 | ||
@@ -2350,7 +2297,6 @@ static struct clk wkup_32k_fck = { | |||
2350 | .ops = &clkops_null, | 2297 | .ops = &clkops_null, |
2351 | .init = &omap2_init_clk_clkdm, | 2298 | .init = &omap2_init_clk_clkdm, |
2352 | .parent = &omap_32k_fck, | 2299 | .parent = &omap_32k_fck, |
2353 | .flags = RATE_PROPAGATES, | ||
2354 | .clkdm_name = "wkup_clkdm", | 2300 | .clkdm_name = "wkup_clkdm", |
2355 | .recalc = &followparent_recalc, | 2301 | .recalc = &followparent_recalc, |
2356 | }; | 2302 | }; |
@@ -2379,7 +2325,6 @@ static struct clk wkup_l4_ick = { | |||
2379 | .name = "wkup_l4_ick", | 2325 | .name = "wkup_l4_ick", |
2380 | .ops = &clkops_null, | 2326 | .ops = &clkops_null, |
2381 | .parent = &sys_ck, | 2327 | .parent = &sys_ck, |
2382 | .flags = RATE_PROPAGATES, | ||
2383 | .clkdm_name = "wkup_clkdm", | 2328 | .clkdm_name = "wkup_clkdm", |
2384 | .recalc = &followparent_recalc, | 2329 | .recalc = &followparent_recalc, |
2385 | }; | 2330 | }; |
@@ -2466,7 +2411,6 @@ static struct clk per_96m_fck = { | |||
2466 | .ops = &clkops_null, | 2411 | .ops = &clkops_null, |
2467 | .parent = &omap_96m_alwon_fck, | 2412 | .parent = &omap_96m_alwon_fck, |
2468 | .init = &omap2_init_clk_clkdm, | 2413 | .init = &omap2_init_clk_clkdm, |
2469 | .flags = RATE_PROPAGATES, | ||
2470 | .clkdm_name = "per_clkdm", | 2414 | .clkdm_name = "per_clkdm", |
2471 | .recalc = &followparent_recalc, | 2415 | .recalc = &followparent_recalc, |
2472 | }; | 2416 | }; |
@@ -2476,7 +2420,6 @@ static struct clk per_48m_fck = { | |||
2476 | .ops = &clkops_null, | 2420 | .ops = &clkops_null, |
2477 | .parent = &omap_48m_fck, | 2421 | .parent = &omap_48m_fck, |
2478 | .init = &omap2_init_clk_clkdm, | 2422 | .init = &omap2_init_clk_clkdm, |
2479 | .flags = RATE_PROPAGATES, | ||
2480 | .clkdm_name = "per_clkdm", | 2423 | .clkdm_name = "per_clkdm", |
2481 | .recalc = &followparent_recalc, | 2424 | .recalc = &followparent_recalc, |
2482 | }; | 2425 | }; |
@@ -2600,7 +2543,6 @@ static struct clk per_32k_alwon_fck = { | |||
2600 | .ops = &clkops_null, | 2543 | .ops = &clkops_null, |
2601 | .parent = &omap_32k_fck, | 2544 | .parent = &omap_32k_fck, |
2602 | .clkdm_name = "per_clkdm", | 2545 | .clkdm_name = "per_clkdm", |
2603 | .flags = RATE_PROPAGATES, | ||
2604 | .recalc = &followparent_recalc, | 2546 | .recalc = &followparent_recalc, |
2605 | }; | 2547 | }; |
2606 | 2548 | ||
@@ -2668,7 +2610,6 @@ static struct clk per_l4_ick = { | |||
2668 | .name = "per_l4_ick", | 2610 | .name = "per_l4_ick", |
2669 | .ops = &clkops_null, | 2611 | .ops = &clkops_null, |
2670 | .parent = &l4_ick, | 2612 | .parent = &l4_ick, |
2671 | .flags = RATE_PROPAGATES, | ||
2672 | .clkdm_name = "per_clkdm", | 2613 | .clkdm_name = "per_clkdm", |
2673 | .recalc = &followparent_recalc, | 2614 | .recalc = &followparent_recalc, |
2674 | }; | 2615 | }; |
@@ -2948,7 +2889,6 @@ static struct clk emu_src_ck = { | |||
2948 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | 2889 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), |
2949 | .clksel_mask = OMAP3430_MUX_CTRL_MASK, | 2890 | .clksel_mask = OMAP3430_MUX_CTRL_MASK, |
2950 | .clksel = emu_src_clksel, | 2891 | .clksel = emu_src_clksel, |
2951 | .flags = RATE_PROPAGATES, | ||
2952 | .clkdm_name = "emu_clkdm", | 2892 | .clkdm_name = "emu_clkdm", |
2953 | .recalc = &omap2_clksel_recalc, | 2893 | .recalc = &omap2_clksel_recalc, |
2954 | }; | 2894 | }; |
@@ -2973,7 +2913,6 @@ static struct clk pclk_fck = { | |||
2973 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | 2913 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), |
2974 | .clksel_mask = OMAP3430_CLKSEL_PCLK_MASK, | 2914 | .clksel_mask = OMAP3430_CLKSEL_PCLK_MASK, |
2975 | .clksel = pclk_emu_clksel, | 2915 | .clksel = pclk_emu_clksel, |
2976 | .flags = RATE_PROPAGATES, | ||
2977 | .clkdm_name = "emu_clkdm", | 2916 | .clkdm_name = "emu_clkdm", |
2978 | .recalc = &omap2_clksel_recalc, | 2917 | .recalc = &omap2_clksel_recalc, |
2979 | }; | 2918 | }; |
@@ -2997,7 +2936,6 @@ static struct clk pclkx2_fck = { | |||
2997 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | 2936 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), |
2998 | .clksel_mask = OMAP3430_CLKSEL_PCLKX2_MASK, | 2937 | .clksel_mask = OMAP3430_CLKSEL_PCLKX2_MASK, |
2999 | .clksel = pclkx2_emu_clksel, | 2938 | .clksel = pclkx2_emu_clksel, |
3000 | .flags = RATE_PROPAGATES, | ||
3001 | .clkdm_name = "emu_clkdm", | 2939 | .clkdm_name = "emu_clkdm", |
3002 | .recalc = &omap2_clksel_recalc, | 2940 | .recalc = &omap2_clksel_recalc, |
3003 | }; | 2941 | }; |
@@ -3014,7 +2952,6 @@ static struct clk atclk_fck = { | |||
3014 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | 2952 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), |
3015 | .clksel_mask = OMAP3430_CLKSEL_ATCLK_MASK, | 2953 | .clksel_mask = OMAP3430_CLKSEL_ATCLK_MASK, |
3016 | .clksel = atclk_emu_clksel, | 2954 | .clksel = atclk_emu_clksel, |
3017 | .flags = RATE_PROPAGATES, | ||
3018 | .clkdm_name = "emu_clkdm", | 2955 | .clkdm_name = "emu_clkdm", |
3019 | .recalc = &omap2_clksel_recalc, | 2956 | .recalc = &omap2_clksel_recalc, |
3020 | }; | 2957 | }; |
@@ -3026,7 +2963,6 @@ static struct clk traceclk_src_fck = { | |||
3026 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | 2963 | .clksel_reg = OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), |
3027 | .clksel_mask = OMAP3430_TRACE_MUX_CTRL_MASK, | 2964 | .clksel_mask = OMAP3430_TRACE_MUX_CTRL_MASK, |
3028 | .clksel = emu_src_clksel, | 2965 | .clksel = emu_src_clksel, |
3029 | .flags = RATE_PROPAGATES, | ||
3030 | .clkdm_name = "emu_clkdm", | 2966 | .clkdm_name = "emu_clkdm", |
3031 | .recalc = &omap2_clksel_recalc, | 2967 | .recalc = &omap2_clksel_recalc, |
3032 | }; | 2968 | }; |
@@ -3063,7 +2999,6 @@ static struct clk sr1_fck = { | |||
3063 | .parent = &sys_ck, | 2999 | .parent = &sys_ck, |
3064 | .enable_reg = OMAP_CM_REGADDR(WKUP_MOD, CM_FCLKEN), | 3000 | .enable_reg = OMAP_CM_REGADDR(WKUP_MOD, CM_FCLKEN), |
3065 | .enable_bit = OMAP3430_EN_SR1_SHIFT, | 3001 | .enable_bit = OMAP3430_EN_SR1_SHIFT, |
3066 | .flags = RATE_PROPAGATES, | ||
3067 | .recalc = &followparent_recalc, | 3002 | .recalc = &followparent_recalc, |
3068 | }; | 3003 | }; |
3069 | 3004 | ||
@@ -3074,7 +3009,6 @@ static struct clk sr2_fck = { | |||
3074 | .parent = &sys_ck, | 3009 | .parent = &sys_ck, |
3075 | .enable_reg = OMAP_CM_REGADDR(WKUP_MOD, CM_FCLKEN), | 3010 | .enable_reg = OMAP_CM_REGADDR(WKUP_MOD, CM_FCLKEN), |
3076 | .enable_bit = OMAP3430_EN_SR2_SHIFT, | 3011 | .enable_bit = OMAP3430_EN_SR2_SHIFT, |
3077 | .flags = RATE_PROPAGATES, | ||
3078 | .recalc = &followparent_recalc, | 3012 | .recalc = &followparent_recalc, |
3079 | }; | 3013 | }; |
3080 | 3014 | ||
diff --git a/arch/arm/plat-omap/clock.c b/arch/arm/plat-omap/clock.c index 54da27af0bd5..6a1737a74477 100644 --- a/arch/arm/plat-omap/clock.c +++ b/arch/arm/plat-omap/clock.c | |||
@@ -143,8 +143,7 @@ int clk_set_rate(struct clk *clk, unsigned long rate) | |||
143 | if (ret == 0) { | 143 | if (ret == 0) { |
144 | if (clk->recalc) | 144 | if (clk->recalc) |
145 | clk->recalc(clk); | 145 | clk->recalc(clk); |
146 | if (clk->flags & RATE_PROPAGATES) | 146 | propagate_rate(clk); |
147 | propagate_rate(clk); | ||
148 | } | 147 | } |
149 | spin_unlock_irqrestore(&clockfw_lock, flags); | 148 | spin_unlock_irqrestore(&clockfw_lock, flags); |
150 | 149 | ||
@@ -166,8 +165,7 @@ int clk_set_parent(struct clk *clk, struct clk *parent) | |||
166 | if (ret == 0) { | 165 | if (ret == 0) { |
167 | if (clk->recalc) | 166 | if (clk->recalc) |
168 | clk->recalc(clk); | 167 | clk->recalc(clk); |
169 | if (clk->flags & RATE_PROPAGATES) | 168 | propagate_rate(clk); |
170 | propagate_rate(clk); | ||
171 | } | 169 | } |
172 | spin_unlock_irqrestore(&clockfw_lock, flags); | 170 | spin_unlock_irqrestore(&clockfw_lock, flags); |
173 | 171 | ||
@@ -214,24 +212,31 @@ void followparent_recalc(struct clk *clk) | |||
214 | clk->rate = clk->parent->rate; | 212 | clk->rate = clk->parent->rate; |
215 | } | 213 | } |
216 | 214 | ||
215 | void clk_reparent(struct clk *child, struct clk *parent) | ||
216 | { | ||
217 | list_del_init(&child->sibling); | ||
218 | if (parent) | ||
219 | list_add(&child->sibling, &parent->children); | ||
220 | child->parent = parent; | ||
221 | |||
222 | /* now do the debugfs renaming to reattach the child | ||
223 | to the proper parent */ | ||
224 | } | ||
225 | |||
217 | /* Propagate rate to children */ | 226 | /* Propagate rate to children */ |
218 | void propagate_rate(struct clk * tclk) | 227 | void propagate_rate(struct clk * tclk) |
219 | { | 228 | { |
220 | struct clk *clkp; | 229 | struct clk *clkp; |
221 | 230 | ||
222 | if (tclk == NULL || IS_ERR(tclk)) | 231 | list_for_each_entry(clkp, &tclk->children, sibling) { |
223 | return; | ||
224 | |||
225 | list_for_each_entry(clkp, &clocks, node) { | ||
226 | if (likely(clkp->parent != tclk)) | ||
227 | continue; | ||
228 | if (clkp->recalc) | 232 | if (clkp->recalc) |
229 | clkp->recalc(clkp); | 233 | clkp->recalc(clkp); |
230 | if (clkp->flags & RATE_PROPAGATES) | 234 | propagate_rate(clkp); |
231 | propagate_rate(clkp); | ||
232 | } | 235 | } |
233 | } | 236 | } |
234 | 237 | ||
238 | static LIST_HEAD(root_clks); | ||
239 | |||
235 | /** | 240 | /** |
236 | * recalculate_root_clocks - recalculate and propagate all root clocks | 241 | * recalculate_root_clocks - recalculate and propagate all root clocks |
237 | * | 242 | * |
@@ -243,16 +248,18 @@ void recalculate_root_clocks(void) | |||
243 | { | 248 | { |
244 | struct clk *clkp; | 249 | struct clk *clkp; |
245 | 250 | ||
246 | list_for_each_entry(clkp, &clocks, node) { | 251 | list_for_each_entry(clkp, &root_clks, sibling) { |
247 | if (!clkp->parent) { | 252 | if (clkp->recalc) |
248 | if (clkp->recalc) | 253 | clkp->recalc(clkp); |
249 | clkp->recalc(clkp); | 254 | propagate_rate(clkp); |
250 | if (clkp->flags & RATE_PROPAGATES) | ||
251 | propagate_rate(clkp); | ||
252 | } | ||
253 | } | 255 | } |
254 | } | 256 | } |
255 | 257 | ||
258 | void clk_init_one(struct clk *clk) | ||
259 | { | ||
260 | INIT_LIST_HEAD(&clk->children); | ||
261 | } | ||
262 | |||
256 | int clk_register(struct clk *clk) | 263 | int clk_register(struct clk *clk) |
257 | { | 264 | { |
258 | if (clk == NULL || IS_ERR(clk)) | 265 | if (clk == NULL || IS_ERR(clk)) |
@@ -265,6 +272,11 @@ int clk_register(struct clk *clk) | |||
265 | return 0; | 272 | return 0; |
266 | 273 | ||
267 | mutex_lock(&clocks_mutex); | 274 | mutex_lock(&clocks_mutex); |
275 | if (clk->parent) | ||
276 | list_add(&clk->sibling, &clk->parent->children); | ||
277 | else | ||
278 | list_add(&clk->sibling, &root_clks); | ||
279 | |||
268 | list_add(&clk->node, &clocks); | 280 | list_add(&clk->node, &clocks); |
269 | if (clk->init) | 281 | if (clk->init) |
270 | clk->init(clk); | 282 | clk->init(clk); |
@@ -280,6 +292,7 @@ void clk_unregister(struct clk *clk) | |||
280 | return; | 292 | return; |
281 | 293 | ||
282 | mutex_lock(&clocks_mutex); | 294 | mutex_lock(&clocks_mutex); |
295 | list_del(&clk->sibling); | ||
283 | list_del(&clk->node); | 296 | list_del(&clk->node); |
284 | mutex_unlock(&clocks_mutex); | 297 | mutex_unlock(&clocks_mutex); |
285 | } | 298 | } |
diff --git a/arch/arm/plat-omap/include/mach/clock.h b/arch/arm/plat-omap/include/mach/clock.h index 8705902de1d6..af6ae4fa46d6 100644 --- a/arch/arm/plat-omap/include/mach/clock.h +++ b/arch/arm/plat-omap/include/mach/clock.h | |||
@@ -70,6 +70,8 @@ struct clk { | |||
70 | const char *name; | 70 | const char *name; |
71 | int id; | 71 | int id; |
72 | struct clk *parent; | 72 | struct clk *parent; |
73 | struct list_head children; | ||
74 | struct list_head sibling; /* node for children */ | ||
73 | unsigned long rate; | 75 | unsigned long rate; |
74 | __u32 flags; | 76 | __u32 flags; |
75 | void __iomem *enable_reg; | 77 | void __iomem *enable_reg; |
@@ -115,7 +117,9 @@ struct clk_functions { | |||
115 | extern unsigned int mpurate; | 117 | extern unsigned int mpurate; |
116 | 118 | ||
117 | extern int clk_init(struct clk_functions *custom_clocks); | 119 | extern int clk_init(struct clk_functions *custom_clocks); |
120 | extern void clk_init_one(struct clk *clk); | ||
118 | extern int clk_register(struct clk *clk); | 121 | extern int clk_register(struct clk *clk); |
122 | extern void clk_reparent(struct clk *child, struct clk *parent); | ||
119 | extern void clk_unregister(struct clk *clk); | 123 | extern void clk_unregister(struct clk *clk); |
120 | extern void propagate_rate(struct clk *clk); | 124 | extern void propagate_rate(struct clk *clk); |
121 | extern void recalculate_root_clocks(void); | 125 | extern void recalculate_root_clocks(void); |
@@ -131,8 +135,7 @@ extern const struct clkops clkops_null; | |||
131 | /* Clock flags */ | 135 | /* Clock flags */ |
132 | /* bit 0 is free */ | 136 | /* bit 0 is free */ |
133 | #define RATE_FIXED (1 << 1) /* Fixed clock rate */ | 137 | #define RATE_FIXED (1 << 1) /* Fixed clock rate */ |
134 | #define RATE_PROPAGATES (1 << 2) /* Program children too */ | 138 | /* bits 2-4 are free */ |
135 | /* bits 3-4 are free */ | ||
136 | #define ENABLE_REG_32BIT (1 << 5) /* Use 32-bit access */ | 139 | #define ENABLE_REG_32BIT (1 << 5) /* Use 32-bit access */ |
137 | #define CLOCK_IDLE_CONTROL (1 << 7) | 140 | #define CLOCK_IDLE_CONTROL (1 << 7) |
138 | #define CLOCK_NO_IDLE_PARENT (1 << 8) | 141 | #define CLOCK_NO_IDLE_PARENT (1 << 8) |