clk: Make clk API return per-user struct clk instances
Moves clock state to struct clk_core, but takes care to change as little API as
possible.
struct clk_hw still has a pointer to a struct clk, which is the
implementation's per-user clk instance, for backwards compatibility.
The struct clk that clk_get_parent() returns isn't owned by the caller, but by
the clock implementation, so the former shouldn't call clk_put() on it.
Because some boards in mach-omap2 still register clocks statically, their clock
registration had to be updated to take into account that the clock information
is stored in struct clk_core now.
Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com>
Reviewed-by: Stephen Boyd <sboyd@codeaurora.org>
Tested-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Michael Turquette <mturquette@linaro.org>
[mturquette@linaro.org: adapted clk_has_parent to struct clk_core
                        applied OMAP3+ DPLL fix from Tero & Tony]
	
	
This commit is contained in:
		
					parent
					
						
							
								af0f349b29
							
						
					
				
			
			
				commit
				
					
						035a61c314
					
				
			
		
					 9 changed files with 604 additions and 305 deletions
				
			
		|  | @ -82,7 +82,7 @@ DEFINE_CLK_MUX(osc_sys_ck, osc_sys_ck_parent_names, NULL, 0x0, | |||
| 	       OMAP3430_PRM_CLKSEL, OMAP3430_SYS_CLKIN_SEL_SHIFT, | ||||
| 	       OMAP3430_SYS_CLKIN_SEL_WIDTH, 0x0, NULL); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(sys_ck, "osc_sys_ck", &osc_sys_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(sys_ck, "osc_sys_ck", &osc_sys_ck_core, 0x0, | ||||
| 		   OMAP3430_PRM_CLKSRC_CTRL, OMAP_SYSCLKDIV_SHIFT, | ||||
| 		   OMAP_SYSCLKDIV_WIDTH, CLK_DIVIDER_ONE_BASED, NULL); | ||||
| 
 | ||||
|  | @ -132,7 +132,7 @@ static struct clk_hw_omap dpll3_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll3_ck, dpll3_ck_parent_names, dpll3_ck_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll3_m2_ck, "dpll3_ck", &dpll3_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll3_m2_ck, "dpll3_ck", &dpll3_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1), | ||||
| 		   OMAP3430_CORE_DPLL_CLKOUT_DIV_SHIFT, | ||||
| 		   OMAP3430_CORE_DPLL_CLKOUT_DIV_WIDTH, | ||||
|  | @ -149,12 +149,12 @@ static const struct clk_ops core_ck_ops = {}; | |||
| DEFINE_STRUCT_CLK_HW_OMAP(core_ck, NULL); | ||||
| DEFINE_STRUCT_CLK(core_ck, core_ck_parent_names, core_ck_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(l3_ick, "core_ck", &core_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(l3_ick, "core_ck", &core_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), | ||||
| 		   OMAP3430_CLKSEL_L3_SHIFT, OMAP3430_CLKSEL_L3_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(l4_ick, "l3_ick", &l3_ick, 0x0, | ||||
| DEFINE_CLK_DIVIDER(l4_ick, "l3_ick", &l3_ick_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), | ||||
| 		   OMAP3430_CLKSEL_L4_SHIFT, OMAP3430_CLKSEL_L4_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -275,9 +275,9 @@ static struct clk_hw_omap dpll1_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll1_ck, dpll3_ck_parent_names, dpll1_ck_ops); | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll1_x2_ck, "dpll1_ck", &dpll1_ck, 0x0, 2, 1); | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll1_x2_ck, "dpll1_ck", &dpll1_ck_core, 0x0, 2, 1); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll1_x2m2_ck, "dpll1_x2_ck", &dpll1_x2_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll1_x2m2_ck, "dpll1_x2_ck", &dpll1_x2_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_CLKSEL2_PLL), | ||||
| 		   OMAP3430_MPU_DPLL_CLKOUT_DIV_SHIFT, | ||||
| 		   OMAP3430_MPU_DPLL_CLKOUT_DIV_WIDTH, | ||||
|  | @ -292,7 +292,7 @@ static const char *mpu_ck_parent_names[] = { | |||
| DEFINE_STRUCT_CLK_HW_OMAP(mpu_ck, "mpu_clkdm"); | ||||
| DEFINE_STRUCT_CLK(mpu_ck, mpu_ck_parent_names, core_l4_ick_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(arm_fck, "mpu_ck", &mpu_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(arm_fck, "mpu_ck", &mpu_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_IDLEST_PLL), | ||||
| 		   OMAP3430_ST_MPU_CLK_SHIFT, OMAP3430_ST_MPU_CLK_WIDTH, | ||||
| 		   0x0, NULL); | ||||
|  | @ -424,7 +424,7 @@ static const struct clk_div_table dpll4_mx_ck_div_table[] = { | |||
| 	{ .div = 0 }, | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll4_m5_ck, "dpll4_ck", &dpll4_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll4_m5_ck, "dpll4_ck", &dpll4_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_CAM_MOD, CM_CLKSEL), | ||||
| 		   OMAP3430_CLKSEL_CAM_SHIFT, OMAP3630_CLKSEL_CAM_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -466,7 +466,7 @@ static struct clk_hw_omap dpll4_m5x2_ck_hw = { | |||
| DEFINE_STRUCT_CLK_FLAGS(dpll4_m5x2_ck, dpll4_m5x2_ck_parent_names, | ||||
| 			dpll4_m5x2_ck_ops, CLK_SET_RATE_PARENT); | ||||
| 
 | ||||
| static struct clk dpll4_m5x2_ck_3630 = { | ||||
| static struct clk_core dpll4_m5x2_ck_3630_core = { | ||||
| 	.name		= "dpll4_m5x2_ck", | ||||
| 	.hw		= &dpll4_m5x2_ck_hw.hw, | ||||
| 	.parent_names	= dpll4_m5x2_ck_parent_names, | ||||
|  | @ -475,6 +475,10 @@ static struct clk dpll4_m5x2_ck_3630 = { | |||
| 	.flags		= CLK_SET_RATE_PARENT, | ||||
| }; | ||||
| 
 | ||||
| static struct clk dpll4_m5x2_ck_3630 = { | ||||
| 	.core = &dpll4_m5x2_ck_3630_core, | ||||
| }; | ||||
| 
 | ||||
| static struct clk cam_mclk; | ||||
| 
 | ||||
| static const char *cam_mclk_parent_names[] = { | ||||
|  | @ -490,7 +494,7 @@ static struct clk_hw_omap cam_mclk_hw = { | |||
| 	.clkdm_name	= "cam_clkdm", | ||||
| }; | ||||
| 
 | ||||
| static struct clk cam_mclk = { | ||||
| static struct clk_core cam_mclk_core = { | ||||
| 	.name		= "cam_mclk", | ||||
| 	.hw		= &cam_mclk_hw.hw, | ||||
| 	.parent_names	= cam_mclk_parent_names, | ||||
|  | @ -499,6 +503,10 @@ static struct clk cam_mclk = { | |||
| 	.flags		= CLK_SET_RATE_PARENT, | ||||
| }; | ||||
| 
 | ||||
| static struct clk cam_mclk = { | ||||
| 	.core = &cam_mclk_core, | ||||
| }; | ||||
| 
 | ||||
| static const struct clksel_rate clkout2_src_core_rates[] = { | ||||
| 	{ .div = 1, .val = 0, .flags = RATE_IN_3XXX }, | ||||
| 	{ .div = 0 } | ||||
|  | @ -514,7 +522,7 @@ static const struct clksel_rate clkout2_src_96m_rates[] = { | |||
| 	{ .div = 0 } | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll4_m2_ck, "dpll4_ck", &dpll4_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll4_m2_ck, "dpll4_ck", &dpll4_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(PLL_MOD, OMAP3430_CM_CLKSEL3), | ||||
| 		   OMAP3430_DIV_96M_SHIFT, OMAP3630_DIV_96M_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -538,7 +546,7 @@ static struct clk_hw_omap dpll4_m2x2_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll4_m2x2_ck, dpll4_m2x2_ck_parent_names, dpll4_m5x2_ck_ops); | ||||
| 
 | ||||
| static struct clk dpll4_m2x2_ck_3630 = { | ||||
| static struct clk_core dpll4_m2x2_ck_3630_core = { | ||||
| 	.name		= "dpll4_m2x2_ck", | ||||
| 	.hw		= &dpll4_m2x2_ck_hw.hw, | ||||
| 	.parent_names	= dpll4_m2x2_ck_parent_names, | ||||
|  | @ -546,6 +554,10 @@ static struct clk dpll4_m2x2_ck_3630 = { | |||
| 	.ops		= &dpll4_m5x2_ck_3630_ops, | ||||
| }; | ||||
| 
 | ||||
| static struct clk dpll4_m2x2_ck_3630 = { | ||||
| 	.core = &dpll4_m2x2_ck_3630_core, | ||||
| }; | ||||
| 
 | ||||
| static struct clk omap_96m_alwon_fck; | ||||
| 
 | ||||
| static const char *omap_96m_alwon_fck_parent_names[] = { | ||||
|  | @ -570,7 +582,7 @@ static const struct clksel_rate clkout2_src_54m_rates[] = { | |||
| 	{ .div = 0 } | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER_TABLE(dpll4_m3_ck, "dpll4_ck", &dpll4_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER_TABLE(dpll4_m3_ck, "dpll4_ck", &dpll4_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_CLKSEL), | ||||
| 		   OMAP3430_CLKSEL_TV_SHIFT, OMAP3630_CLKSEL_TV_WIDTH, | ||||
| 		   0, dpll4_mx_ck_div_table, NULL); | ||||
|  | @ -594,7 +606,7 @@ static struct clk_hw_omap dpll4_m3x2_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll4_m3x2_ck, dpll4_m3x2_ck_parent_names, dpll4_m5x2_ck_ops); | ||||
| 
 | ||||
| static struct clk dpll4_m3x2_ck_3630 = { | ||||
| static struct clk_core dpll4_m3x2_ck_3630_core = { | ||||
| 	.name		= "dpll4_m3x2_ck", | ||||
| 	.hw		= &dpll4_m3x2_ck_hw.hw, | ||||
| 	.parent_names	= dpll4_m3x2_ck_parent_names, | ||||
|  | @ -602,6 +614,10 @@ static struct clk dpll4_m3x2_ck_3630 = { | |||
| 	.ops		= &dpll4_m5x2_ck_3630_ops, | ||||
| }; | ||||
| 
 | ||||
| static struct clk dpll4_m3x2_ck_3630 = { | ||||
| 	.core = &dpll4_m3x2_ck_3630_core, | ||||
| }; | ||||
| 
 | ||||
| static const char *omap_54m_fck_parent_names[] = { | ||||
| 	"dpll4_m3x2_ck", "sys_altclk", | ||||
| }; | ||||
|  | @ -677,7 +693,8 @@ static struct clk_hw_omap omap_48m_fck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(omap_48m_fck, omap_48m_fck_parent_names, omap_48m_fck_ops); | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(omap_12m_fck, "omap_48m_fck", &omap_48m_fck, 0x0, 1, 4); | ||||
| DEFINE_CLK_FIXED_FACTOR(omap_12m_fck, "omap_48m_fck", &omap_48m_fck_core, 0x0, | ||||
| 			1, 4); | ||||
| 
 | ||||
| static struct clk core_12m_fck; | ||||
| 
 | ||||
|  | @ -723,7 +740,8 @@ static const char *core_l3_ick_parent_names[] = { | |||
| DEFINE_STRUCT_CLK_HW_OMAP(core_l3_ick, "core_l3_clkdm"); | ||||
| DEFINE_STRUCT_CLK(core_l3_ick, core_l3_ick_parent_names, core_l4_ick_ops); | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll3_m2x2_ck, "dpll3_m2_ck", &dpll3_m2_ck, 0x0, 2, 1); | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll3_m2x2_ck, "dpll3_m2_ck", &dpll3_m2_ck_core, 0x0, | ||||
| 			2, 1); | ||||
| 
 | ||||
| static struct clk corex2_fck; | ||||
| 
 | ||||
|  | @ -809,7 +827,7 @@ static struct clk_hw_omap des2_ick_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(des2_ick, aes2_ick_parent_names, aes2_ick_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll1_fck, "core_ck", &core_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll1_fck, "core_ck", &core_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(MPU_MOD, OMAP3430_CM_CLKSEL1_PLL), | ||||
| 		   OMAP3430_MPU_CLK_SRC_SHIFT, OMAP3430_MPU_CLK_SRC_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -852,18 +870,18 @@ static struct clk_hw_omap dpll2_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll2_ck, dpll3_ck_parent_names, dpll1_ck_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll2_fck, "core_ck", &core_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll2_fck, "core_ck", &core_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_IVA2_MOD, OMAP3430_CM_CLKSEL1_PLL), | ||||
| 		   OMAP3430_IVA2_CLK_SRC_SHIFT, OMAP3430_IVA2_CLK_SRC_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll2_m2_ck, "dpll2_ck", &dpll2_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll2_m2_ck, "dpll2_ck", &dpll2_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_IVA2_MOD, OMAP3430_CM_CLKSEL2_PLL), | ||||
| 		   OMAP3430_IVA2_DPLL_CLKOUT_DIV_SHIFT, | ||||
| 		   OMAP3430_IVA2_DPLL_CLKOUT_DIV_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll3_m3_ck, "dpll3_ck", &dpll3_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll3_m3_ck, "dpll3_ck", &dpll3_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | ||||
| 		   OMAP3430_DIV_DPLL3_SHIFT, OMAP3430_DIV_DPLL3_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -887,7 +905,7 @@ static struct clk_hw_omap dpll3_m3x2_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll3_m3x2_ck, dpll3_m3x2_ck_parent_names, dpll4_m5x2_ck_ops); | ||||
| 
 | ||||
| static struct clk dpll3_m3x2_ck_3630 = { | ||||
| static struct clk_core dpll3_m3x2_ck_3630_core = { | ||||
| 	.name		= "dpll3_m3x2_ck", | ||||
| 	.hw		= &dpll3_m3x2_ck_hw.hw, | ||||
| 	.parent_names	= dpll3_m3x2_ck_parent_names, | ||||
|  | @ -895,9 +913,13 @@ static struct clk dpll3_m3x2_ck_3630 = { | |||
| 	.ops		= &dpll4_m5x2_ck_3630_ops, | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll3_x2_ck, "dpll3_ck", &dpll3_ck, 0x0, 2, 1); | ||||
| static struct clk dpll3_m3x2_ck_3630 = { | ||||
| 	.core = &dpll3_m3x2_ck_3630_core, | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER_TABLE(dpll4_m4_ck, "dpll4_ck", &dpll4_ck, 0x0, | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll3_x2_ck, "dpll3_ck", &dpll3_ck_core, 0x0, 2, 1); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER_TABLE(dpll4_m4_ck, "dpll4_ck", &dpll4_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_CLKSEL), | ||||
| 		   OMAP3430_CLKSEL_DSS1_SHIFT, OMAP3630_CLKSEL_DSS1_WIDTH, | ||||
| 		   0, dpll4_mx_ck_div_table, NULL); | ||||
|  | @ -922,7 +944,7 @@ static struct clk_hw_omap dpll4_m4x2_ck_hw = { | |||
| DEFINE_STRUCT_CLK_FLAGS(dpll4_m4x2_ck, dpll4_m4x2_ck_parent_names, | ||||
| 		dpll4_m5x2_ck_ops, CLK_SET_RATE_PARENT); | ||||
| 
 | ||||
| static struct clk dpll4_m4x2_ck_3630 = { | ||||
| static struct clk_core dpll4_m4x2_ck_3630_core = { | ||||
| 	.name		= "dpll4_m4x2_ck", | ||||
| 	.hw		= &dpll4_m4x2_ck_hw.hw, | ||||
| 	.parent_names	= dpll4_m4x2_ck_parent_names, | ||||
|  | @ -931,7 +953,11 @@ static struct clk dpll4_m4x2_ck_3630 = { | |||
| 	.flags		= CLK_SET_RATE_PARENT, | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll4_m6_ck, "dpll4_ck", &dpll4_ck, 0x0, | ||||
| static struct clk dpll4_m4x2_ck_3630 = { | ||||
| 	.core = &dpll4_m4x2_ck_3630_core, | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll4_m6_ck, "dpll4_ck", &dpll4_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | ||||
| 		   OMAP3430_DIV_DPLL4_SHIFT, OMAP3630_DIV_DPLL4_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -955,7 +981,7 @@ static struct clk_hw_omap dpll4_m6x2_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll4_m6x2_ck, dpll4_m6x2_ck_parent_names, dpll4_m5x2_ck_ops); | ||||
| 
 | ||||
| static struct clk dpll4_m6x2_ck_3630 = { | ||||
| static struct clk_core dpll4_m6x2_ck_3630_core = { | ||||
| 	.name		= "dpll4_m6x2_ck", | ||||
| 	.hw		= &dpll4_m6x2_ck_hw.hw, | ||||
| 	.parent_names	= dpll4_m6x2_ck_parent_names, | ||||
|  | @ -963,7 +989,11 @@ static struct clk dpll4_m6x2_ck_3630 = { | |||
| 	.ops		= &dpll4_m5x2_ck_3630_ops, | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll4_x2_ck, "dpll4_ck", &dpll4_ck, 0x0, 2, 1); | ||||
| static struct clk dpll4_m6x2_ck_3630 = { | ||||
| 	.core = &dpll4_m6x2_ck_3630_core, | ||||
| }; | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(dpll4_x2_ck, "dpll4_ck", &dpll4_ck_core, 0x0, 2, 1); | ||||
| 
 | ||||
| static struct dpll_data dpll5_dd = { | ||||
| 	.mult_div1_reg	= OMAP_CM_REGADDR(PLL_MOD, OMAP3430ES2_CM_CLKSEL4), | ||||
|  | @ -1000,7 +1030,7 @@ static struct clk_hw_omap dpll5_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(dpll5_ck, dpll3_ck_parent_names, dpll1_ck_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(dpll5_m2_ck, "dpll5_ck", &dpll5_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(dpll5_m2_ck, "dpll5_ck", &dpll5_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(PLL_MOD, OMAP3430ES2_CM_CLKSEL5), | ||||
| 		   OMAP3430ES2_DIV_120M_SHIFT, OMAP3430ES2_DIV_120M_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -1247,7 +1277,7 @@ static struct clk_hw_omap emu_src_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(emu_src_ck, emu_src_ck_parent_names, emu_src_ck_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(atclk_fck, "emu_src_ck", &emu_src_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(atclk_fck, "emu_src_ck", &emu_src_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | ||||
| 		   OMAP3430_CLKSEL_ATCLK_SHIFT, OMAP3430_CLKSEL_ATCLK_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -1298,7 +1328,7 @@ static struct clk_hw_omap gfx_l3_ck_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(gfx_l3_ck, core_l3_ick_parent_names, aes1_ick_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(gfx_l3_fck, "l3_ick", &l3_ick, 0x0, | ||||
| DEFINE_CLK_DIVIDER(gfx_l3_fck, "l3_ick", &l3_ick_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(GFX_MOD, CM_CLKSEL), | ||||
| 		   OMAP_CLKSEL_GFX_SHIFT, OMAP_CLKSEL_GFX_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -2498,7 +2528,7 @@ static struct clk_hw_omap omap_96m_alwon_fck_3630_hw = { | |||
| 	.clksel_mask	= OMAP3630_CLKSEL_96M_MASK, | ||||
| }; | ||||
| 
 | ||||
| static struct clk omap_96m_alwon_fck_3630 = { | ||||
| static struct clk_core omap_96m_alwon_fck_3630_core = { | ||||
| 	.name	= "omap_96m_alwon_fck", | ||||
| 	.hw	= &omap_96m_alwon_fck_3630_hw.hw, | ||||
| 	.parent_names	= omap_96m_alwon_fck_3630_parent_names, | ||||
|  | @ -2506,6 +2536,10 @@ static struct clk omap_96m_alwon_fck_3630 = { | |||
| 	.ops	= &omap_96m_alwon_fck_3630_ops, | ||||
| }; | ||||
| 
 | ||||
| static struct clk omap_96m_alwon_fck_3630 = { | ||||
| 	.core = &omap_96m_alwon_fck_3630_core, | ||||
| }; | ||||
| 
 | ||||
| static struct clk omapctrl_ick; | ||||
| 
 | ||||
| static struct clk_hw_omap omapctrl_ick_hw = { | ||||
|  | @ -2521,12 +2555,12 @@ static struct clk_hw_omap omapctrl_ick_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(omapctrl_ick, aes2_ick_parent_names, aes2_ick_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(pclk_fck, "emu_src_ck", &emu_src_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(pclk_fck, "emu_src_ck", &emu_src_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | ||||
| 		   OMAP3430_CLKSEL_PCLK_SHIFT, OMAP3430_CLKSEL_PCLK_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(pclkx2_fck, "emu_src_ck", &emu_src_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(pclkx2_fck, "emu_src_ck", &emu_src_ck_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | ||||
| 		   OMAP3430_CLKSEL_PCLKX2_SHIFT, OMAP3430_CLKSEL_PCLKX2_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -2558,7 +2592,7 @@ static struct clk_hw_omap pka_ick_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(pka_ick, pka_ick_parent_names, aes1_ick_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(rm_ick, "l4_ick", &l4_ick, 0x0, | ||||
| DEFINE_CLK_DIVIDER(rm_ick, "l4_ick", &l4_ick_core, 0x0, | ||||
| 		   OMAP_CM_REGADDR(WKUP_MOD, CM_CLKSEL), | ||||
| 		   OMAP3430_CLKSEL_RM_SHIFT, OMAP3430_CLKSEL_RM_WIDTH, | ||||
| 		   CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  | @ -2819,10 +2853,10 @@ DEFINE_CLK_OMAP_MUX_GATE(ssi_ssr_fck_3430es2, "core_l4_clkdm", | |||
| 			 ssi_ssr_fck_3430es1_ops); | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(ssi_sst_fck_3430es1, "ssi_ssr_fck_3430es1", | ||||
| 			&ssi_ssr_fck_3430es1, 0x0, 1, 2); | ||||
| 			&ssi_ssr_fck_3430es1_core, 0x0, 1, 2); | ||||
| 
 | ||||
| DEFINE_CLK_FIXED_FACTOR(ssi_sst_fck_3430es2, "ssi_ssr_fck_3430es2", | ||||
| 			&ssi_ssr_fck_3430es2, 0x0, 1, 2); | ||||
| 			&ssi_ssr_fck_3430es2_core, 0x0, 1, 2); | ||||
| 
 | ||||
| static struct clk sys_clkout1; | ||||
| 
 | ||||
|  | @ -2840,7 +2874,7 @@ static struct clk_hw_omap sys_clkout1_hw = { | |||
| 
 | ||||
| DEFINE_STRUCT_CLK(sys_clkout1, sys_clkout1_parent_names, aes1_ick_ops); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(sys_clkout2, "clkout2_src_ck", &clkout2_src_ck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(sys_clkout2, "clkout2_src_ck", &clkout2_src_ck_core, 0x0, | ||||
| 		   OMAP3430_CM_CLKOUT_CTRL, OMAP3430_CLKOUT2_DIV_SHIFT, | ||||
| 		   OMAP3430_CLKOUT2_DIV_WIDTH, CLK_DIVIDER_POWER_OF_TWO, NULL); | ||||
| 
 | ||||
|  | @ -2849,7 +2883,8 @@ DEFINE_CLK_MUX(traceclk_src_fck, emu_src_ck_parent_names, NULL, 0x0, | |||
| 	       OMAP3430_TRACE_MUX_CTRL_SHIFT, OMAP3430_TRACE_MUX_CTRL_WIDTH, | ||||
| 	       0x0, NULL); | ||||
| 
 | ||||
| DEFINE_CLK_DIVIDER(traceclk_fck, "traceclk_src_fck", &traceclk_src_fck, 0x0, | ||||
| DEFINE_CLK_DIVIDER(traceclk_fck, "traceclk_src_fck", &traceclk_src_fck_core, | ||||
| 		   0x0, | ||||
| 		   OMAP_CM_REGADDR(OMAP3430_EMU_MOD, CM_CLKSEL1), | ||||
| 		   OMAP3430_CLKSEL_TRACECLK_SHIFT, | ||||
| 		   OMAP3430_CLKSEL_TRACECLK_WIDTH, CLK_DIVIDER_ONE_BASED, NULL); | ||||
|  |  | |||
|  | @ -40,23 +40,29 @@ struct omap_clk { | |||
| struct clockdomain; | ||||
| 
 | ||||
| #define DEFINE_STRUCT_CLK(_name, _parent_array_name, _clkops_name)	\ | ||||
| 	static struct clk _name = {				\ | ||||
| 	static struct clk_core _name##_core = {			\ | ||||
| 		.name = #_name,					\ | ||||
| 		.hw = &_name##_hw.hw,				\ | ||||
| 		.parent_names = _parent_array_name,		\ | ||||
| 		.num_parents = ARRAY_SIZE(_parent_array_name),	\ | ||||
| 		.ops = &_clkops_name,				\ | ||||
| 	};							\ | ||||
| 	static struct clk _name = {				\ | ||||
| 		.core = &_name##_core,				\ | ||||
| 	}; | ||||
| 
 | ||||
| #define DEFINE_STRUCT_CLK_FLAGS(_name, _parent_array_name,	\ | ||||
| 				_clkops_name, _flags)		\ | ||||
| 	static struct clk _name = {				\ | ||||
| 	static struct clk_core _name##_core = {			\ | ||||
| 		.name = #_name,					\ | ||||
| 		.hw = &_name##_hw.hw,				\ | ||||
| 		.parent_names = _parent_array_name,		\ | ||||
| 		.num_parents = ARRAY_SIZE(_parent_array_name),	\ | ||||
| 		.ops = &_clkops_name,				\ | ||||
| 		.flags = _flags,				\ | ||||
| 	};							\ | ||||
| 	static struct clk _name = {				\ | ||||
| 		.core = &_name##_core,				\ | ||||
| 	}; | ||||
| 
 | ||||
| #define DEFINE_STRUCT_CLK_HW_OMAP(_name, _clkdm_name)		\ | ||||
|  | @ -248,6 +254,7 @@ extern const struct clksel_rate gpt_32k_rates[]; | |||
| extern const struct clksel_rate gpt_sys_rates[]; | ||||
| extern const struct clksel_rate gfx_l3_rates[]; | ||||
| extern const struct clksel_rate dsp_ick_rates[]; | ||||
| extern struct clk_core dummy_ck_core; | ||||
| extern struct clk dummy_ck; | ||||
| 
 | ||||
| extern const struct clk_hw_omap_ops clkhwops_iclk_wait; | ||||
|  |  | |||
|  | @ -119,8 +119,11 @@ const struct clksel_rate div31_1to31_rates[] = { | |||
| 
 | ||||
| static struct clk_ops dummy_ck_ops = {}; | ||||
| 
 | ||||
| struct clk dummy_ck = { | ||||
| struct clk_core dummy_ck_core = { | ||||
| 	.name = "dummy_clk", | ||||
| 	.ops = &dummy_ck_ops, | ||||
| 	.flags = CLK_IS_BASIC, | ||||
| }; | ||||
| struct clk dummy_ck = { | ||||
| 	.core = &dummy_ck_core, | ||||
| }; | ||||
|  |  | |||
|  | @ -410,7 +410,7 @@ int omap3_noncore_dpll_enable(struct clk_hw *hw) | |||
| 	struct clk_hw_omap *clk = to_clk_hw_omap(hw); | ||||
| 	int r; | ||||
| 	struct dpll_data *dd; | ||||
| 	struct clk *parent; | ||||
| 	struct clk_hw *parent; | ||||
| 
 | ||||
| 	dd = clk->dpll_data; | ||||
| 	if (!dd) | ||||
|  | @ -427,13 +427,13 @@ int omap3_noncore_dpll_enable(struct clk_hw *hw) | |||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	parent = __clk_get_parent(hw->clk); | ||||
| 	parent = __clk_get_hw(__clk_get_parent(hw->clk)); | ||||
| 
 | ||||
| 	if (__clk_get_rate(hw->clk) == __clk_get_rate(dd->clk_bypass)) { | ||||
| 		WARN_ON(parent != dd->clk_bypass); | ||||
| 		WARN_ON(parent != __clk_get_hw(dd->clk_bypass)); | ||||
| 		r = _omap3_noncore_dpll_bypass(clk); | ||||
| 	} else { | ||||
| 		WARN_ON(parent != dd->clk_ref); | ||||
| 		WARN_ON(parent != __clk_get_hw(dd->clk_ref)); | ||||
| 		r = _omap3_noncore_dpll_lock(clk); | ||||
| 	} | ||||
| 
 | ||||
|  | @ -549,7 +549,8 @@ int omap3_noncore_dpll_set_rate(struct clk_hw *hw, unsigned long rate, | |||
| 	if (!dd) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	if (__clk_get_parent(hw->clk) != dd->clk_ref) | ||||
| 	if (__clk_get_hw(__clk_get_parent(hw->clk)) != | ||||
| 	    __clk_get_hw(dd->clk_ref)) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	if (dd->last_rounded_rate == 0) | ||||
|  |  | |||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -9,9 +9,14 @@ | |||
|  * published by the Free Software Foundation. | ||||
|  */ | ||||
| 
 | ||||
| struct clk_hw; | ||||
| 
 | ||||
| #if defined(CONFIG_OF) && defined(CONFIG_COMMON_CLK) | ||||
| struct clk *of_clk_get_by_clkspec(struct of_phandle_args *clkspec); | ||||
| struct clk *__of_clk_get_from_provider(struct of_phandle_args *clkspec); | ||||
| void of_clk_lock(void); | ||||
| void of_clk_unlock(void); | ||||
| #endif | ||||
| 
 | ||||
| struct clk *__clk_create_clk(struct clk_hw *hw, const char *dev_id, | ||||
| 			     const char *con_id); | ||||
|  |  | |||
|  | @ -19,6 +19,7 @@ | |||
| #include <linux/mutex.h> | ||||
| #include <linux/clk.h> | ||||
| #include <linux/clkdev.h> | ||||
| #include <linux/clk-provider.h> | ||||
| #include <linux/of.h> | ||||
| 
 | ||||
| #include "clk.h" | ||||
|  | @ -53,7 +54,7 @@ struct clk *of_clk_get_by_clkspec(struct of_phandle_args *clkspec) | |||
| 	return clk; | ||||
| } | ||||
| 
 | ||||
| struct clk *of_clk_get(struct device_node *np, int index) | ||||
| static struct clk *__of_clk_get(struct device_node *np, int index) | ||||
| { | ||||
| 	struct of_phandle_args clkspec; | ||||
| 	struct clk *clk; | ||||
|  | @ -69,20 +70,24 @@ struct clk *of_clk_get(struct device_node *np, int index) | |||
| 
 | ||||
| 	clk = of_clk_get_by_clkspec(&clkspec); | ||||
| 	of_node_put(clkspec.np); | ||||
| 
 | ||||
| 	return clk; | ||||
| } | ||||
| 
 | ||||
| struct clk *of_clk_get(struct device_node *np, int index) | ||||
| { | ||||
| 	struct clk *clk = __of_clk_get(np, index); | ||||
| 
 | ||||
| 	if (!IS_ERR(clk)) | ||||
| 		clk = __clk_create_clk(__clk_get_hw(clk), np->full_name, NULL); | ||||
| 
 | ||||
| 	return clk; | ||||
| } | ||||
| EXPORT_SYMBOL(of_clk_get); | ||||
| 
 | ||||
| /**
 | ||||
|  * of_clk_get_by_name() - Parse and lookup a clock referenced by a device node | ||||
|  * @np: pointer to clock consumer node | ||||
|  * @name: name of consumer's clock input, or NULL for the first clock reference | ||||
|  * | ||||
|  * This function parses the clocks and clock-names properties, | ||||
|  * and uses them to look up the struct clk from the registered list of clock | ||||
|  * providers. | ||||
|  */ | ||||
| struct clk *of_clk_get_by_name(struct device_node *np, const char *name) | ||||
| static struct clk *__of_clk_get_by_name(struct device_node *np, | ||||
| 					const char *dev_id, | ||||
| 					const char *name) | ||||
| { | ||||
| 	struct clk *clk = ERR_PTR(-ENOENT); | ||||
| 
 | ||||
|  | @ -97,9 +102,11 @@ struct clk *of_clk_get_by_name(struct device_node *np, const char *name) | |||
| 		 */ | ||||
| 		if (name) | ||||
| 			index = of_property_match_string(np, "clock-names", name); | ||||
| 		clk = of_clk_get(np, index); | ||||
| 		if (!IS_ERR(clk)) | ||||
| 		clk = __of_clk_get(np, index); | ||||
| 		if (!IS_ERR(clk)) { | ||||
| 			clk = __clk_create_clk(__clk_get_hw(clk), dev_id, name); | ||||
| 			break; | ||||
| 		} | ||||
| 		else if (name && index >= 0) { | ||||
| 			if (PTR_ERR(clk) != -EPROBE_DEFER) | ||||
| 				pr_err("ERROR: could not get clock %s:%s(%i)\n", | ||||
|  | @ -119,7 +126,33 @@ struct clk *of_clk_get_by_name(struct device_node *np, const char *name) | |||
| 
 | ||||
| 	return clk; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  * of_clk_get_by_name() - Parse and lookup a clock referenced by a device node | ||||
|  * @np: pointer to clock consumer node | ||||
|  * @name: name of consumer's clock input, or NULL for the first clock reference | ||||
|  * | ||||
|  * This function parses the clocks and clock-names properties, | ||||
|  * and uses them to look up the struct clk from the registered list of clock | ||||
|  * providers. | ||||
|  */ | ||||
| struct clk *of_clk_get_by_name(struct device_node *np, const char *name) | ||||
| { | ||||
| 	if (!np) | ||||
| 		return ERR_PTR(-ENOENT); | ||||
| 
 | ||||
| 	return __of_clk_get_by_name(np, np->full_name, name); | ||||
| } | ||||
| EXPORT_SYMBOL(of_clk_get_by_name); | ||||
| 
 | ||||
| #else /* defined(CONFIG_OF) && defined(CONFIG_COMMON_CLK) */ | ||||
| 
 | ||||
| static struct clk *__of_clk_get_by_name(struct device_node *np, | ||||
| 					const char *dev_id, | ||||
| 					const char *name) | ||||
| { | ||||
| 	return ERR_PTR(-ENOENT); | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  | @ -168,14 +201,29 @@ static struct clk_lookup *clk_find(const char *dev_id, const char *con_id) | |||
| struct clk *clk_get_sys(const char *dev_id, const char *con_id) | ||||
| { | ||||
| 	struct clk_lookup *cl; | ||||
| 	struct clk *clk = NULL; | ||||
| 
 | ||||
| 	mutex_lock(&clocks_mutex); | ||||
| 
 | ||||
| 	cl = clk_find(dev_id, con_id); | ||||
| 	if (cl && !__clk_get(cl->clk)) | ||||
| 	if (!cl) | ||||
| 		goto out; | ||||
| 
 | ||||
| 	if (!__clk_get(cl->clk)) { | ||||
| 		cl = NULL; | ||||
| 		goto out; | ||||
| 	} | ||||
| 
 | ||||
| #if defined(CONFIG_COMMON_CLK) | ||||
| 	clk = __clk_create_clk(__clk_get_hw(cl->clk), dev_id, con_id); | ||||
| #else | ||||
| 	clk = cl->clk; | ||||
| #endif | ||||
| 
 | ||||
| out: | ||||
| 	mutex_unlock(&clocks_mutex); | ||||
| 
 | ||||
| 	return cl ? cl->clk : ERR_PTR(-ENOENT); | ||||
| 	return cl ? clk : ERR_PTR(-ENOENT); | ||||
| } | ||||
| EXPORT_SYMBOL(clk_get_sys); | ||||
| 
 | ||||
|  | @ -185,10 +233,8 @@ struct clk *clk_get(struct device *dev, const char *con_id) | |||
| 	struct clk *clk; | ||||
| 
 | ||||
| 	if (dev) { | ||||
| 		clk = of_clk_get_by_name(dev->of_node, con_id); | ||||
| 		if (!IS_ERR(clk)) | ||||
| 			return clk; | ||||
| 		if (PTR_ERR(clk) == -EPROBE_DEFER) | ||||
| 		clk = __of_clk_get_by_name(dev->of_node, dev_id, con_id); | ||||
| 		if (!IS_ERR(clk) || PTR_ERR(clk) == -EPROBE_DEFER) | ||||
| 			return clk; | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -28,20 +28,20 @@ | |||
| 
 | ||||
| struct module; | ||||
| 
 | ||||
| struct clk { | ||||
| struct clk_core { | ||||
| 	const char		*name; | ||||
| 	const struct clk_ops	*ops; | ||||
| 	struct clk_hw		*hw; | ||||
| 	struct module		*owner; | ||||
| 	struct clk		*parent; | ||||
| 	struct clk_core		*parent; | ||||
| 	const char		**parent_names; | ||||
| 	struct clk		**parents; | ||||
| 	struct clk_core		**parents; | ||||
| 	u8			num_parents; | ||||
| 	u8			new_parent_index; | ||||
| 	unsigned long		rate; | ||||
| 	unsigned long		new_rate; | ||||
| 	struct clk		*new_parent; | ||||
| 	struct clk		*new_child; | ||||
| 	struct clk_core		*new_parent; | ||||
| 	struct clk_core		*new_child; | ||||
| 	unsigned long		flags; | ||||
| 	unsigned int		enable_count; | ||||
| 	unsigned int		prepare_count; | ||||
|  | @ -57,6 +57,12 @@ struct clk { | |||
| 	struct kref		ref; | ||||
| }; | ||||
| 
 | ||||
| struct clk { | ||||
| 	struct clk_core	*core; | ||||
| 	const char *dev_id; | ||||
| 	const char *con_id; | ||||
| }; | ||||
| 
 | ||||
| /*
 | ||||
|  * DOC: Basic clock implementations common to many platforms | ||||
|  * | ||||
|  | @ -69,6 +75,9 @@ struct clk { | |||
| #define DEFINE_CLK(_name, _ops, _flags, _parent_names,		\ | ||||
| 		_parents)					\ | ||||
| 	static struct clk _name = {				\ | ||||
| 		.core = &_name##_core				\ | ||||
| 	};							\ | ||||
| 	static struct clk_core _name##_core = {			\ | ||||
| 		.name = #_name,					\ | ||||
| 		.ops = &_ops,					\ | ||||
| 		.hw = &_name##_hw.hw,				\ | ||||
|  | @ -81,9 +90,11 @@ struct clk { | |||
| #define DEFINE_CLK_FIXED_RATE(_name, _flags, _rate,		\ | ||||
| 				_fixed_rate_flags)		\ | ||||
| 	static struct clk _name;				\ | ||||
| 	static struct clk_core _name##_core;			\ | ||||
| 	static const char *_name##_parent_names[] = {};		\ | ||||
| 	static struct clk_fixed_rate _name##_hw = {		\ | ||||
| 		.hw = {						\ | ||||
| 			.core = &_name##_core,			\ | ||||
| 			.clk = &_name,				\ | ||||
| 		},						\ | ||||
| 		.fixed_rate = _rate,				\ | ||||
|  | @ -96,14 +107,16 @@ struct clk { | |||
| 				_flags, _reg, _bit_idx,		\ | ||||
| 				_gate_flags, _lock)		\ | ||||
| 	static struct clk _name;				\ | ||||
| 	static struct clk_core _name##_core;			\ | ||||
| 	static const char *_name##_parent_names[] = {		\ | ||||
| 		_parent_name,					\ | ||||
| 	};							\ | ||||
| 	static struct clk *_name##_parents[] = {		\ | ||||
| 	static struct clk_core *_name##_parents[] = {		\ | ||||
| 		_parent_ptr,					\ | ||||
| 	};							\ | ||||
| 	static struct clk_gate _name##_hw = {			\ | ||||
| 		.hw = {						\ | ||||
| 			.core = &_name##_core,			\ | ||||
| 			.clk = &_name,				\ | ||||
| 		},						\ | ||||
| 		.reg = _reg,					\ | ||||
|  | @ -118,14 +131,16 @@ struct clk { | |||
| 				_flags, _reg, _shift, _width,	\ | ||||
| 				_divider_flags, _table, _lock)	\ | ||||
| 	static struct clk _name;				\ | ||||
| 	static struct clk_core _name##_core;			\ | ||||
| 	static const char *_name##_parent_names[] = {		\ | ||||
| 		_parent_name,					\ | ||||
| 	};							\ | ||||
| 	static struct clk *_name##_parents[] = {		\ | ||||
| 	static struct clk_core *_name##_parents[] = {		\ | ||||
| 		_parent_ptr,					\ | ||||
| 	};							\ | ||||
| 	static struct clk_divider _name##_hw = {		\ | ||||
| 		.hw = {						\ | ||||
| 			.core = &_name##_core,			\ | ||||
| 			.clk = &_name,				\ | ||||
| 		},						\ | ||||
| 		.reg = _reg,					\ | ||||
|  | @ -157,8 +172,10 @@ struct clk { | |||
| 				_reg, _shift, _width,		\ | ||||
| 				_mux_flags, _lock)		\ | ||||
| 	static struct clk _name;				\ | ||||
| 	static struct clk_core _name##_core;			\ | ||||
| 	static struct clk_mux _name##_hw = {			\ | ||||
| 		.hw = {						\ | ||||
| 			.core = &_name##_core,			\ | ||||
| 			.clk = &_name,				\ | ||||
| 		},						\ | ||||
| 		.reg = _reg,					\ | ||||
|  | @ -174,14 +191,16 @@ struct clk { | |||
| 				_parent_ptr, _flags,		\ | ||||
| 				_mult, _div)			\ | ||||
| 	static struct clk _name;				\ | ||||
| 	static struct clk_core _name##_core;			\ | ||||
| 	static const char *_name##_parent_names[] = {		\ | ||||
| 		_parent_name,					\ | ||||
| 	};							\ | ||||
| 	static struct clk *_name##_parents[] = {		\ | ||||
| 	static struct clk_core *_name##_parents[] = {		\ | ||||
| 		_parent_ptr,					\ | ||||
| 	};							\ | ||||
| 	static struct clk_fixed_factor _name##_hw = {		\ | ||||
| 		.hw = {						\ | ||||
| 			.core = &_name##_core,			\ | ||||
| 			.clk = &_name,				\ | ||||
| 		},						\ | ||||
| 		.mult = _mult,					\ | ||||
|  |  | |||
|  | @ -33,6 +33,7 @@ | |||
| #define CLK_GET_ACCURACY_NOCACHE BIT(8) /* do not use the cached clk accuracy */ | ||||
| 
 | ||||
| struct clk_hw; | ||||
| struct clk_core; | ||||
| struct dentry; | ||||
| 
 | ||||
| /**
 | ||||
|  | @ -216,13 +217,17 @@ struct clk_init_data { | |||
|  * clk_foo and then referenced by the struct clk instance that uses struct | ||||
|  * clk_foo's clk_ops | ||||
|  * | ||||
|  * @clk: pointer to the struct clk instance that points back to this struct | ||||
|  * clk_hw instance | ||||
|  * @core: pointer to the struct clk_core instance that points back to this | ||||
|  * struct clk_hw instance | ||||
|  * | ||||
|  * @clk: pointer to the per-user struct clk instance that can be used to call | ||||
|  * into the clk API | ||||
|  * | ||||
|  * @init: pointer to struct clk_init_data that contains the init data shared | ||||
|  * with the common clock framework. | ||||
|  */ | ||||
| struct clk_hw { | ||||
| 	struct clk_core *core; | ||||
| 	struct clk *clk; | ||||
| 	const struct clk_init_data *init; | ||||
| }; | ||||
|  | @ -577,9 +582,6 @@ long __clk_mux_determine_rate_closest(struct clk_hw *hw, unsigned long rate, | |||
| /*
 | ||||
|  * FIXME clock api without lock protection | ||||
|  */ | ||||
| int __clk_prepare(struct clk *clk); | ||||
| void __clk_unprepare(struct clk *clk); | ||||
| void __clk_reparent(struct clk *clk, struct clk *new_parent); | ||||
| unsigned long __clk_round_rate(struct clk *clk, unsigned long rate); | ||||
| 
 | ||||
| struct of_device_id; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Tomeu Vizoso
				Tomeu Vizoso