|
@@ -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.
|