OMAP4: clocks: Update clock tree for ES2
This patch updates the clock tree with all the changes in OMAP4430 ES2. clock nodes added -1- tie_low_clock_ck -2- abe_dpll_bypass_clk_mux_ck clock nodes deleted -1- dpll_sys_ref_clk -2- per_sgx_fclk -3- usbphyocp2scp_ick Signed-off-by: Rajendra Nayak <rnayak@ti.com> Signed-off-by: Benoît Cousson <b-cousson@ti.com> [paul@pwsan.com: added comment re ES1 clocks to top of file] Signed-off-by: Paul Walmsley <paul@pwsan.com> Cc: Kevin Hilman <khilman@deeprootsystems.com>
This commit is contained in:
parent
b30a3f6257
commit
76cf52951a
|
@ -17,6 +17,10 @@
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
* published by the Free Software Foundation.
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* XXX Some of the ES1 clocks have been removed/changed; once support
|
||||||
|
* is added for discriminating clocks by ES level, these should be added back
|
||||||
|
* in.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
@ -175,21 +179,27 @@ static struct clk sys_clkin_ck = {
|
||||||
.recalc = &omap2_clksel_recalc,
|
.recalc = &omap2_clksel_recalc,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct clk tie_low_clock_ck = {
|
||||||
|
.name = "tie_low_clock_ck",
|
||||||
|
.rate = 0,
|
||||||
|
.ops = &clkops_null,
|
||||||
|
};
|
||||||
|
|
||||||
static struct clk utmi_phy_clkout_ck = {
|
static struct clk utmi_phy_clkout_ck = {
|
||||||
.name = "utmi_phy_clkout_ck",
|
.name = "utmi_phy_clkout_ck",
|
||||||
.rate = 12000000,
|
.rate = 60000000,
|
||||||
.ops = &clkops_null,
|
.ops = &clkops_null,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clk xclk60mhsp1_ck = {
|
static struct clk xclk60mhsp1_ck = {
|
||||||
.name = "xclk60mhsp1_ck",
|
.name = "xclk60mhsp1_ck",
|
||||||
.rate = 12000000,
|
.rate = 60000000,
|
||||||
.ops = &clkops_null,
|
.ops = &clkops_null,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clk xclk60mhsp2_ck = {
|
static struct clk xclk60mhsp2_ck = {
|
||||||
.name = "xclk60mhsp2_ck",
|
.name = "xclk60mhsp2_ck",
|
||||||
.rate = 12000000,
|
.rate = 60000000,
|
||||||
.ops = &clkops_null,
|
.ops = &clkops_null,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -201,39 +211,23 @@ static struct clk xclk60motg_ck = {
|
||||||
|
|
||||||
/* Module clocks and DPLL outputs */
|
/* Module clocks and DPLL outputs */
|
||||||
|
|
||||||
static const struct clksel_rate div2_1to2_rates[] = {
|
static const struct clksel abe_dpll_bypass_clk_mux_sel[] = {
|
||||||
{ .div = 1, .val = 0, .flags = RATE_IN_4430 },
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
||||||
{ .div = 2, .val = 1, .flags = RATE_IN_4430 },
|
|
||||||
{ .div = 0 },
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct clksel dpll_sys_ref_clk_div[] = {
|
|
||||||
{ .parent = &sys_clkin_ck, .rates = div2_1to2_rates },
|
|
||||||
{ .parent = NULL },
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct clk dpll_sys_ref_clk = {
|
|
||||||
.name = "dpll_sys_ref_clk",
|
|
||||||
.parent = &sys_clkin_ck,
|
|
||||||
.clksel = dpll_sys_ref_clk_div,
|
|
||||||
.clksel_reg = OMAP4430_CM_DPLL_SYS_REF_CLKSEL,
|
|
||||||
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
|
||||||
.ops = &clkops_null,
|
|
||||||
.recalc = &omap2_clksel_recalc,
|
|
||||||
.round_rate = &omap2_clksel_round_rate,
|
|
||||||
.set_rate = &omap2_clksel_set_rate,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct clksel abe_dpll_refclk_mux_sel[] = {
|
|
||||||
{ .parent = &dpll_sys_ref_clk, .rates = div_1_0_rates },
|
|
||||||
{ .parent = &sys_32k_ck, .rates = div_1_1_rates },
|
{ .parent = &sys_32k_ck, .rates = div_1_1_rates },
|
||||||
{ .parent = NULL },
|
{ .parent = NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct clk abe_dpll_bypass_clk_mux_ck = {
|
||||||
|
.name = "abe_dpll_bypass_clk_mux_ck",
|
||||||
|
.parent = &sys_clkin_ck,
|
||||||
|
.ops = &clkops_null,
|
||||||
|
.recalc = &followparent_recalc,
|
||||||
|
};
|
||||||
|
|
||||||
static struct clk abe_dpll_refclk_mux_ck = {
|
static struct clk abe_dpll_refclk_mux_ck = {
|
||||||
.name = "abe_dpll_refclk_mux_ck",
|
.name = "abe_dpll_refclk_mux_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = abe_dpll_refclk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_ABE_PLL_REF_CLKSEL,
|
.clksel_reg = OMAP4430_CM_ABE_PLL_REF_CLKSEL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
||||||
|
@ -244,7 +238,7 @@ static struct clk abe_dpll_refclk_mux_ck = {
|
||||||
/* DPLL_ABE */
|
/* DPLL_ABE */
|
||||||
static struct dpll_data dpll_abe_dd = {
|
static struct dpll_data dpll_abe_dd = {
|
||||||
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_ABE,
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_ABE,
|
||||||
.clk_bypass = &sys_clkin_ck,
|
.clk_bypass = &abe_dpll_bypass_clk_mux_ck,
|
||||||
.clk_ref = &abe_dpll_refclk_mux_ck,
|
.clk_ref = &abe_dpll_refclk_mux_ck,
|
||||||
.control_reg = OMAP4430_CM_CLKMODE_DPLL_ABE,
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_ABE,
|
||||||
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
||||||
|
@ -310,6 +304,12 @@ static struct clk abe_clk = {
|
||||||
.set_rate = &omap2_clksel_set_rate,
|
.set_rate = &omap2_clksel_set_rate,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct clksel_rate div2_1to2_rates[] = {
|
||||||
|
{ .div = 1, .val = 0, .flags = RATE_IN_4430 },
|
||||||
|
{ .div = 2, .val = 1, .flags = RATE_IN_4430 },
|
||||||
|
{ .div = 0 },
|
||||||
|
};
|
||||||
|
|
||||||
static const struct clksel aess_fclk_div[] = {
|
static const struct clksel aess_fclk_div[] = {
|
||||||
{ .parent = &abe_clk, .rates = div2_1to2_rates },
|
{ .parent = &abe_clk, .rates = div2_1to2_rates },
|
||||||
{ .parent = NULL },
|
{ .parent = NULL },
|
||||||
|
@ -380,14 +380,14 @@ static struct clk dpll_abe_m3_ck = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct clksel core_hsd_byp_clk_mux_sel[] = {
|
static const struct clksel core_hsd_byp_clk_mux_sel[] = {
|
||||||
{ .parent = &dpll_sys_ref_clk, .rates = div_1_0_rates },
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
||||||
{ .parent = &dpll_abe_m3_ck, .rates = div_1_1_rates },
|
{ .parent = &dpll_abe_m3_ck, .rates = div_1_1_rates },
|
||||||
{ .parent = NULL },
|
{ .parent = NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clk core_hsd_byp_clk_mux_ck = {
|
static struct clk core_hsd_byp_clk_mux_ck = {
|
||||||
.name = "core_hsd_byp_clk_mux_ck",
|
.name = "core_hsd_byp_clk_mux_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = core_hsd_byp_clk_mux_sel,
|
.clksel = core_hsd_byp_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_CLKSEL_DPLL_CORE,
|
.clksel_reg = OMAP4430_CM_CLKSEL_DPLL_CORE,
|
||||||
|
@ -400,7 +400,7 @@ static struct clk core_hsd_byp_clk_mux_ck = {
|
||||||
static struct dpll_data dpll_core_dd = {
|
static struct dpll_data dpll_core_dd = {
|
||||||
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_CORE,
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_CORE,
|
||||||
.clk_bypass = &core_hsd_byp_clk_mux_ck,
|
.clk_bypass = &core_hsd_byp_clk_mux_ck,
|
||||||
.clk_ref = &dpll_sys_ref_clk,
|
.clk_ref = &sys_clkin_ck,
|
||||||
.control_reg = OMAP4430_CM_CLKMODE_DPLL_CORE,
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_CORE,
|
||||||
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
||||||
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_CORE,
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_CORE,
|
||||||
|
@ -418,7 +418,7 @@ static struct dpll_data dpll_core_dd = {
|
||||||
|
|
||||||
static struct clk dpll_core_ck = {
|
static struct clk dpll_core_ck = {
|
||||||
.name = "dpll_core_ck",
|
.name = "dpll_core_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.dpll_data = &dpll_core_dd,
|
.dpll_data = &dpll_core_dd,
|
||||||
.init = &omap2_init_dpll_parent,
|
.init = &omap2_init_dpll_parent,
|
||||||
.ops = &clkops_null,
|
.ops = &clkops_null,
|
||||||
|
@ -596,14 +596,14 @@ static struct clk dpll_core_m7_ck = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct clksel iva_hsd_byp_clk_mux_sel[] = {
|
static const struct clksel iva_hsd_byp_clk_mux_sel[] = {
|
||||||
{ .parent = &dpll_sys_ref_clk, .rates = div_1_0_rates },
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
||||||
{ .parent = &div_iva_hs_clk, .rates = div_1_1_rates },
|
{ .parent = &div_iva_hs_clk, .rates = div_1_1_rates },
|
||||||
{ .parent = NULL },
|
{ .parent = NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clk iva_hsd_byp_clk_mux_ck = {
|
static struct clk iva_hsd_byp_clk_mux_ck = {
|
||||||
.name = "iva_hsd_byp_clk_mux_ck",
|
.name = "iva_hsd_byp_clk_mux_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.ops = &clkops_null,
|
.ops = &clkops_null,
|
||||||
.recalc = &followparent_recalc,
|
.recalc = &followparent_recalc,
|
||||||
};
|
};
|
||||||
|
@ -612,7 +612,7 @@ static struct clk iva_hsd_byp_clk_mux_ck = {
|
||||||
static struct dpll_data dpll_iva_dd = {
|
static struct dpll_data dpll_iva_dd = {
|
||||||
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_IVA,
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_IVA,
|
||||||
.clk_bypass = &iva_hsd_byp_clk_mux_ck,
|
.clk_bypass = &iva_hsd_byp_clk_mux_ck,
|
||||||
.clk_ref = &dpll_sys_ref_clk,
|
.clk_ref = &sys_clkin_ck,
|
||||||
.control_reg = OMAP4430_CM_CLKMODE_DPLL_IVA,
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_IVA,
|
||||||
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
||||||
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_IVA,
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_IVA,
|
||||||
|
@ -630,7 +630,7 @@ static struct dpll_data dpll_iva_dd = {
|
||||||
|
|
||||||
static struct clk dpll_iva_ck = {
|
static struct clk dpll_iva_ck = {
|
||||||
.name = "dpll_iva_ck",
|
.name = "dpll_iva_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.dpll_data = &dpll_iva_dd,
|
.dpll_data = &dpll_iva_dd,
|
||||||
.init = &omap2_init_dpll_parent,
|
.init = &omap2_init_dpll_parent,
|
||||||
.ops = &clkops_omap3_noncore_dpll_ops,
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
||||||
|
@ -672,7 +672,7 @@ static struct clk dpll_iva_m5_ck = {
|
||||||
static struct dpll_data dpll_mpu_dd = {
|
static struct dpll_data dpll_mpu_dd = {
|
||||||
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_MPU,
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_MPU,
|
||||||
.clk_bypass = &div_mpu_hs_clk,
|
.clk_bypass = &div_mpu_hs_clk,
|
||||||
.clk_ref = &dpll_sys_ref_clk,
|
.clk_ref = &sys_clkin_ck,
|
||||||
.control_reg = OMAP4430_CM_CLKMODE_DPLL_MPU,
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_MPU,
|
||||||
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
||||||
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_MPU,
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_MPU,
|
||||||
|
@ -690,7 +690,7 @@ static struct dpll_data dpll_mpu_dd = {
|
||||||
|
|
||||||
static struct clk dpll_mpu_ck = {
|
static struct clk dpll_mpu_ck = {
|
||||||
.name = "dpll_mpu_ck",
|
.name = "dpll_mpu_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.dpll_data = &dpll_mpu_dd,
|
.dpll_data = &dpll_mpu_dd,
|
||||||
.init = &omap2_init_dpll_parent,
|
.init = &omap2_init_dpll_parent,
|
||||||
.ops = &clkops_omap3_noncore_dpll_ops,
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
||||||
|
@ -724,14 +724,14 @@ static struct clk per_hs_clk_div_ck = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct clksel per_hsd_byp_clk_mux_sel[] = {
|
static const struct clksel per_hsd_byp_clk_mux_sel[] = {
|
||||||
{ .parent = &dpll_sys_ref_clk, .rates = div_1_0_rates },
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
||||||
{ .parent = &per_hs_clk_div_ck, .rates = div_1_1_rates },
|
{ .parent = &per_hs_clk_div_ck, .rates = div_1_1_rates },
|
||||||
{ .parent = NULL },
|
{ .parent = NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clk per_hsd_byp_clk_mux_ck = {
|
static struct clk per_hsd_byp_clk_mux_ck = {
|
||||||
.name = "per_hsd_byp_clk_mux_ck",
|
.name = "per_hsd_byp_clk_mux_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = per_hsd_byp_clk_mux_sel,
|
.clksel = per_hsd_byp_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_CLKSEL_DPLL_PER,
|
.clksel_reg = OMAP4430_CM_CLKSEL_DPLL_PER,
|
||||||
|
@ -744,7 +744,7 @@ static struct clk per_hsd_byp_clk_mux_ck = {
|
||||||
static struct dpll_data dpll_per_dd = {
|
static struct dpll_data dpll_per_dd = {
|
||||||
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_PER,
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_PER,
|
||||||
.clk_bypass = &per_hsd_byp_clk_mux_ck,
|
.clk_bypass = &per_hsd_byp_clk_mux_ck,
|
||||||
.clk_ref = &dpll_sys_ref_clk,
|
.clk_ref = &sys_clkin_ck,
|
||||||
.control_reg = OMAP4430_CM_CLKMODE_DPLL_PER,
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_PER,
|
||||||
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
||||||
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_PER,
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_PER,
|
||||||
|
@ -762,7 +762,7 @@ static struct dpll_data dpll_per_dd = {
|
||||||
|
|
||||||
static struct clk dpll_per_ck = {
|
static struct clk dpll_per_ck = {
|
||||||
.name = "dpll_per_ck",
|
.name = "dpll_per_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.dpll_data = &dpll_per_dd,
|
.dpll_data = &dpll_per_dd,
|
||||||
.init = &omap2_init_dpll_parent,
|
.init = &omap2_init_dpll_parent,
|
||||||
.ops = &clkops_omap3_noncore_dpll_ops,
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
||||||
|
@ -858,8 +858,8 @@ static struct clk dpll_per_m7_ck = {
|
||||||
/* DPLL_UNIPRO */
|
/* DPLL_UNIPRO */
|
||||||
static struct dpll_data dpll_unipro_dd = {
|
static struct dpll_data dpll_unipro_dd = {
|
||||||
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_UNIPRO,
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_UNIPRO,
|
||||||
.clk_bypass = &dpll_sys_ref_clk,
|
.clk_bypass = &sys_clkin_ck,
|
||||||
.clk_ref = &dpll_sys_ref_clk,
|
.clk_ref = &sys_clkin_ck,
|
||||||
.control_reg = OMAP4430_CM_CLKMODE_DPLL_UNIPRO,
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_UNIPRO,
|
||||||
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
||||||
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_UNIPRO,
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_UNIPRO,
|
||||||
|
@ -877,7 +877,7 @@ static struct dpll_data dpll_unipro_dd = {
|
||||||
|
|
||||||
static struct clk dpll_unipro_ck = {
|
static struct clk dpll_unipro_ck = {
|
||||||
.name = "dpll_unipro_ck",
|
.name = "dpll_unipro_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.dpll_data = &dpll_unipro_dd,
|
.dpll_data = &dpll_unipro_dd,
|
||||||
.init = &omap2_init_dpll_parent,
|
.init = &omap2_init_dpll_parent,
|
||||||
.ops = &clkops_omap3_noncore_dpll_ops,
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
||||||
|
@ -914,7 +914,7 @@ static struct clk usb_hs_clk_div_ck = {
|
||||||
static struct dpll_data dpll_usb_dd = {
|
static struct dpll_data dpll_usb_dd = {
|
||||||
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_USB,
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_USB,
|
||||||
.clk_bypass = &usb_hs_clk_div_ck,
|
.clk_bypass = &usb_hs_clk_div_ck,
|
||||||
.clk_ref = &dpll_sys_ref_clk,
|
.clk_ref = &sys_clkin_ck,
|
||||||
.control_reg = OMAP4430_CM_CLKMODE_DPLL_USB,
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_USB,
|
||||||
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
||||||
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_USB,
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_USB,
|
||||||
|
@ -933,7 +933,7 @@ static struct dpll_data dpll_usb_dd = {
|
||||||
|
|
||||||
static struct clk dpll_usb_ck = {
|
static struct clk dpll_usb_ck = {
|
||||||
.name = "dpll_usb_ck",
|
.name = "dpll_usb_ck",
|
||||||
.parent = &dpll_sys_ref_clk,
|
.parent = &sys_clkin_ck,
|
||||||
.dpll_data = &dpll_usb_dd,
|
.dpll_data = &dpll_usb_dd,
|
||||||
.init = &omap2_init_dpll_parent,
|
.init = &omap2_init_dpll_parent,
|
||||||
.ops = &clkops_omap3_noncore_dpll_ops,
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
||||||
|
@ -1222,7 +1222,7 @@ static struct clk per_abe_24m_fclk = {
|
||||||
static const struct clksel pmd_stm_clock_mux_sel[] = {
|
static const struct clksel pmd_stm_clock_mux_sel[] = {
|
||||||
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
||||||
{ .parent = &dpll_core_m6_ck, .rates = div_1_1_rates },
|
{ .parent = &dpll_core_m6_ck, .rates = div_1_1_rates },
|
||||||
{ .parent = &dpll_per_m7_ck, .rates = div_1_2_rates },
|
{ .parent = &tie_low_clock_ck, .rates = div_1_2_rates },
|
||||||
{ .parent = NULL },
|
{ .parent = NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1240,10 +1240,15 @@ static struct clk pmd_trace_clk_mux_ck = {
|
||||||
.recalc = &followparent_recalc,
|
.recalc = &followparent_recalc,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct clksel syc_clk_div_div[] = {
|
||||||
|
{ .parent = &sys_clkin_ck, .rates = div2_1to2_rates },
|
||||||
|
{ .parent = NULL },
|
||||||
|
};
|
||||||
|
|
||||||
static struct clk syc_clk_div_ck = {
|
static struct clk syc_clk_div_ck = {
|
||||||
.name = "syc_clk_div_ck",
|
.name = "syc_clk_div_ck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dpll_sys_ref_clk_div,
|
.clksel = syc_clk_div_div,
|
||||||
.clksel_reg = OMAP4430_CM_ABE_DSS_SYS_CLKSEL,
|
.clksel_reg = OMAP4430_CM_ABE_DSS_SYS_CLKSEL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
||||||
.ops = &clkops_null,
|
.ops = &clkops_null,
|
||||||
|
@ -1407,26 +1412,9 @@ static struct clk fdif_fck = {
|
||||||
.clkdm_name = "iss_clkdm",
|
.clkdm_name = "iss_clkdm",
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct clksel per_sgx_fclk_div[] = {
|
|
||||||
{ .parent = &dpll_per_m2x2_ck, .rates = div3_1to4_rates },
|
|
||||||
{ .parent = NULL },
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct clk per_sgx_fclk = {
|
|
||||||
.name = "per_sgx_fclk",
|
|
||||||
.parent = &dpll_per_m2x2_ck,
|
|
||||||
.clksel = per_sgx_fclk_div,
|
|
||||||
.clksel_reg = OMAP4430_CM_GFX_GFX_CLKCTRL,
|
|
||||||
.clksel_mask = OMAP4430_CLKSEL_PER_192M_MASK,
|
|
||||||
.ops = &clkops_null,
|
|
||||||
.recalc = &omap2_clksel_recalc,
|
|
||||||
.round_rate = &omap2_clksel_round_rate,
|
|
||||||
.set_rate = &omap2_clksel_set_rate,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct clksel sgx_clk_mux_sel[] = {
|
static const struct clksel sgx_clk_mux_sel[] = {
|
||||||
{ .parent = &dpll_core_m7_ck, .rates = div_1_0_rates },
|
{ .parent = &dpll_core_m7_ck, .rates = div_1_0_rates },
|
||||||
{ .parent = &per_sgx_fclk, .rates = div_1_1_rates },
|
{ .parent = &dpll_per_m7_ck, .rates = div_1_1_rates },
|
||||||
{ .parent = NULL },
|
{ .parent = NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1515,12 +1503,6 @@ static struct clk gpmc_ick = {
|
||||||
.recalc = &followparent_recalc,
|
.recalc = &followparent_recalc,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct clksel dmt1_clk_mux_sel[] = {
|
|
||||||
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
|
||||||
{ .parent = &sys_32k_ck, .rates = div_1_1_rates },
|
|
||||||
{ .parent = NULL },
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Merged dmt1_clk_mux into gptimer1
|
* Merged dmt1_clk_mux into gptimer1
|
||||||
* gptimer1 renamed temporarily into gpt1 to match OMAP3 convention
|
* gptimer1 renamed temporarily into gpt1 to match OMAP3 convention
|
||||||
|
@ -1528,7 +1510,7 @@ static const struct clksel dmt1_clk_mux_sel[] = {
|
||||||
static struct clk gpt1_fck = {
|
static struct clk gpt1_fck = {
|
||||||
.name = "gpt1_fck",
|
.name = "gpt1_fck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dmt1_clk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_WKUP_TIMER1_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_WKUP_TIMER1_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
||||||
|
@ -1546,7 +1528,7 @@ static struct clk gpt1_fck = {
|
||||||
static struct clk gpt10_fck = {
|
static struct clk gpt10_fck = {
|
||||||
.name = "gpt10_fck",
|
.name = "gpt10_fck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dmt1_clk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER10_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER10_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
||||||
|
@ -1564,7 +1546,7 @@ static struct clk gpt10_fck = {
|
||||||
static struct clk gpt11_fck = {
|
static struct clk gpt11_fck = {
|
||||||
.name = "gpt11_fck",
|
.name = "gpt11_fck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dmt1_clk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER11_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER11_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
||||||
|
@ -1582,7 +1564,7 @@ static struct clk gpt11_fck = {
|
||||||
static struct clk gpt2_fck = {
|
static struct clk gpt2_fck = {
|
||||||
.name = "gpt2_fck",
|
.name = "gpt2_fck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dmt1_clk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER2_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER2_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
||||||
|
@ -1600,7 +1582,7 @@ static struct clk gpt2_fck = {
|
||||||
static struct clk gpt3_fck = {
|
static struct clk gpt3_fck = {
|
||||||
.name = "gpt3_fck",
|
.name = "gpt3_fck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dmt1_clk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER3_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER3_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
||||||
|
@ -1618,7 +1600,7 @@ static struct clk gpt3_fck = {
|
||||||
static struct clk gpt4_fck = {
|
static struct clk gpt4_fck = {
|
||||||
.name = "gpt4_fck",
|
.name = "gpt4_fck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dmt1_clk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER4_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER4_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
||||||
|
@ -1714,7 +1696,7 @@ static struct clk gpt8_fck = {
|
||||||
static struct clk gpt9_fck = {
|
static struct clk gpt9_fck = {
|
||||||
.name = "gpt9_fck",
|
.name = "gpt9_fck",
|
||||||
.parent = &sys_clkin_ck,
|
.parent = &sys_clkin_ck,
|
||||||
.clksel = dmt1_clk_mux_sel,
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
||||||
.init = &omap2_init_clksel_parent,
|
.init = &omap2_init_clksel_parent,
|
||||||
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER9_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER9_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
||||||
|
@ -1735,11 +1717,16 @@ static struct clk hdq1w_fck = {
|
||||||
.recalc = &followparent_recalc,
|
.recalc = &followparent_recalc,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct clksel hsi_fclk_div[] = {
|
||||||
|
{ .parent = &dpll_per_m2x2_ck, .rates = div3_1to4_rates },
|
||||||
|
{ .parent = NULL },
|
||||||
|
};
|
||||||
|
|
||||||
/* Merged hsi_fclk into hsi */
|
/* Merged hsi_fclk into hsi */
|
||||||
static struct clk hsi_ick = {
|
static struct clk hsi_ick = {
|
||||||
.name = "hsi_ick",
|
.name = "hsi_ick",
|
||||||
.parent = &dpll_per_m2x2_ck,
|
.parent = &dpll_per_m2x2_ck,
|
||||||
.clksel = per_sgx_fclk_div,
|
.clksel = hsi_fclk_div,
|
||||||
.clksel_reg = OMAP4430_CM_L3INIT_HSI_CLKCTRL,
|
.clksel_reg = OMAP4430_CM_L3INIT_HSI_CLKCTRL,
|
||||||
.clksel_mask = OMAP4430_CLKSEL_24_25_MASK,
|
.clksel_mask = OMAP4430_CLKSEL_24_25_MASK,
|
||||||
.ops = &clkops_omap2_dflt,
|
.ops = &clkops_omap2_dflt,
|
||||||
|
@ -2315,21 +2302,11 @@ static struct clk usb_tll_ick = {
|
||||||
.recalc = &followparent_recalc,
|
.recalc = &followparent_recalc,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clk usbphyocp2scp_ick = {
|
static struct clk usim_ick = {
|
||||||
.name = "usbphyocp2scp_ick",
|
.name = "usim_ick",
|
||||||
.ops = &clkops_omap2_dflt,
|
|
||||||
.enable_reg = OMAP4430_CM_L3INIT_USBPHYOCP2SCP_CLKCTRL,
|
|
||||||
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
||||||
.clkdm_name = "l3_init_clkdm",
|
|
||||||
.parent = &l4_div_ck,
|
|
||||||
.recalc = &followparent_recalc,
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct clk usim_fck = {
|
|
||||||
.name = "usim_fck",
|
|
||||||
.ops = &clkops_omap2_dflt,
|
.ops = &clkops_omap2_dflt,
|
||||||
.enable_reg = OMAP4430_CM_WKUP_USIM_CLKCTRL,
|
.enable_reg = OMAP4430_CM_WKUP_USIM_CLKCTRL,
|
||||||
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
||||||
.clkdm_name = "l4_wkup_clkdm",
|
.clkdm_name = "l4_wkup_clkdm",
|
||||||
.parent = &sys_32k_ck,
|
.parent = &sys_32k_ck,
|
||||||
.recalc = &followparent_recalc,
|
.recalc = &followparent_recalc,
|
||||||
|
@ -2483,11 +2460,12 @@ static struct omap_clk omap44xx_clks[] = {
|
||||||
CLK(NULL, "virt_27000000_ck", &virt_27000000_ck, CK_443X),
|
CLK(NULL, "virt_27000000_ck", &virt_27000000_ck, CK_443X),
|
||||||
CLK(NULL, "virt_38400000_ck", &virt_38400000_ck, CK_443X),
|
CLK(NULL, "virt_38400000_ck", &virt_38400000_ck, CK_443X),
|
||||||
CLK(NULL, "sys_clkin_ck", &sys_clkin_ck, CK_443X),
|
CLK(NULL, "sys_clkin_ck", &sys_clkin_ck, CK_443X),
|
||||||
|
CLK(NULL, "tie_low_clock_ck", &tie_low_clock_ck, CK_443X),
|
||||||
CLK(NULL, "utmi_phy_clkout_ck", &utmi_phy_clkout_ck, CK_443X),
|
CLK(NULL, "utmi_phy_clkout_ck", &utmi_phy_clkout_ck, CK_443X),
|
||||||
CLK(NULL, "xclk60mhsp1_ck", &xclk60mhsp1_ck, CK_443X),
|
CLK(NULL, "xclk60mhsp1_ck", &xclk60mhsp1_ck, CK_443X),
|
||||||
CLK(NULL, "xclk60mhsp2_ck", &xclk60mhsp2_ck, CK_443X),
|
CLK(NULL, "xclk60mhsp2_ck", &xclk60mhsp2_ck, CK_443X),
|
||||||
CLK(NULL, "xclk60motg_ck", &xclk60motg_ck, CK_443X),
|
CLK(NULL, "xclk60motg_ck", &xclk60motg_ck, CK_443X),
|
||||||
CLK(NULL, "dpll_sys_ref_clk", &dpll_sys_ref_clk, CK_443X),
|
CLK(NULL, "abe_dpll_bypass_clk_mux_ck", &abe_dpll_bypass_clk_mux_ck, CK_443X),
|
||||||
CLK(NULL, "abe_dpll_refclk_mux_ck", &abe_dpll_refclk_mux_ck, CK_443X),
|
CLK(NULL, "abe_dpll_refclk_mux_ck", &abe_dpll_refclk_mux_ck, CK_443X),
|
||||||
CLK(NULL, "dpll_abe_ck", &dpll_abe_ck, CK_443X),
|
CLK(NULL, "dpll_abe_ck", &dpll_abe_ck, CK_443X),
|
||||||
CLK(NULL, "dpll_abe_m2x2_ck", &dpll_abe_m2x2_ck, CK_443X),
|
CLK(NULL, "dpll_abe_m2x2_ck", &dpll_abe_m2x2_ck, CK_443X),
|
||||||
|
@ -2566,7 +2544,6 @@ static struct omap_clk omap44xx_clks[] = {
|
||||||
CLK(NULL, "emif1_ick", &emif1_ick, CK_443X),
|
CLK(NULL, "emif1_ick", &emif1_ick, CK_443X),
|
||||||
CLK(NULL, "emif2_ick", &emif2_ick, CK_443X),
|
CLK(NULL, "emif2_ick", &emif2_ick, CK_443X),
|
||||||
CLK(NULL, "fdif_fck", &fdif_fck, CK_443X),
|
CLK(NULL, "fdif_fck", &fdif_fck, CK_443X),
|
||||||
CLK(NULL, "per_sgx_fclk", &per_sgx_fclk, CK_443X),
|
|
||||||
CLK(NULL, "gfx_fck", &gfx_fck, CK_443X),
|
CLK(NULL, "gfx_fck", &gfx_fck, CK_443X),
|
||||||
CLK(NULL, "gpio1_ick", &gpio1_ick, CK_443X),
|
CLK(NULL, "gpio1_ick", &gpio1_ick, CK_443X),
|
||||||
CLK(NULL, "gpio2_ick", &gpio2_ick, CK_443X),
|
CLK(NULL, "gpio2_ick", &gpio2_ick, CK_443X),
|
||||||
|
@ -2637,8 +2614,7 @@ static struct omap_clk omap44xx_clks[] = {
|
||||||
CLK(NULL, "usb_host_fs_fck", &usb_host_fs_fck, CK_443X),
|
CLK(NULL, "usb_host_fs_fck", &usb_host_fs_fck, CK_443X),
|
||||||
CLK("musb_hdrc", "ick", &usb_otg_ick, CK_443X),
|
CLK("musb_hdrc", "ick", &usb_otg_ick, CK_443X),
|
||||||
CLK(NULL, "usb_tll_ick", &usb_tll_ick, CK_443X),
|
CLK(NULL, "usb_tll_ick", &usb_tll_ick, CK_443X),
|
||||||
CLK(NULL, "usbphyocp2scp_ick", &usbphyocp2scp_ick, CK_443X),
|
CLK(NULL, "usim_ick", &usim_ick, CK_443X),
|
||||||
CLK(NULL, "usim_fck", &usim_fck, CK_443X),
|
|
||||||
CLK("omap_wdt", "fck", &wdt2_fck, CK_443X),
|
CLK("omap_wdt", "fck", &wdt2_fck, CK_443X),
|
||||||
CLK(NULL, "wdt3_fck", &wdt3_fck, CK_443X),
|
CLK(NULL, "wdt3_fck", &wdt3_fck, CK_443X),
|
||||||
CLK(NULL, "otg_60m_gfclk_ck", &otg_60m_gfclk_ck, CK_443X),
|
CLK(NULL, "otg_60m_gfclk_ck", &otg_60m_gfclk_ck, CK_443X),
|
||||||
|
|
Loading…
Reference in New Issue