|
@@ -264,3 +264,137 @@ static struct clk_hw_omap dpll_core_ck_hw = {
|
|
|
DEFINE_STRUCT_CLK(dpll_core_ck, dpll_core_ck_parents, dpll_core_ck_ops);
|
|
|
|
|
|
static const char *dpll_core_x2_ck_parents[] = {
|
|
|
+ "dpll_core_ck",
|
|
|
+};
|
|
|
+
|
|
|
+static struct clk dpll_core_x2_ck;
|
|
|
+
|
|
|
+static struct clk_hw_omap dpll_core_x2_ck_hw = {
|
|
|
+ .hw = {
|
|
|
+ .clk = &dpll_core_x2_ck,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+DEFINE_STRUCT_CLK(dpll_core_x2_ck, dpll_core_x2_ck_parents, dpll_abe_x2_ck_ops);
|
|
|
+
|
|
|
+DEFINE_CLK_OMAP_HSDIVIDER(dpll_core_m6x2_ck, "dpll_core_x2_ck",
|
|
|
+ &dpll_core_x2_ck, 0x0, OMAP4430_CM_DIV_M6_DPLL_CORE,
|
|
|
+ OMAP4430_HSDIVIDER_CLKOUT3_DIV_MASK);
|
|
|
+
|
|
|
+DEFINE_CLK_OMAP_HSDIVIDER(dpll_core_m2_ck, "dpll_core_ck", &dpll_core_ck, 0x0,
|
|
|
+ OMAP4430_CM_DIV_M2_DPLL_CORE,
|
|
|
+ OMAP4430_DPLL_CLKOUT_DIV_MASK);
|
|
|
+
|
|
|
+DEFINE_CLK_FIXED_FACTOR(ddrphy_ck, "dpll_core_m2_ck", &dpll_core_m2_ck, 0x0, 1,
|
|
|
+ 2);
|
|
|
+
|
|
|
+DEFINE_CLK_OMAP_HSDIVIDER(dpll_core_m5x2_ck, "dpll_core_x2_ck",
|
|
|
+ &dpll_core_x2_ck, 0x0, OMAP4430_CM_DIV_M5_DPLL_CORE,
|
|
|
+ OMAP4430_HSDIVIDER_CLKOUT2_DIV_MASK);
|
|
|
+
|
|
|
+DEFINE_CLK_DIVIDER(div_core_ck, "dpll_core_m5x2_ck", &dpll_core_m5x2_ck, 0x0,
|
|
|
+ OMAP4430_CM_CLKSEL_CORE, OMAP4430_CLKSEL_CORE_SHIFT,
|
|
|
+ OMAP4430_CLKSEL_CORE_WIDTH, 0x0, NULL);
|
|
|
+
|
|
|
+DEFINE_CLK_DIVIDER(div_iva_hs_clk, "dpll_core_m5x2_ck", &dpll_core_m5x2_ck,
|
|
|
+ 0x0, OMAP4430_CM_BYPCLK_DPLL_IVA, OMAP4430_CLKSEL_0_1_SHIFT,
|
|
|
+ OMAP4430_CLKSEL_0_1_WIDTH, CLK_DIVIDER_POWER_OF_TWO, NULL);
|
|
|
+
|
|
|
+DEFINE_CLK_DIVIDER(div_mpu_hs_clk, "dpll_core_m5x2_ck", &dpll_core_m5x2_ck,
|
|
|
+ 0x0, OMAP4430_CM_BYPCLK_DPLL_MPU, OMAP4430_CLKSEL_0_1_SHIFT,
|
|
|
+ OMAP4430_CLKSEL_0_1_WIDTH, CLK_DIVIDER_POWER_OF_TWO, NULL);
|
|
|
+
|
|
|
+DEFINE_CLK_OMAP_HSDIVIDER(dpll_core_m4x2_ck, "dpll_core_x2_ck",
|
|
|
+ &dpll_core_x2_ck, 0x0, OMAP4430_CM_DIV_M4_DPLL_CORE,
|
|
|
+ OMAP4430_HSDIVIDER_CLKOUT1_DIV_MASK);
|
|
|
+
|
|
|
+DEFINE_CLK_FIXED_FACTOR(dll_clk_div_ck, "dpll_core_m4x2_ck", &dpll_core_m4x2_ck,
|
|
|
+ 0x0, 1, 2);
|
|
|
+
|
|
|
+DEFINE_CLK_DIVIDER(dpll_abe_m2_ck, "dpll_abe_ck", &dpll_abe_ck, 0x0,
|
|
|
+ OMAP4430_CM_DIV_M2_DPLL_ABE, OMAP4430_DPLL_CLKOUT_DIV_SHIFT,
|
|
|
+ OMAP4430_DPLL_CLKOUT_DIV_WIDTH, CLK_DIVIDER_ONE_BASED, NULL);
|
|
|
+
|
|
|
+static const struct clk_ops dmic_fck_ops = {
|
|
|
+ .enable = &omap2_dflt_clk_enable,
|
|
|
+ .disable = &omap2_dflt_clk_disable,
|
|
|
+ .is_enabled = &omap2_dflt_clk_is_enabled,
|
|
|
+ .recalc_rate = &omap2_clksel_recalc,
|
|
|
+ .get_parent = &omap2_clksel_find_parent_index,
|
|
|
+ .set_parent = &omap2_clksel_set_parent,
|
|
|
+ .init = &omap2_init_clk_clkdm,
|
|
|
+};
|
|
|
+
|
|
|
+static const char *dpll_core_m3x2_ck_parents[] = {
|
|
|
+ "dpll_core_x2_ck",
|
|
|
+};
|
|
|
+
|
|
|
+static const struct clksel dpll_core_m3x2_div[] = {
|
|
|
+ { .parent = &dpll_core_x2_ck, .rates = div31_1to31_rates },
|
|
|
+ { .parent = NULL },
|
|
|
+};
|
|
|
+
|
|
|
+/* XXX Missing round_rate, set_rate in ops */
|
|
|
+DEFINE_CLK_OMAP_MUX_GATE(dpll_core_m3x2_ck, NULL, dpll_core_m3x2_div,
|
|
|
+ OMAP4430_CM_DIV_M3_DPLL_CORE,
|
|
|
+ OMAP4430_DPLL_CLKOUTHIF_DIV_MASK,
|
|
|
+ OMAP4430_CM_DIV_M3_DPLL_CORE,
|
|
|
+ OMAP4430_DPLL_CLKOUTHIF_GATE_CTRL_SHIFT, NULL,
|
|
|
+ dpll_core_m3x2_ck_parents, dmic_fck_ops);
|
|
|
+
|
|
|
+DEFINE_CLK_OMAP_HSDIVIDER(dpll_core_m7x2_ck, "dpll_core_x2_ck",
|
|
|
+ &dpll_core_x2_ck, 0x0, OMAP4430_CM_DIV_M7_DPLL_CORE,
|
|
|
+ OMAP4430_HSDIVIDER_CLKOUT4_DIV_MASK);
|
|
|
+
|
|
|
+static const char *iva_hsd_byp_clk_mux_ck_parents[] = {
|
|
|
+ "sys_clkin_ck", "div_iva_hs_clk",
|
|
|
+};
|
|
|
+
|
|
|
+DEFINE_CLK_MUX(iva_hsd_byp_clk_mux_ck, iva_hsd_byp_clk_mux_ck_parents, NULL,
|
|
|
+ 0x0, OMAP4430_CM_CLKSEL_DPLL_IVA, OMAP4430_DPLL_BYP_CLKSEL_SHIFT,
|
|
|
+ OMAP4430_DPLL_BYP_CLKSEL_WIDTH, 0x0, NULL);
|
|
|
+
|
|
|
+/* DPLL_IVA */
|
|
|
+static struct dpll_data dpll_iva_dd = {
|
|
|
+ .mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_IVA,
|
|
|
+ .clk_bypass = &iva_hsd_byp_clk_mux_ck,
|
|
|
+ .clk_ref = &sys_clkin_ck,
|
|
|
+ .control_reg = OMAP4430_CM_CLKMODE_DPLL_IVA,
|
|
|
+ .modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
|
|
+ .autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_IVA,
|
|
|
+ .idlest_reg = OMAP4430_CM_IDLEST_DPLL_IVA,
|
|
|
+ .mult_mask = OMAP4430_DPLL_MULT_MASK,
|
|
|
+ .div1_mask = OMAP4430_DPLL_DIV_MASK,
|
|
|
+ .enable_mask = OMAP4430_DPLL_EN_MASK,
|
|
|
+ .autoidle_mask = OMAP4430_AUTO_DPLL_MODE_MASK,
|
|
|
+ .idlest_mask = OMAP4430_ST_DPLL_CLK_MASK,
|
|
|
+ .max_multiplier = 2047,
|
|
|
+ .max_divider = 128,
|
|
|
+ .min_divider = 1,
|
|
|
+};
|
|
|
+
|
|
|
+static const char *dpll_iva_ck_parents[] = {
|
|
|
+ "sys_clkin_ck", "iva_hsd_byp_clk_mux_ck"
|
|
|
+};
|
|
|
+
|
|
|
+static struct clk dpll_iva_ck;
|
|
|
+
|
|
|
+static const struct clk_ops dpll_ck_ops = {
|
|
|
+ .enable = &omap3_noncore_dpll_enable,
|
|
|
+ .disable = &omap3_noncore_dpll_disable,
|
|
|
+ .recalc_rate = &omap3_dpll_recalc,
|
|
|
+ .round_rate = &omap2_dpll_round_rate,
|
|
|
+ .set_rate = &omap3_noncore_dpll_set_rate,
|
|
|
+ .get_parent = &omap2_init_dpll_parent,
|
|
|
+};
|
|
|
+
|
|
|
+static struct clk_hw_omap dpll_iva_ck_hw = {
|
|
|
+ .hw = {
|
|
|
+ .clk = &dpll_iva_ck,
|
|
|
+ },
|
|
|
+ .dpll_data = &dpll_iva_dd,
|
|
|
+ .ops = &clkhwops_omap3_dpll,
|
|
|
+};
|
|
|
+
|
|
|
+DEFINE_STRUCT_CLK(dpll_iva_ck, dpll_iva_ck_parents, dpll_ck_ops);
|
|
|
+
|