| 
					
				 | 
			
			
				@@ -252,3 +252,94 @@ DEFINE_CLK_FIXED_FACTOR(dpll_ddr_m2_div2_ck, "dpll_ddr_m2_ck", &dpll_ddr_m2_ck, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 /* DPLL_DISP */ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 static struct dpll_data dpll_disp_dd = { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.mult_div1_reg	= AM33XX_CM_CLKSEL_DPLL_DISP, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.clk_bypass	= &sys_clkin_ck, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.clk_ref	= &sys_clkin_ck, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.control_reg	= AM33XX_CM_CLKMODE_DPLL_DISP, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.modes		= (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.idlest_reg	= AM33XX_CM_IDLEST_DPLL_DISP, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.mult_mask	= AM33XX_DPLL_MULT_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.div1_mask	= AM33XX_DPLL_DIV_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.enable_mask	= AM33XX_DPLL_EN_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.idlest_mask	= AM33XX_ST_DPLL_CLK_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.max_multiplier	= 2047, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.max_divider	= 128, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.min_divider	= 1, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+}; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+/* CLKOUT: fdpll/M2 */ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+static struct clk dpll_disp_ck; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+static struct clk_hw_omap dpll_disp_ck_hw = { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.hw = { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		.clk	= &dpll_disp_ck, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	}, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.dpll_data	= &dpll_disp_dd, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.ops		= &clkhwops_omap3_dpll, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+}; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_STRUCT_CLK(dpll_disp_ck, dpll_core_ck_parents, dpll_ddr_ck_ops); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+/* 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ * TODO: Add clksel here (sys_clkin, CORE_CLKOUTM6, PER_CLKOUTM2 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ * and ALT_CLK1/2) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ */ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_CLK_DIVIDER(dpll_disp_m2_ck, "dpll_disp_ck", &dpll_disp_ck, 0x0, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		   AM33XX_CM_DIV_M2_DPLL_DISP, AM33XX_DPLL_CLKOUT_DIV_SHIFT, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		   AM33XX_DPLL_CLKOUT_DIV_WIDTH, CLK_DIVIDER_ONE_BASED, NULL); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+/* DPLL_PER */ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+static struct dpll_data dpll_per_dd = { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.mult_div1_reg	= AM33XX_CM_CLKSEL_DPLL_PERIPH, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.clk_bypass	= &sys_clkin_ck, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.clk_ref	= &sys_clkin_ck, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.control_reg	= AM33XX_CM_CLKMODE_DPLL_PER, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.modes		= (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.idlest_reg	= AM33XX_CM_IDLEST_DPLL_PER, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.mult_mask	= AM33XX_DPLL_MULT_PERIPH_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.div1_mask	= AM33XX_DPLL_PER_DIV_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.enable_mask	= AM33XX_DPLL_EN_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.idlest_mask	= AM33XX_ST_DPLL_CLK_MASK, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.max_multiplier	= 2047, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.max_divider	= 128, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.min_divider	= 1, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.flags		= DPLL_J_TYPE, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+}; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+/* CLKDCOLDO */ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+static struct clk dpll_per_ck; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+static struct clk_hw_omap dpll_per_ck_hw = { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.hw	= { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		.clk	= &dpll_per_ck, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	}, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.dpll_data	= &dpll_per_dd, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	.ops		= &clkhwops_omap3_dpll, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+}; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_STRUCT_CLK(dpll_per_ck, dpll_core_ck_parents, dpll_ddr_ck_ops); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+/* CLKOUT: fdpll/M2 */ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_CLK_DIVIDER(dpll_per_m2_ck, "dpll_per_ck", &dpll_per_ck, 0x0, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		   AM33XX_CM_DIV_M2_DPLL_PER, AM33XX_DPLL_CLKOUT_DIV_SHIFT, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		   AM33XX_DPLL_CLKOUT_DIV_WIDTH, CLK_DIVIDER_ONE_BASED, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		   NULL); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_CLK_FIXED_FACTOR(dpll_per_m2_div4_wkupdm_ck, "dpll_per_m2_ck", 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			&dpll_per_m2_ck, 0x0, 1, 4); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_CLK_FIXED_FACTOR(dpll_per_m2_div4_ck, "dpll_per_m2_ck", 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			&dpll_per_m2_ck, 0x0, 1, 4); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_CLK_FIXED_FACTOR(dpll_core_m4_div2_ck, "dpll_core_m4_ck", 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			&dpll_core_m4_ck, 0x0, 1, 2); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_CLK_FIXED_FACTOR(l4_rtc_gclk, "dpll_core_m4_ck", &dpll_core_m4_ck, 0x0, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			1, 2); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+DEFINE_CLK_FIXED_FACTOR(clk_24mhz, "dpll_per_m2_ck", &dpll_per_m2_ck, 0x0, 1, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			8); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+/* 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ * Below clock nodes describes clockdomains derived out 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ * of core clock. 
			 |