2009-12-08 18:46:28 -07:00
|
|
|
/*
|
|
|
|
* OMAP4 Clock data
|
|
|
|
*
|
2010-02-22 22:09:39 -07:00
|
|
|
* Copyright (C) 2009-2010 Texas Instruments, Inc.
|
|
|
|
* Copyright (C) 2009-2010 Nokia Corporation
|
2009-12-08 18:46:28 -07:00
|
|
|
*
|
|
|
|
* Paul Walmsley (paul@pwsan.com)
|
|
|
|
* Rajendra Nayak (rnayak@ti.com)
|
|
|
|
* Benoit Cousson (b-cousson@ti.com)
|
|
|
|
*
|
|
|
|
* This file is automatically generated from the OMAP hardware databases.
|
|
|
|
* We respectfully ask that any modifications to this file be coordinated
|
|
|
|
* with the public linux-omap@vger.kernel.org mailing list and the
|
|
|
|
* authors above to ensure that the autogeneration scripts are kept
|
|
|
|
* up-to-date with the file contents.
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
* published by the Free Software Foundation.
|
2010-09-27 14:02:54 -06:00
|
|
|
*
|
|
|
|
* 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.
|
2009-12-08 18:46:28 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/kernel.h>
|
OMAP2/3/4 clock: fix DPLL multiplier value errors; also copyrights, includes, documentation
The maximum DPLL multiplier (M) values for OMAP2xxx and OMAP3xxx are
one increment higher than they should be. See for example the
OMAP242x TRM Rev X Section 5.10.6 "Clock Generator Registers" and the
OMAP36xx TRM Rev C Table 3-202 "CM_CLKSEL1_PLL". Programming a 0 into
the DPLL's M register bitfield is valid for OMAP2/3 and indicates that
the DPLL should enter MN-bypass mode. Also, increase the minimum
multiplier (M) value for the DPLL rate rounding code from 1 to 2, to
ensure that it does not inadvertently put the DPLL into bypass.
Note that the register documentation in the OMAP2xxx and OMAP3xxx TRMs
does not make clear that the actual DPLL divider value (the "N") is
the content of the appropriate register bitfield for the N value,
_plus one_. (In other words, an N register bitfield of 0 indicates a
DPLL divider value of 1.) This is only clearly documented in the
OMAP4430 TRM, in, for example, OMAP4430 TRM Rev A Table 3-1167
"CM_CLKSEL_DPLL_USB".
While here, update copyrights, add kerneldoc for struct dpll_data,
drop the unused struct dpll_data.max_tolerance field, remove some
unnecessary #includes in DPLL-related code, and replace the #include
of <linux/module.h> with <linux/list.h>, which is what was really
needed. The OMAP4 clock autogenerator script has been updated
accordingly.
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Rajendra Nayak <rnayak@ti.com>
2010-02-22 22:09:12 -07:00
|
|
|
#include <linux/list.h>
|
2009-12-08 18:46:28 -07:00
|
|
|
#include <linux/clk.h>
|
|
|
|
#include <plat/clkdev_omap.h>
|
|
|
|
|
|
|
|
#include "clock.h"
|
|
|
|
#include "clock44xx.h"
|
|
|
|
#include "cm.h"
|
|
|
|
#include "cm-regbits-44xx.h"
|
|
|
|
#include "prm.h"
|
|
|
|
#include "prm-regbits-44xx.h"
|
2010-10-08 11:40:20 -06:00
|
|
|
#include "control.h"
|
2009-12-08 18:46:28 -07:00
|
|
|
|
|
|
|
/* Root clocks */
|
|
|
|
|
|
|
|
static struct clk extalt_clkin_ck = {
|
|
|
|
.name = "extalt_clkin_ck",
|
|
|
|
.rate = 59000000,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk pad_clks_ck = {
|
|
|
|
.name = "pad_clks_ck",
|
|
|
|
.rate = 12000000,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk pad_slimbus_core_clks_ck = {
|
|
|
|
.name = "pad_slimbus_core_clks_ck",
|
|
|
|
.rate = 12000000,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk secure_32k_clk_src_ck = {
|
|
|
|
.name = "secure_32k_clk_src_ck",
|
|
|
|
.rate = 32768,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk slimbus_clk = {
|
|
|
|
.name = "slimbus_clk",
|
|
|
|
.rate = 12000000,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk sys_32k_ck = {
|
|
|
|
.name = "sys_32k_ck",
|
|
|
|
.rate = 32768,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk virt_12000000_ck = {
|
|
|
|
.name = "virt_12000000_ck",
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.rate = 12000000,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk virt_13000000_ck = {
|
|
|
|
.name = "virt_13000000_ck",
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.rate = 13000000,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk virt_16800000_ck = {
|
|
|
|
.name = "virt_16800000_ck",
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.rate = 16800000,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk virt_19200000_ck = {
|
|
|
|
.name = "virt_19200000_ck",
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.rate = 19200000,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk virt_26000000_ck = {
|
|
|
|
.name = "virt_26000000_ck",
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.rate = 26000000,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk virt_27000000_ck = {
|
|
|
|
.name = "virt_27000000_ck",
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.rate = 27000000,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk virt_38400000_ck = {
|
|
|
|
.name = "virt_38400000_ck",
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.rate = 38400000,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_0_rates[] = {
|
|
|
|
{ .div = 1, .val = 0, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_1_rates[] = {
|
|
|
|
{ .div = 1, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_2_rates[] = {
|
|
|
|
{ .div = 1, .val = 2, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_3_rates[] = {
|
|
|
|
{ .div = 1, .val = 3, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_4_rates[] = {
|
|
|
|
{ .div = 1, .val = 4, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_5_rates[] = {
|
|
|
|
{ .div = 1, .val = 5, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_6_rates[] = {
|
|
|
|
{ .div = 1, .val = 6, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div_1_7_rates[] = {
|
|
|
|
{ .div = 1, .val = 7, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel sys_clkin_sel[] = {
|
|
|
|
{ .parent = &virt_12000000_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = &virt_13000000_ck, .rates = div_1_2_rates },
|
|
|
|
{ .parent = &virt_16800000_ck, .rates = div_1_3_rates },
|
|
|
|
{ .parent = &virt_19200000_ck, .rates = div_1_4_rates },
|
|
|
|
{ .parent = &virt_26000000_ck, .rates = div_1_5_rates },
|
|
|
|
{ .parent = &virt_27000000_ck, .rates = div_1_6_rates },
|
|
|
|
{ .parent = &virt_38400000_ck, .rates = div_1_7_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk sys_clkin_ck = {
|
|
|
|
.name = "sys_clkin_ck",
|
|
|
|
.rate = 38400000,
|
|
|
|
.clksel = sys_clkin_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_SYS_CLKSEL,
|
|
|
|
.clksel_mask = OMAP4430_SYS_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk tie_low_clock_ck = {
|
|
|
|
.name = "tie_low_clock_ck",
|
|
|
|
.rate = 0,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
2009-12-08 18:46:28 -07:00
|
|
|
static struct clk utmi_phy_clkout_ck = {
|
|
|
|
.name = "utmi_phy_clkout_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.rate = 60000000,
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk xclk60mhsp1_ck = {
|
|
|
|
.name = "xclk60mhsp1_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.rate = 60000000,
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk xclk60mhsp2_ck = {
|
|
|
|
.name = "xclk60mhsp2_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.rate = 60000000,
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk xclk60motg_ck = {
|
|
|
|
.name = "xclk60motg_ck",
|
|
|
|
.rate = 60000000,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Module clocks and DPLL outputs */
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static const struct clksel abe_dpll_bypass_clk_mux_sel[] = {
|
|
|
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &sys_32k_ck, .rates = div_1_1_rates },
|
2009-12-08 18:46:28 -07:00
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk abe_dpll_bypass_clk_mux_ck = {
|
|
|
|
.name = "abe_dpll_bypass_clk_mux_ck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.ops = &clkops_null,
|
2010-09-27 14:02:54 -06:00
|
|
|
.recalc = &followparent_recalc,
|
2009-12-08 18:46:28 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk abe_dpll_refclk_mux_ck = {
|
|
|
|
.name = "abe_dpll_refclk_mux_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
2009-12-08 18:46:28 -07:00
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_ABE_PLL_REF_CLKSEL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* DPLL_ABE */
|
|
|
|
static struct dpll_data dpll_abe_dd = {
|
|
|
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_ABE,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clk_bypass = &abe_dpll_bypass_clk_mux_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clk_ref = &abe_dpll_refclk_mux_ck,
|
|
|
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_ABE,
|
|
|
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
|
|
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_ABE,
|
|
|
|
.idlest_reg = OMAP4430_CM_IDLEST_DPLL_ABE,
|
|
|
|
.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 = OMAP4430_MAX_DPLL_MULT,
|
|
|
|
.max_divider = OMAP4430_MAX_DPLL_DIV,
|
|
|
|
.min_divider = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct clk dpll_abe_ck = {
|
|
|
|
.name = "dpll_abe_ck",
|
|
|
|
.parent = &abe_dpll_refclk_mux_ck,
|
|
|
|
.dpll_data = &dpll_abe_dd,
|
2009-12-08 18:47:17 -07:00
|
|
|
.init = &omap2_init_dpll_parent,
|
OMAP3/4 clock: split into per-chip family files
clock34xx_data.c now contains data for the OMAP34xx family, the
OMAP36xx family, and the OMAP3517 family, so rename it to
clock3xxx_data.c. Rename clock34xx.c to clock3xxx.c, and move the
chip family-specific clock functions to clock34xx.c, clock36xx.c, or
clock3517.c, as appropriate. So now "clock3xxx.*" refers to the OMAP3
superset.
The main goal here is to prepare to compile chip family-specific clock
functions only for kernel builds that target that chip family. To get to
that point, we also need to add CONFIG_SOC_* options for those other
chip families; that will be done in future patches, planned for 2.6.35.
OMAP4 is also affected by this. It duplicated the OMAP3 non-CORE DPLL
clkops structure. The OMAP4 variant of this clkops structure has been
removed, and since there was nothing else currently in clock44xx.c, it
too has been removed -- it can always be added back later when there
is some content for it. (The OMAP4 clock autogeneration scripts have been
updated accordingly.)
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Rajendra Nayak <rnayak@ti.com>
Cc: Ranjith Lohithakshan <ranjithl@ti.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-02-22 22:09:20 -07:00
|
|
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &omap3_dpll_recalc,
|
|
|
|
.round_rate = &omap2_dpll_round_rate,
|
|
|
|
.set_rate = &omap3_noncore_dpll_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_abe_m2x2_ck = {
|
|
|
|
.name = "dpll_abe_m2x2_ck",
|
|
|
|
.parent = &dpll_abe_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk abe_24m_fclk = {
|
|
|
|
.name = "abe_24m_fclk",
|
|
|
|
.parent = &dpll_abe_m2x2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div3_1to4_rates[] = {
|
|
|
|
{ .div = 1, .val = 0, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 2, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 4, .val = 2, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel abe_clk_div[] = {
|
|
|
|
{ .parent = &dpll_abe_m2x2_ck, .rates = div3_1to4_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk abe_clk = {
|
|
|
|
.name = "abe_clk",
|
|
|
|
.parent = &dpll_abe_m2x2_ck,
|
|
|
|
.clksel = abe_clk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_ABE,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_OPP_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
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 },
|
|
|
|
};
|
|
|
|
|
2009-12-08 18:46:28 -07:00
|
|
|
static const struct clksel aess_fclk_div[] = {
|
|
|
|
{ .parent = &abe_clk, .rates = div2_1to2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk aess_fclk = {
|
|
|
|
.name = "aess_fclk",
|
|
|
|
.parent = &abe_clk,
|
|
|
|
.clksel = aess_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_AESS_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_AESS_FCLK_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div31_1to31_rates[] = {
|
2010-01-19 17:30:55 -07:00
|
|
|
{ .div = 1, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 2, .val = 2, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 3, .val = 3, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 4, .val = 4, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 5, .val = 5, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 6, .val = 6, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 7, .val = 7, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 8, .val = 8, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 9, .val = 9, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 10, .val = 10, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 11, .val = 11, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 12, .val = 12, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 13, .val = 13, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 14, .val = 14, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 15, .val = 15, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 16, .val = 16, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 17, .val = 17, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 18, .val = 18, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 19, .val = 19, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 20, .val = 20, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 21, .val = 21, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 22, .val = 22, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 23, .val = 23, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 24, .val = 24, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 25, .val = 25, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 26, .val = 26, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 27, .val = 27, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 28, .val = 28, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 29, .val = 29, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 30, .val = 30, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 31, .val = 31, .flags = RATE_IN_4430 },
|
2009-12-08 18:46:28 -07:00
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dpll_abe_m3_div[] = {
|
|
|
|
{ .parent = &dpll_abe_ck, .rates = div31_1to31_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_abe_m3_ck = {
|
|
|
|
.name = "dpll_abe_m3_ck",
|
|
|
|
.parent = &dpll_abe_ck,
|
|
|
|
.clksel = dpll_abe_m3_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M3_DPLL_ABE,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUTHIF_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel core_hsd_byp_clk_mux_sel[] = {
|
2010-09-27 14:02:54 -06:00
|
|
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
2009-12-08 18:46:28 -07:00
|
|
|
{ .parent = &dpll_abe_m3_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk core_hsd_byp_clk_mux_ck = {
|
|
|
|
.name = "core_hsd_byp_clk_mux_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clksel = core_hsd_byp_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_DPLL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_BYP_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* DPLL_CORE */
|
|
|
|
static struct dpll_data dpll_core_dd = {
|
|
|
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_CORE,
|
|
|
|
.clk_bypass = &core_hsd_byp_clk_mux_ck,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clk_ref = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_CORE,
|
|
|
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
|
|
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_CORE,
|
|
|
|
.idlest_reg = OMAP4430_CM_IDLEST_DPLL_CORE,
|
|
|
|
.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 = OMAP4430_MAX_DPLL_MULT,
|
|
|
|
.max_divider = OMAP4430_MAX_DPLL_DIV,
|
|
|
|
.min_divider = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct clk dpll_core_ck = {
|
|
|
|
.name = "dpll_core_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.dpll_data = &dpll_core_dd,
|
2009-12-08 18:47:17 -07:00
|
|
|
.init = &omap2_init_dpll_parent,
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap3_dpll_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dpll_core_m6_div[] = {
|
|
|
|
{ .parent = &dpll_core_ck, .rates = div31_1to31_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_core_m6_ck = {
|
|
|
|
.name = "dpll_core_m6_ck",
|
|
|
|
.parent = &dpll_core_ck,
|
|
|
|
.clksel = dpll_core_m6_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M6_DPLL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT3_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dbgclk_mux_sel[] = {
|
|
|
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &dpll_core_m6_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dbgclk_mux_ck = {
|
|
|
|
.name = "dbgclk_mux_ck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_core_m2_ck = {
|
|
|
|
.name = "dpll_core_m2_ck",
|
|
|
|
.parent = &dpll_core_ck,
|
|
|
|
.clksel = dpll_core_m6_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M2_DPLL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUT_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk ddrphy_ck = {
|
|
|
|
.name = "ddrphy_ck",
|
|
|
|
.parent = &dpll_core_m2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_core_m5_ck = {
|
|
|
|
.name = "dpll_core_m5_ck",
|
|
|
|
.parent = &dpll_core_ck,
|
|
|
|
.clksel = dpll_core_m6_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M5_DPLL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT2_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel div_core_div[] = {
|
|
|
|
{ .parent = &dpll_core_m5_ck, .rates = div2_1to2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk div_core_ck = {
|
|
|
|
.name = "div_core_ck",
|
|
|
|
.parent = &dpll_core_m5_ck,
|
|
|
|
.clksel = div_core_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_CORE_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div4_1to8_rates[] = {
|
|
|
|
{ .div = 1, .val = 0, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 2, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 4, .val = 2, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 8, .val = 3, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel div_iva_hs_clk_div[] = {
|
|
|
|
{ .parent = &dpll_core_m5_ck, .rates = div4_1to8_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk div_iva_hs_clk = {
|
|
|
|
.name = "div_iva_hs_clk",
|
|
|
|
.parent = &dpll_core_m5_ck,
|
|
|
|
.clksel = div_iva_hs_clk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_BYPCLK_DPLL_IVA,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_0_1_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk div_mpu_hs_clk = {
|
|
|
|
.name = "div_mpu_hs_clk",
|
|
|
|
.parent = &dpll_core_m5_ck,
|
|
|
|
.clksel = div_iva_hs_clk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_BYPCLK_DPLL_MPU,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_0_1_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_core_m4_ck = {
|
|
|
|
.name = "dpll_core_m4_ck",
|
|
|
|
.parent = &dpll_core_ck,
|
|
|
|
.clksel = dpll_core_m6_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M4_DPLL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT1_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dll_clk_div_ck = {
|
|
|
|
.name = "dll_clk_div_ck",
|
|
|
|
.parent = &dpll_core_m4_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_abe_m2_ck = {
|
|
|
|
.name = "dpll_abe_m2_ck",
|
|
|
|
.parent = &dpll_abe_ck,
|
|
|
|
.clksel = dpll_abe_m3_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M2_DPLL_ABE,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUT_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_core_m3_ck = {
|
|
|
|
.name = "dpll_core_m3_ck",
|
|
|
|
.parent = &dpll_core_ck,
|
|
|
|
.clksel = dpll_core_m6_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M3_DPLL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUTHIF_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_core_m7_ck = {
|
|
|
|
.name = "dpll_core_m7_ck",
|
|
|
|
.parent = &dpll_core_ck,
|
|
|
|
.clksel = dpll_core_m6_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M7_DPLL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT4_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel iva_hsd_byp_clk_mux_sel[] = {
|
2010-09-27 14:02:54 -06:00
|
|
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
2009-12-08 18:46:28 -07:00
|
|
|
{ .parent = &div_iva_hs_clk, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk iva_hsd_byp_clk_mux_ck = {
|
|
|
|
.name = "iva_hsd_byp_clk_mux_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 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,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clk_ref = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.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 = OMAP4430_MAX_DPLL_MULT,
|
|
|
|
.max_divider = OMAP4430_MAX_DPLL_DIV,
|
|
|
|
.min_divider = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct clk dpll_iva_ck = {
|
|
|
|
.name = "dpll_iva_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.dpll_data = &dpll_iva_dd,
|
2009-12-08 18:47:17 -07:00
|
|
|
.init = &omap2_init_dpll_parent,
|
OMAP3/4 clock: split into per-chip family files
clock34xx_data.c now contains data for the OMAP34xx family, the
OMAP36xx family, and the OMAP3517 family, so rename it to
clock3xxx_data.c. Rename clock34xx.c to clock3xxx.c, and move the
chip family-specific clock functions to clock34xx.c, clock36xx.c, or
clock3517.c, as appropriate. So now "clock3xxx.*" refers to the OMAP3
superset.
The main goal here is to prepare to compile chip family-specific clock
functions only for kernel builds that target that chip family. To get to
that point, we also need to add CONFIG_SOC_* options for those other
chip families; that will be done in future patches, planned for 2.6.35.
OMAP4 is also affected by this. It duplicated the OMAP3 non-CORE DPLL
clkops structure. The OMAP4 variant of this clkops structure has been
removed, and since there was nothing else currently in clock44xx.c, it
too has been removed -- it can always be added back later when there
is some content for it. (The OMAP4 clock autogeneration scripts have been
updated accordingly.)
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Rajendra Nayak <rnayak@ti.com>
Cc: Ranjith Lohithakshan <ranjithl@ti.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-02-22 22:09:20 -07:00
|
|
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &omap3_dpll_recalc,
|
|
|
|
.round_rate = &omap2_dpll_round_rate,
|
|
|
|
.set_rate = &omap3_noncore_dpll_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dpll_iva_m4_div[] = {
|
|
|
|
{ .parent = &dpll_iva_ck, .rates = div31_1to31_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_iva_m4_ck = {
|
|
|
|
.name = "dpll_iva_m4_ck",
|
|
|
|
.parent = &dpll_iva_ck,
|
|
|
|
.clksel = dpll_iva_m4_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M4_DPLL_IVA,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT1_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_iva_m5_ck = {
|
|
|
|
.name = "dpll_iva_m5_ck",
|
|
|
|
.parent = &dpll_iva_ck,
|
|
|
|
.clksel = dpll_iva_m4_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M5_DPLL_IVA,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT2_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* DPLL_MPU */
|
|
|
|
static struct dpll_data dpll_mpu_dd = {
|
|
|
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_MPU,
|
|
|
|
.clk_bypass = &div_mpu_hs_clk,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clk_ref = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_MPU,
|
|
|
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
|
|
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_MPU,
|
|
|
|
.idlest_reg = OMAP4430_CM_IDLEST_DPLL_MPU,
|
|
|
|
.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 = OMAP4430_MAX_DPLL_MULT,
|
|
|
|
.max_divider = OMAP4430_MAX_DPLL_DIV,
|
|
|
|
.min_divider = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct clk dpll_mpu_ck = {
|
|
|
|
.name = "dpll_mpu_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.dpll_data = &dpll_mpu_dd,
|
2009-12-08 18:47:17 -07:00
|
|
|
.init = &omap2_init_dpll_parent,
|
OMAP3/4 clock: split into per-chip family files
clock34xx_data.c now contains data for the OMAP34xx family, the
OMAP36xx family, and the OMAP3517 family, so rename it to
clock3xxx_data.c. Rename clock34xx.c to clock3xxx.c, and move the
chip family-specific clock functions to clock34xx.c, clock36xx.c, or
clock3517.c, as appropriate. So now "clock3xxx.*" refers to the OMAP3
superset.
The main goal here is to prepare to compile chip family-specific clock
functions only for kernel builds that target that chip family. To get to
that point, we also need to add CONFIG_SOC_* options for those other
chip families; that will be done in future patches, planned for 2.6.35.
OMAP4 is also affected by this. It duplicated the OMAP3 non-CORE DPLL
clkops structure. The OMAP4 variant of this clkops structure has been
removed, and since there was nothing else currently in clock44xx.c, it
too has been removed -- it can always be added back later when there
is some content for it. (The OMAP4 clock autogeneration scripts have been
updated accordingly.)
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Rajendra Nayak <rnayak@ti.com>
Cc: Ranjith Lohithakshan <ranjithl@ti.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-02-22 22:09:20 -07:00
|
|
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &omap3_dpll_recalc,
|
|
|
|
.round_rate = &omap2_dpll_round_rate,
|
|
|
|
.set_rate = &omap3_noncore_dpll_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dpll_mpu_m2_div[] = {
|
|
|
|
{ .parent = &dpll_mpu_ck, .rates = div31_1to31_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_mpu_m2_ck = {
|
|
|
|
.name = "dpll_mpu_m2_ck",
|
|
|
|
.parent = &dpll_mpu_ck,
|
|
|
|
.clksel = dpll_mpu_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M2_DPLL_MPU,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUT_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk per_hs_clk_div_ck = {
|
|
|
|
.name = "per_hs_clk_div_ck",
|
|
|
|
.parent = &dpll_abe_m3_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel per_hsd_byp_clk_mux_sel[] = {
|
2010-09-27 14:02:54 -06:00
|
|
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
2009-12-08 18:46:28 -07:00
|
|
|
{ .parent = &per_hs_clk_div_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk per_hsd_byp_clk_mux_ck = {
|
|
|
|
.name = "per_hsd_byp_clk_mux_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clksel = per_hsd_byp_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_DPLL_PER,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_BYP_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* DPLL_PER */
|
|
|
|
static struct dpll_data dpll_per_dd = {
|
|
|
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_PER,
|
|
|
|
.clk_bypass = &per_hsd_byp_clk_mux_ck,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clk_ref = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_PER,
|
|
|
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
|
|
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_PER,
|
|
|
|
.idlest_reg = OMAP4430_CM_IDLEST_DPLL_PER,
|
|
|
|
.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 = OMAP4430_MAX_DPLL_MULT,
|
|
|
|
.max_divider = OMAP4430_MAX_DPLL_DIV,
|
|
|
|
.min_divider = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct clk dpll_per_ck = {
|
|
|
|
.name = "dpll_per_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.dpll_data = &dpll_per_dd,
|
2009-12-08 18:47:17 -07:00
|
|
|
.init = &omap2_init_dpll_parent,
|
OMAP3/4 clock: split into per-chip family files
clock34xx_data.c now contains data for the OMAP34xx family, the
OMAP36xx family, and the OMAP3517 family, so rename it to
clock3xxx_data.c. Rename clock34xx.c to clock3xxx.c, and move the
chip family-specific clock functions to clock34xx.c, clock36xx.c, or
clock3517.c, as appropriate. So now "clock3xxx.*" refers to the OMAP3
superset.
The main goal here is to prepare to compile chip family-specific clock
functions only for kernel builds that target that chip family. To get to
that point, we also need to add CONFIG_SOC_* options for those other
chip families; that will be done in future patches, planned for 2.6.35.
OMAP4 is also affected by this. It duplicated the OMAP3 non-CORE DPLL
clkops structure. The OMAP4 variant of this clkops structure has been
removed, and since there was nothing else currently in clock44xx.c, it
too has been removed -- it can always be added back later when there
is some content for it. (The OMAP4 clock autogeneration scripts have been
updated accordingly.)
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Rajendra Nayak <rnayak@ti.com>
Cc: Ranjith Lohithakshan <ranjithl@ti.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-02-22 22:09:20 -07:00
|
|
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &omap3_dpll_recalc,
|
|
|
|
.round_rate = &omap2_dpll_round_rate,
|
|
|
|
.set_rate = &omap3_noncore_dpll_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dpll_per_m2_div[] = {
|
|
|
|
{ .parent = &dpll_per_ck, .rates = div31_1to31_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_per_m2_ck = {
|
|
|
|
.name = "dpll_per_m2_ck",
|
|
|
|
.parent = &dpll_per_ck,
|
|
|
|
.clksel = dpll_per_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M2_DPLL_PER,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUT_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_per_m2x2_ck = {
|
|
|
|
.name = "dpll_per_m2x2_ck",
|
|
|
|
.parent = &dpll_per_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_per_m3_ck = {
|
|
|
|
.name = "dpll_per_m3_ck",
|
|
|
|
.parent = &dpll_per_ck,
|
|
|
|
.clksel = dpll_per_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M3_DPLL_PER,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUTHIF_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_per_m4_ck = {
|
|
|
|
.name = "dpll_per_m4_ck",
|
|
|
|
.parent = &dpll_per_ck,
|
|
|
|
.clksel = dpll_per_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M4_DPLL_PER,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT1_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_per_m5_ck = {
|
|
|
|
.name = "dpll_per_m5_ck",
|
|
|
|
.parent = &dpll_per_ck,
|
|
|
|
.clksel = dpll_per_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M5_DPLL_PER,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT2_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_per_m6_ck = {
|
|
|
|
.name = "dpll_per_m6_ck",
|
|
|
|
.parent = &dpll_per_ck,
|
|
|
|
.clksel = dpll_per_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M6_DPLL_PER,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT3_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_per_m7_ck = {
|
|
|
|
.name = "dpll_per_m7_ck",
|
|
|
|
.parent = &dpll_per_ck,
|
|
|
|
.clksel = dpll_per_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M7_DPLL_PER,
|
|
|
|
.clksel_mask = OMAP4430_HSDIVIDER_CLKOUT4_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* DPLL_UNIPRO */
|
|
|
|
static struct dpll_data dpll_unipro_dd = {
|
|
|
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_UNIPRO,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clk_bypass = &sys_clkin_ck,
|
|
|
|
.clk_ref = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_UNIPRO,
|
|
|
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
|
|
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_UNIPRO,
|
|
|
|
.idlest_reg = OMAP4430_CM_IDLEST_DPLL_UNIPRO,
|
|
|
|
.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 = OMAP4430_MAX_DPLL_MULT,
|
|
|
|
.max_divider = OMAP4430_MAX_DPLL_DIV,
|
|
|
|
.min_divider = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct clk dpll_unipro_ck = {
|
|
|
|
.name = "dpll_unipro_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.dpll_data = &dpll_unipro_dd,
|
2009-12-08 18:47:17 -07:00
|
|
|
.init = &omap2_init_dpll_parent,
|
OMAP3/4 clock: split into per-chip family files
clock34xx_data.c now contains data for the OMAP34xx family, the
OMAP36xx family, and the OMAP3517 family, so rename it to
clock3xxx_data.c. Rename clock34xx.c to clock3xxx.c, and move the
chip family-specific clock functions to clock34xx.c, clock36xx.c, or
clock3517.c, as appropriate. So now "clock3xxx.*" refers to the OMAP3
superset.
The main goal here is to prepare to compile chip family-specific clock
functions only for kernel builds that target that chip family. To get to
that point, we also need to add CONFIG_SOC_* options for those other
chip families; that will be done in future patches, planned for 2.6.35.
OMAP4 is also affected by this. It duplicated the OMAP3 non-CORE DPLL
clkops structure. The OMAP4 variant of this clkops structure has been
removed, and since there was nothing else currently in clock44xx.c, it
too has been removed -- it can always be added back later when there
is some content for it. (The OMAP4 clock autogeneration scripts have been
updated accordingly.)
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Rajendra Nayak <rnayak@ti.com>
Cc: Ranjith Lohithakshan <ranjithl@ti.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-02-22 22:09:20 -07:00
|
|
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &omap3_dpll_recalc,
|
|
|
|
.round_rate = &omap2_dpll_round_rate,
|
|
|
|
.set_rate = &omap3_noncore_dpll_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dpll_unipro_m2x2_div[] = {
|
|
|
|
{ .parent = &dpll_unipro_ck, .rates = div31_1to31_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_unipro_m2x2_ck = {
|
|
|
|
.name = "dpll_unipro_m2x2_ck",
|
|
|
|
.parent = &dpll_unipro_ck,
|
|
|
|
.clksel = dpll_unipro_m2x2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M2_DPLL_UNIPRO,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUT_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_hs_clk_div_ck = {
|
|
|
|
.name = "usb_hs_clk_div_ck",
|
|
|
|
.parent = &dpll_abe_m3_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* DPLL_USB */
|
|
|
|
static struct dpll_data dpll_usb_dd = {
|
|
|
|
.mult_div1_reg = OMAP4430_CM_CLKSEL_DPLL_USB,
|
|
|
|
.clk_bypass = &usb_hs_clk_div_ck,
|
2010-09-27 14:02:54 -06:00
|
|
|
.flags = DPLL_J_TYPE | DPLL_NO_DCO_SEL,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clk_ref = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.control_reg = OMAP4430_CM_CLKMODE_DPLL_USB,
|
|
|
|
.modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
|
|
|
|
.autoidle_reg = OMAP4430_CM_AUTOIDLE_DPLL_USB,
|
|
|
|
.idlest_reg = OMAP4430_CM_IDLEST_DPLL_USB,
|
|
|
|
.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 = OMAP4430_MAX_DPLL_MULT,
|
|
|
|
.max_divider = OMAP4430_MAX_DPLL_DIV,
|
|
|
|
.min_divider = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct clk dpll_usb_ck = {
|
|
|
|
.name = "dpll_usb_ck",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.dpll_data = &dpll_usb_dd,
|
2009-12-08 18:47:17 -07:00
|
|
|
.init = &omap2_init_dpll_parent,
|
OMAP3/4 clock: split into per-chip family files
clock34xx_data.c now contains data for the OMAP34xx family, the
OMAP36xx family, and the OMAP3517 family, so rename it to
clock3xxx_data.c. Rename clock34xx.c to clock3xxx.c, and move the
chip family-specific clock functions to clock34xx.c, clock36xx.c, or
clock3517.c, as appropriate. So now "clock3xxx.*" refers to the OMAP3
superset.
The main goal here is to prepare to compile chip family-specific clock
functions only for kernel builds that target that chip family. To get to
that point, we also need to add CONFIG_SOC_* options for those other
chip families; that will be done in future patches, planned for 2.6.35.
OMAP4 is also affected by this. It duplicated the OMAP3 non-CORE DPLL
clkops structure. The OMAP4 variant of this clkops structure has been
removed, and since there was nothing else currently in clock44xx.c, it
too has been removed -- it can always be added back later when there
is some content for it. (The OMAP4 clock autogeneration scripts have been
updated accordingly.)
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Benoît Cousson <b-cousson@ti.com>
Cc: Rajendra Nayak <rnayak@ti.com>
Cc: Ranjith Lohithakshan <ranjithl@ti.com>
Cc: Tony Lindgren <tony@atomide.com>
2010-02-22 22:09:20 -07:00
|
|
|
.ops = &clkops_omap3_noncore_dpll_ops,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &omap3_dpll_recalc,
|
|
|
|
.round_rate = &omap2_dpll_round_rate,
|
|
|
|
.set_rate = &omap3_noncore_dpll_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_usb_clkdcoldo_ck = {
|
|
|
|
.name = "dpll_usb_clkdcoldo_ck",
|
|
|
|
.parent = &dpll_usb_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dpll_usb_m2_div[] = {
|
|
|
|
{ .parent = &dpll_usb_ck, .rates = div31_1to31_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dpll_usb_m2_ck = {
|
|
|
|
.name = "dpll_usb_m2_ck",
|
|
|
|
.parent = &dpll_usb_ck,
|
|
|
|
.clksel = dpll_usb_m2_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_DIV_M2_DPLL_USB,
|
|
|
|
.clksel_mask = OMAP4430_DPLL_CLKOUT_DIV_0_6_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel ducati_clk_mux_sel[] = {
|
|
|
|
{ .parent = &div_core_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &dpll_per_m6_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk ducati_clk_mux_ck = {
|
|
|
|
.name = "ducati_clk_mux_ck",
|
|
|
|
.parent = &div_core_ck,
|
|
|
|
.clksel = ducati_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_DUCATI_ISS_ROOT,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk func_12m_fclk = {
|
|
|
|
.name = "func_12m_fclk",
|
|
|
|
.parent = &dpll_per_m2x2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk func_24m_clk = {
|
|
|
|
.name = "func_24m_clk",
|
|
|
|
.parent = &dpll_per_m2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk func_24mc_fclk = {
|
|
|
|
.name = "func_24mc_fclk",
|
|
|
|
.parent = &dpll_per_m2x2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div2_4to8_rates[] = {
|
|
|
|
{ .div = 4, .val = 0, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 8, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_48m_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_per_m2x2_ck, .rates = div2_4to8_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk func_48m_fclk = {
|
|
|
|
.name = "func_48m_fclk",
|
|
|
|
.parent = &dpll_per_m2x2_ck,
|
|
|
|
.clksel = func_48m_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_SCALE_FCLK,
|
|
|
|
.clksel_mask = OMAP4430_SCALE_FCLK_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk func_48mc_fclk = {
|
|
|
|
.name = "func_48mc_fclk",
|
|
|
|
.parent = &dpll_per_m2x2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div2_2to4_rates[] = {
|
|
|
|
{ .div = 2, .val = 0, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 4, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_64m_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_per_m4_ck, .rates = div2_2to4_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk func_64m_fclk = {
|
|
|
|
.name = "func_64m_fclk",
|
|
|
|
.parent = &dpll_per_m4_ck,
|
|
|
|
.clksel = func_64m_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_SCALE_FCLK,
|
|
|
|
.clksel_mask = OMAP4430_SCALE_FCLK_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_96m_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_per_m2x2_ck, .rates = div2_2to4_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk func_96m_fclk = {
|
|
|
|
.name = "func_96m_fclk",
|
|
|
|
.parent = &dpll_per_m2x2_ck,
|
|
|
|
.clksel = func_96m_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_SCALE_FCLK,
|
|
|
|
.clksel_mask = OMAP4430_SCALE_FCLK_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel hsmmc6_fclk_sel[] = {
|
|
|
|
{ .parent = &func_64m_fclk, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &func_96m_fclk, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk hsmmc6_fclk = {
|
|
|
|
.name = "hsmmc6_fclk",
|
|
|
|
.parent = &func_64m_fclk,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel_rate div2_1to8_rates[] = {
|
|
|
|
{ .div = 1, .val = 0, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 8, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel init_60m_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_usb_m2_ck, .rates = div2_1to8_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk init_60m_fclk = {
|
|
|
|
.name = "init_60m_fclk",
|
|
|
|
.parent = &dpll_usb_m2_ck,
|
|
|
|
.clksel = init_60m_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_USB_60MHZ,
|
|
|
|
.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 l3_div_div[] = {
|
|
|
|
{ .parent = &div_core_ck, .rates = div2_1to2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk l3_div_ck = {
|
|
|
|
.name = "l3_div_ck",
|
|
|
|
.parent = &div_core_ck,
|
|
|
|
.clksel = l3_div_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_L3_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel l4_div_div[] = {
|
|
|
|
{ .parent = &l3_div_ck, .rates = div2_1to2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk l4_div_ck = {
|
|
|
|
.name = "l4_div_ck",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.clksel = l4_div_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_CLKSEL_CORE,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_L4_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk lp_clk_div_ck = {
|
|
|
|
.name = "lp_clk_div_ck",
|
|
|
|
.parent = &dpll_abe_m2x2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel l4_wkup_clk_mux_sel[] = {
|
|
|
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &lp_clk_div_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk l4_wkup_clk_mux_ck = {
|
|
|
|
.name = "l4_wkup_clk_mux_ck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = l4_wkup_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4_WKUP_CLKSEL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_0_0_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel per_abe_nc_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_abe_m2_ck, .rates = div2_1to2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk per_abe_nc_fclk = {
|
|
|
|
.name = "per_abe_nc_fclk",
|
|
|
|
.parent = &dpll_abe_m2_ck,
|
|
|
|
.clksel = per_abe_nc_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_SCALE_FCLK,
|
|
|
|
.clksel_mask = OMAP4430_SCALE_FCLK_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel mcasp2_fclk_sel[] = {
|
|
|
|
{ .parent = &func_96m_fclk, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &per_abe_nc_fclk, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk mcasp2_fclk = {
|
|
|
|
.name = "mcasp2_fclk",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk mcasp3_fclk = {
|
|
|
|
.name = "mcasp3_fclk",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk ocp_abe_iclk = {
|
|
|
|
.name = "ocp_abe_iclk",
|
|
|
|
.parent = &aess_fclk,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk per_abe_24m_fclk = {
|
|
|
|
.name = "per_abe_24m_fclk",
|
|
|
|
.parent = &dpll_abe_m2_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel pmd_stm_clock_mux_sel[] = {
|
|
|
|
{ .parent = &sys_clkin_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &dpll_core_m6_ck, .rates = div_1_1_rates },
|
2010-09-27 14:02:54 -06:00
|
|
|
{ .parent = &tie_low_clock_ck, .rates = div_1_2_rates },
|
2009-12-08 18:46:28 -07:00
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk pmd_stm_clock_mux_ck = {
|
|
|
|
.name = "pmd_stm_clock_mux_ck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk pmd_trace_clk_mux_ck = {
|
|
|
|
.name = "pmd_trace_clk_mux_ck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static const struct clksel syc_clk_div_div[] = {
|
|
|
|
{ .parent = &sys_clkin_ck, .rates = div2_1to2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2009-12-08 18:46:28 -07:00
|
|
|
static struct clk syc_clk_div_ck = {
|
|
|
|
.name = "syc_clk_div_ck",
|
|
|
|
.parent = &sys_clkin_ck,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clksel = syc_clk_div_div,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clksel_reg = OMAP4430_CM_ABE_DSS_SYS_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,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Leaf clocks controlled by modules */
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk aes1_fck = {
|
|
|
|
.name = "aes1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4SEC_AES1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_secure_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk aes2_fck = {
|
|
|
|
.name = "aes2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4SEC_AES2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_secure_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk aess_fck = {
|
|
|
|
.name = "aess_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_AESS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &aess_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk bandgap_fclk = {
|
|
|
|
.name = "bandgap_fclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_BANDGAP_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_BGAP_32K_SHIFT,
|
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk des3des_fck = {
|
|
|
|
.name = "des3des_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4SEC_DES3DES_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_secure_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel dmic_sync_mux_sel[] = {
|
|
|
|
{ .parent = &abe_24m_fclk, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &syc_clk_div_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = &func_24m_clk, .rates = div_1_2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dmic_sync_mux_ck = {
|
|
|
|
.name = "dmic_sync_mux_ck",
|
|
|
|
.parent = &abe_24m_fclk,
|
|
|
|
.clksel = dmic_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_DMIC_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_INTERNAL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_dmic_abe_gfclk_sel[] = {
|
|
|
|
{ .parent = &dmic_sync_mux_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &pad_clks_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = &slimbus_clk, .rates = div_1_2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged func_dmic_abe_gfclk into dmic */
|
|
|
|
static struct clk dmic_fck = {
|
|
|
|
.name = "dmic_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &dmic_sync_mux_ck,
|
|
|
|
.clksel = func_dmic_abe_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_DMIC_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_DMIC_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk dsp_fck = {
|
|
|
|
.name = "dsp_fck",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_TESLA_TESLA_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "tesla_clkdm",
|
|
|
|
.parent = &dpll_iva_m4_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk dss_sys_clk = {
|
|
|
|
.name = "dss_sys_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_SYS_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_dss_clkdm",
|
|
|
|
.parent = &syc_clk_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dss_tv_clk = {
|
|
|
|
.name = "dss_tv_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_TV_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_dss_clkdm",
|
|
|
|
.parent = &extalt_clkin_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dss_dss_clk = {
|
|
|
|
.name = "dss_dss_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_DSSCLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_dss_clkdm",
|
|
|
|
.parent = &dpll_per_m5_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk dss_48mhz_clk = {
|
|
|
|
.name = "dss_48mhz_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_48MHZ_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_dss_clkdm",
|
|
|
|
.parent = &func_48mc_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk dss_fck = {
|
|
|
|
.name = "dss_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l3_dss_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk efuse_ctrl_cust_fck = {
|
|
|
|
.name = "efuse_ctrl_cust_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
2010-09-27 14:02:54 -06:00
|
|
|
.enable_reg = OMAP4430_CM_CEFUSE_CEFUSE_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_cefuse_clkdm",
|
|
|
|
.parent = &sys_clkin_ck,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk emif1_fck = {
|
|
|
|
.name = "emif1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_MEMIF_EMIF_1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
2010-06-16 19:01:33 +03:00
|
|
|
.flags = ENABLE_ON_INIT,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clkdm_name = "l3_emif_clkdm",
|
|
|
|
.parent = &ddrphy_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk emif2_fck = {
|
|
|
|
.name = "emif2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_MEMIF_EMIF_2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
2010-06-16 19:01:33 +03:00
|
|
|
.flags = ENABLE_ON_INIT,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clkdm_name = "l3_emif_clkdm",
|
|
|
|
.parent = &ddrphy_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel fdif_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_per_m4_ck, .rates = div3_1to4_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged fdif_fclk into fdif */
|
|
|
|
static struct clk fdif_fck = {
|
|
|
|
.name = "fdif_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &dpll_per_m4_ck,
|
|
|
|
.clksel = fdif_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_CAM_FDIF_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_FCLK_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
.enable_reg = OMAP4430_CM_CAM_FDIF_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "iss_clkdm",
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk fpka_fck = {
|
|
|
|
.name = "fpka_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
2010-09-27 14:02:54 -06:00
|
|
|
.enable_reg = OMAP4430_CM_L4SEC_PKAEIP29_CLKCTRL,
|
2009-12-08 18:46:28 -07:00
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clkdm_name = "l4_secure_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
2009-12-08 18:46:28 -07:00
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk gpio1_dbclk = {
|
|
|
|
.name = "gpio1_dbclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_GPIO1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_DBCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk gpio1_ick = {
|
|
|
|
.name = "gpio1_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_GPIO1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
.parent = &l4_wkup_clk_mux_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk gpio2_dbclk = {
|
|
|
|
.name = "gpio2_dbclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_DBCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk gpio2_ick = {
|
|
|
|
.name = "gpio2_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk gpio3_dbclk = {
|
|
|
|
.name = "gpio3_dbclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_DBCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk gpio3_ick = {
|
|
|
|
.name = "gpio3_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk gpio4_dbclk = {
|
|
|
|
.name = "gpio4_dbclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_DBCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk gpio4_ick = {
|
|
|
|
.name = "gpio4_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk gpio5_dbclk = {
|
|
|
|
.name = "gpio5_dbclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO5_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_DBCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk gpio5_ick = {
|
|
|
|
.name = "gpio5_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO5_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk gpio6_dbclk = {
|
|
|
|
.name = "gpio6_dbclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO6_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_DBCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk gpio6_ick = {
|
|
|
|
.name = "gpio6_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_GPIO6_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk gpmc_ick = {
|
|
|
|
.name = "gpmc_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3_2_GPMC_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l3_2_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static const struct clksel sgx_clk_mux_sel[] = {
|
|
|
|
{ .parent = &dpll_core_m7_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &dpll_per_m7_ck, .rates = div_1_1_rates },
|
2009-12-08 18:46:28 -07:00
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
/* Merged sgx_clk_mux into gpu */
|
|
|
|
static struct clk gpu_fck = {
|
|
|
|
.name = "gpu_fck",
|
|
|
|
.parent = &dpll_core_m7_ck,
|
|
|
|
.clksel = sgx_clk_mux_sel,
|
2009-12-08 18:46:28 -07:00
|
|
|
.init = &omap2_init_clksel_parent,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clksel_reg = OMAP4430_CM_GFX_GFX_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_SGX_FCLK_MASK,
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
2010-09-27 14:02:54 -06:00
|
|
|
.enable_reg = OMAP4430_CM_GFX_GFX_CLKCTRL,
|
2009-12-08 18:46:28 -07:00
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clkdm_name = "l3_gfx_clkdm",
|
2009-12-08 18:46:28 -07:00
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk hdq1w_fck = {
|
|
|
|
.name = "hdq1w_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_HDQ1W_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_12m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static const struct clksel hsi_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_per_m2x2_ck, .rates = div3_1to4_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged hsi_fclk into hsi */
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk hsi_fck = {
|
|
|
|
.name = "hsi_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &dpll_per_m2x2_ck,
|
2010-09-27 14:02:54 -06:00
|
|
|
.clksel = hsi_fclk_div,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clksel_reg = OMAP4430_CM_L3INIT_HSI_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_24_25_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_HSI_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk i2c1_fck = {
|
|
|
|
.name = "i2c1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_I2C1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk i2c2_fck = {
|
|
|
|
.name = "i2c2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_I2C2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk i2c3_fck = {
|
|
|
|
.name = "i2c3_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_I2C3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk i2c4_fck = {
|
|
|
|
.name = "i2c4_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_I2C4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk ipu_fck = {
|
|
|
|
.name = "ipu_fck",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_DUCATI_DUCATI_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "ducati_clkdm",
|
|
|
|
.parent = &ducati_clk_mux_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk iss_ctrlclk = {
|
|
|
|
.name = "iss_ctrlclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_CAM_ISS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_CTRLCLK_SHIFT,
|
|
|
|
.clkdm_name = "iss_clkdm",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk iss_fck = {
|
|
|
|
.name = "iss_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_CAM_ISS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "iss_clkdm",
|
|
|
|
.parent = &ducati_clk_mux_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk iva_fck = {
|
|
|
|
.name = "iva_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_IVAHD_IVAHD_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "ivahd_clkdm",
|
|
|
|
.parent = &dpll_iva_m5_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk kbd_fck = {
|
|
|
|
.name = "kbd_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_KEYBOARD_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk l3_instr_ick = {
|
|
|
|
.name = "l3_instr_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INSTR_L3_INSTR_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l3_instr_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk l3_main_3_ick = {
|
|
|
|
.name = "l3_main_3_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INSTR_L3_3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l3_instr_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk mcasp_sync_mux_ck = {
|
|
|
|
.name = "mcasp_sync_mux_ck",
|
|
|
|
.parent = &abe_24m_fclk,
|
|
|
|
.clksel = dmic_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCASP_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_INTERNAL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_mcasp_abe_gfclk_sel[] = {
|
|
|
|
{ .parent = &mcasp_sync_mux_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &pad_clks_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = &slimbus_clk, .rates = div_1_2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged func_mcasp_abe_gfclk into mcasp */
|
|
|
|
static struct clk mcasp_fck = {
|
|
|
|
.name = "mcasp_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &mcasp_sync_mux_ck,
|
|
|
|
.clksel = func_mcasp_abe_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCASP_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_MCASP_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk mcbsp1_sync_mux_ck = {
|
|
|
|
.name = "mcbsp1_sync_mux_ck",
|
|
|
|
.parent = &abe_24m_fclk,
|
|
|
|
.clksel = dmic_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCBSP1_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_INTERNAL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_mcbsp1_gfclk_sel[] = {
|
|
|
|
{ .parent = &mcbsp1_sync_mux_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &pad_clks_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = &slimbus_clk, .rates = div_1_2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged func_mcbsp1_gfclk into mcbsp1 */
|
|
|
|
static struct clk mcbsp1_fck = {
|
|
|
|
.name = "mcbsp1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &mcbsp1_sync_mux_ck,
|
|
|
|
.clksel = func_mcbsp1_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCBSP1_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_MCBSP1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk mcbsp2_sync_mux_ck = {
|
|
|
|
.name = "mcbsp2_sync_mux_ck",
|
|
|
|
.parent = &abe_24m_fclk,
|
|
|
|
.clksel = dmic_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCBSP2_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_INTERNAL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_mcbsp2_gfclk_sel[] = {
|
|
|
|
{ .parent = &mcbsp2_sync_mux_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &pad_clks_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = &slimbus_clk, .rates = div_1_2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged func_mcbsp2_gfclk into mcbsp2 */
|
|
|
|
static struct clk mcbsp2_fck = {
|
|
|
|
.name = "mcbsp2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &mcbsp2_sync_mux_ck,
|
|
|
|
.clksel = func_mcbsp2_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCBSP2_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_MCBSP2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk mcbsp3_sync_mux_ck = {
|
|
|
|
.name = "mcbsp3_sync_mux_ck",
|
|
|
|
.parent = &abe_24m_fclk,
|
|
|
|
.clksel = dmic_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCBSP3_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_INTERNAL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel func_mcbsp3_gfclk_sel[] = {
|
|
|
|
{ .parent = &mcbsp3_sync_mux_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &pad_clks_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = &slimbus_clk, .rates = div_1_2_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged func_mcbsp3_gfclk into mcbsp3 */
|
|
|
|
static struct clk mcbsp3_fck = {
|
|
|
|
.name = "mcbsp3_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &mcbsp3_sync_mux_ck,
|
|
|
|
.clksel = func_mcbsp3_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_MCBSP3_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_MCBSP3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk mcbsp4_sync_mux_ck = {
|
|
|
|
.name = "mcbsp4_sync_mux_ck",
|
|
|
|
.parent = &func_96m_fclk,
|
|
|
|
.clksel = mcasp2_fclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_MCBSP4_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_INTERNAL_SOURCE_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel per_mcbsp4_gfclk_sel[] = {
|
|
|
|
{ .parent = &mcbsp4_sync_mux_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &pad_clks_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged per_mcbsp4_gfclk into mcbsp4 */
|
|
|
|
static struct clk mcbsp4_fck = {
|
|
|
|
.name = "mcbsp4_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &mcbsp4_sync_mux_ck,
|
|
|
|
.clksel = per_mcbsp4_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_MCBSP4_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_SOURCE_24_24_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MCBSP4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk mcpdm_fck = {
|
|
|
|
.name = "mcpdm_fck",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_PDM_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &pad_clks_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk mcspi1_fck = {
|
|
|
|
.name = "mcspi1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MCSPI1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk mcspi2_fck = {
|
|
|
|
.name = "mcspi2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MCSPI2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk mcspi3_fck = {
|
|
|
|
.name = "mcspi3_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MCSPI3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk mcspi4_fck = {
|
|
|
|
.name = "mcspi4_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MCSPI4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged hsmmc1_fclk into mmc1 */
|
|
|
|
static struct clk mmc1_fck = {
|
|
|
|
.name = "mmc1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &func_64m_fclk,
|
|
|
|
.clksel = hsmmc6_fclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L3INIT_MMC1_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_MMC1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
/* Merged hsmmc2_fclk into mmc2 */
|
|
|
|
static struct clk mmc2_fck = {
|
|
|
|
.name = "mmc2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.parent = &func_64m_fclk,
|
|
|
|
.clksel = hsmmc6_fclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L3INIT_MMC2_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_MMC2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk mmc3_fck = {
|
|
|
|
.name = "mmc3_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MMCSD3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk mmc4_fck = {
|
|
|
|
.name = "mmc4_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MMCSD4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk mmc5_fck = {
|
|
|
|
.name = "mmc5_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_MMCSD5_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:56 -06:00
|
|
|
static struct clk ocp2scp_usb_phy_phy_48m = {
|
|
|
|
.name = "ocp2scp_usb_phy_phy_48m",
|
2010-09-27 14:02:55 -06:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USBPHYOCP2SCP_CLKCTRL,
|
2010-09-27 14:02:56 -06:00
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_PHY_48M_SHIFT,
|
2010-09-27 14:02:55 -06:00
|
|
|
.clkdm_name = "l3_init_clkdm",
|
2010-09-27 14:02:56 -06:00
|
|
|
.parent = &func_48m_fclk,
|
2010-09-27 14:02:55 -06:00
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:56 -06:00
|
|
|
static struct clk ocp2scp_usb_phy_ick = {
|
|
|
|
.name = "ocp2scp_usb_phy_ick",
|
2010-09-27 14:02:55 -06:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USBPHYOCP2SCP_CLKCTRL,
|
2010-09-27 14:02:56 -06:00
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
2010-09-27 14:02:55 -06:00
|
|
|
.clkdm_name = "l3_init_clkdm",
|
2010-09-27 14:02:56 -06:00
|
|
|
.parent = &l4_div_ck,
|
2010-09-27 14:02:55 -06:00
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk ocp_wp_noc_ick = {
|
|
|
|
.name = "ocp_wp_noc_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INSTR_OCP_WP1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l3_instr_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk rng_ick = {
|
|
|
|
.name = "rng_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4SEC_RNG_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l4_secure_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk sha2md5_fck = {
|
|
|
|
.name = "sha2md5_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4SEC_SHA2MD51_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_secure_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk sl2if_ick = {
|
|
|
|
.name = "sl2if_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_IVAHD_SL2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "ivahd_clkdm",
|
|
|
|
.parent = &dpll_iva_m5_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk slimbus1_fclk_1 = {
|
|
|
|
.name = "slimbus1_fclk_1",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_SLIMBUS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_FCLK1_SHIFT,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &func_24m_clk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk slimbus1_fclk_0 = {
|
|
|
|
.name = "slimbus1_fclk_0",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_SLIMBUS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_FCLK0_SHIFT,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &abe_24m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk slimbus1_fclk_2 = {
|
|
|
|
.name = "slimbus1_fclk_2",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_SLIMBUS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_FCLK2_SHIFT,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &pad_clks_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk slimbus1_slimbus_clk = {
|
|
|
|
.name = "slimbus1_slimbus_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_SLIMBUS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_SLIMBUS_CLK_11_11_SHIFT,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &slimbus_clk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk slimbus1_fck = {
|
|
|
|
.name = "slimbus1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_SLIMBUS_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &ocp_abe_iclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk slimbus2_fclk_1 = {
|
|
|
|
.name = "slimbus2_fclk_1",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_SLIMBUS2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_PERABE24M_GFCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &per_abe_24m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk slimbus2_fclk_0 = {
|
|
|
|
.name = "slimbus2_fclk_0",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_SLIMBUS2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_PER24MC_GFCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_24mc_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk slimbus2_slimbus_clk = {
|
|
|
|
.name = "slimbus2_slimbus_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_SLIMBUS2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_SLIMBUS_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &pad_slimbus_core_clks_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk slimbus2_fck = {
|
|
|
|
.name = "slimbus2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_SLIMBUS2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk smartreflex_core_fck = {
|
|
|
|
.name = "smartreflex_core_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_ALWON_SR_CORE_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_ao_clkdm",
|
|
|
|
.parent = &l4_wkup_clk_mux_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk smartreflex_iva_fck = {
|
|
|
|
.name = "smartreflex_iva_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_ALWON_SR_IVA_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_ao_clkdm",
|
|
|
|
.parent = &l4_wkup_clk_mux_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk smartreflex_mpu_fck = {
|
|
|
|
.name = "smartreflex_mpu_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_ALWON_SR_MPU_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_ao_clkdm",
|
|
|
|
.parent = &l4_wkup_clk_mux_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
/* Merged dmt1_clk_mux into timer1 */
|
|
|
|
static struct clk timer1_fck = {
|
|
|
|
.name = "timer1_fck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_WKUP_TIMER1_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
2010-09-27 14:02:54 -06:00
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_TIMER1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged cm2_dm10_mux into timer10 */
|
|
|
|
static struct clk timer10_fck = {
|
|
|
|
.name = "timer10_fck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER10_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_DMTIMER10_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged cm2_dm11_mux into timer11 */
|
|
|
|
static struct clk timer11_fck = {
|
|
|
|
.name = "timer11_fck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER11_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_DMTIMER11_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged cm2_dm2_mux into timer2 */
|
|
|
|
static struct clk timer2_fck = {
|
|
|
|
.name = "timer2_fck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER2_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_DMTIMER2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged cm2_dm3_mux into timer3 */
|
|
|
|
static struct clk timer3_fck = {
|
|
|
|
.name = "timer3_fck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER3_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_DMTIMER3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged cm2_dm4_mux into timer4 */
|
|
|
|
static struct clk timer4_fck = {
|
|
|
|
.name = "timer4_fck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER4_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_DMTIMER4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel timer5_sync_mux_sel[] = {
|
|
|
|
{ .parent = &syc_clk_div_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &sys_32k_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged timer5_sync_mux into timer5 */
|
|
|
|
static struct clk timer5_fck = {
|
|
|
|
.name = "timer5_fck",
|
|
|
|
.parent = &syc_clk_div_ck,
|
|
|
|
.clksel = timer5_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_TIMER5_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_TIMER5_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged timer6_sync_mux into timer6 */
|
|
|
|
static struct clk timer6_fck = {
|
|
|
|
.name = "timer6_fck",
|
|
|
|
.parent = &syc_clk_div_ck,
|
|
|
|
.clksel = timer5_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_TIMER6_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_TIMER6_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged timer7_sync_mux into timer7 */
|
|
|
|
static struct clk timer7_fck = {
|
|
|
|
.name = "timer7_fck",
|
|
|
|
.parent = &syc_clk_div_ck,
|
|
|
|
.clksel = timer5_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_TIMER7_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_TIMER7_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged timer8_sync_mux into timer8 */
|
|
|
|
static struct clk timer8_fck = {
|
|
|
|
.name = "timer8_fck",
|
|
|
|
.parent = &syc_clk_div_ck,
|
|
|
|
.clksel = timer5_sync_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM1_ABE_TIMER8_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_TIMER8_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Merged cm2_dm9_mux into timer9 */
|
|
|
|
static struct clk timer9_fck = {
|
|
|
|
.name = "timer9_fck",
|
|
|
|
.parent = &sys_clkin_ck,
|
|
|
|
.clksel = abe_dpll_bypass_clk_mux_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L4PER_DMTIMER9_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_MASK,
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_DMTIMER9_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
2009-12-08 18:46:28 -07:00
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk uart1_fck = {
|
|
|
|
.name = "uart1_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_UART1_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk uart2_fck = {
|
|
|
|
.name = "uart2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_UART2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk uart3_fck = {
|
|
|
|
.name = "uart3_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_UART3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-02-22 22:09:39 -07:00
|
|
|
static struct clk uart4_fck = {
|
|
|
|
.name = "uart4_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L4PER_UART4_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_per_clkdm",
|
|
|
|
.parent = &func_48m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk usb_host_fs_fck = {
|
|
|
|
.name = "usb_host_fs_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
2010-09-27 14:02:54 -06:00
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_FS_CLKCTRL,
|
2009-12-08 18:46:28 -07:00
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
2010-09-27 14:02:54 -06:00
|
|
|
.parent = &func_48mc_fclk,
|
2009-12-08 18:46:28 -07:00
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk usb_host_hs_utmi_p3_clk = {
|
|
|
|
.name = "usb_host_hs_utmi_p3_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_UTMI_P3_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_host_hs_hsic60m_p1_clk = {
|
|
|
|
.name = "usb_host_hs_hsic60m_p1_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_HSIC60M_P1_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_host_hs_hsic60m_p2_clk = {
|
|
|
|
.name = "usb_host_hs_hsic60m_p2_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_HSIC60M_P2_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel utmi_p1_gfclk_sel[] = {
|
|
|
|
{ .parent = &init_60m_fclk, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &xclk60mhsp1_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk utmi_p1_gfclk = {
|
|
|
|
.name = "utmi_p1_gfclk",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.clksel = utmi_p1_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_UTMI_P1_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_host_hs_utmi_p1_clk = {
|
|
|
|
.name = "usb_host_hs_utmi_p1_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_UTMI_P1_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &utmi_p1_gfclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel utmi_p2_gfclk_sel[] = {
|
|
|
|
{ .parent = &init_60m_fclk, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &xclk60mhsp2_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk utmi_p2_gfclk = {
|
|
|
|
.name = "utmi_p2_gfclk",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.clksel = utmi_p2_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_UTMI_P2_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_host_hs_utmi_p2_clk = {
|
|
|
|
.name = "usb_host_hs_utmi_p2_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_UTMI_P2_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &utmi_p2_gfclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_host_hs_hsic480m_p1_clk = {
|
|
|
|
.name = "usb_host_hs_hsic480m_p1_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_HSIC480M_P1_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &dpll_usb_m2_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_host_hs_hsic480m_p2_clk = {
|
|
|
|
.name = "usb_host_hs_hsic480m_p2_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_HSIC480M_P2_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &dpll_usb_m2_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_host_hs_func48mclk = {
|
|
|
|
.name = "usb_host_hs_func48mclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_FUNC48MCLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &func_48mc_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk usb_host_hs_fck = {
|
|
|
|
.name = "usb_host_hs_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static const struct clksel otg_60m_gfclk_sel[] = {
|
|
|
|
{ .parent = &utmi_phy_clkout_ck, .rates = div_1_0_rates },
|
|
|
|
{ .parent = &xclk60motg_ck, .rates = div_1_1_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk otg_60m_gfclk = {
|
|
|
|
.name = "otg_60m_gfclk",
|
|
|
|
.parent = &utmi_phy_clkout_ck,
|
|
|
|
.clksel = otg_60m_gfclk_sel,
|
|
|
|
.init = &omap2_init_clksel_parent,
|
|
|
|
.clksel_reg = OMAP4430_CM_L3INIT_USB_OTG_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_60M_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_otg_hs_xclk = {
|
|
|
|
.name = "usb_otg_hs_xclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_OTG_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_XCLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &otg_60m_gfclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk usb_otg_hs_ick = {
|
|
|
|
.name = "usb_otg_hs_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_OTG_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &l3_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:56 -06:00
|
|
|
static struct clk usb_phy_cm_clk32k = {
|
|
|
|
.name = "usb_phy_cm_clk32k",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_ALWON_USBPHY_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_CLK32K_SHIFT,
|
|
|
|
.clkdm_name = "l4_ao_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:55 -06:00
|
|
|
static struct clk usb_tll_hs_usb_ch2_clk = {
|
|
|
|
.name = "usb_tll_hs_usb_ch2_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_TLL_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_USB_CH2_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_tll_hs_usb_ch0_clk = {
|
|
|
|
.name = "usb_tll_hs_usb_ch0_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_TLL_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_USB_CH0_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usb_tll_hs_usb_ch1_clk = {
|
|
|
|
.name = "usb_tll_hs_usb_ch1_clk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_TLL_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_USB_CH1_CLK_SHIFT,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &init_60m_fclk,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk usb_tll_hs_ick = {
|
|
|
|
.name = "usb_tll_hs_ick",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_L3INIT_USB_TLL_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
|
|
|
.clkdm_name = "l3_init_clkdm",
|
|
|
|
.parent = &l4_div_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:56 -06:00
|
|
|
static const struct clksel_rate div2_14to18_rates[] = {
|
|
|
|
{ .div = 14, .val = 0, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 18, .val = 1, .flags = RATE_IN_4430 },
|
|
|
|
{ .div = 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel usim_fclk_div[] = {
|
|
|
|
{ .parent = &dpll_per_m4_ck, .rates = div2_14to18_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usim_ck = {
|
|
|
|
.name = "usim_ck",
|
|
|
|
.parent = &dpll_per_m4_ck,
|
|
|
|
.clksel = usim_fclk_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_WKUP_USIM_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_DIV_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk usim_fclk = {
|
|
|
|
.name = "usim_fclk",
|
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_USIM_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_OPTFCLKEN_FCLK_SHIFT,
|
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
.parent = &usim_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk usim_fck = {
|
|
|
|
.name = "usim_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_USIM_CLKCTRL,
|
2010-09-27 14:02:54 -06:00
|
|
|
.enable_bit = OMAP4430_MODULEMODE_HWCTRL,
|
2009-12-08 18:46:28 -07:00
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk wd_timer2_fck = {
|
|
|
|
.name = "wd_timer2_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM_WKUP_WDT2_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "l4_wkup_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
2010-09-27 14:02:54 -06:00
|
|
|
static struct clk wd_timer3_fck = {
|
|
|
|
.name = "wd_timer3_fck",
|
2009-12-08 18:46:28 -07:00
|
|
|
.ops = &clkops_omap2_dflt,
|
|
|
|
.enable_reg = OMAP4430_CM1_ABE_WDT3_CLKCTRL,
|
|
|
|
.enable_bit = OMAP4430_MODULEMODE_SWCTRL,
|
|
|
|
.clkdm_name = "abe_clkdm",
|
|
|
|
.parent = &sys_32k_ck,
|
|
|
|
.recalc = &followparent_recalc,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Remaining optional clocks */
|
|
|
|
static const struct clksel stm_clk_div_div[] = {
|
|
|
|
{ .parent = &pmd_stm_clock_mux_ck, .rates = div3_1to4_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk stm_clk_div_ck = {
|
|
|
|
.name = "stm_clk_div_ck",
|
|
|
|
.parent = &pmd_stm_clock_mux_ck,
|
|
|
|
.clksel = stm_clk_div_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_EMU_DEBUGSS_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_PMD_STM_CLK_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
static const struct clksel trace_clk_div_div[] = {
|
|
|
|
{ .parent = &pmd_trace_clk_mux_ck, .rates = div3_1to4_rates },
|
|
|
|
{ .parent = NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct clk trace_clk_div_ck = {
|
|
|
|
.name = "trace_clk_div_ck",
|
|
|
|
.parent = &pmd_trace_clk_mux_ck,
|
|
|
|
.clksel = trace_clk_div_div,
|
|
|
|
.clksel_reg = OMAP4430_CM_EMU_DEBUGSS_CLKCTRL,
|
|
|
|
.clksel_mask = OMAP4430_CLKSEL_PMD_TRACE_CLK_MASK,
|
|
|
|
.ops = &clkops_null,
|
|
|
|
.recalc = &omap2_clksel_recalc,
|
|
|
|
.round_rate = &omap2_clksel_round_rate,
|
|
|
|
.set_rate = &omap2_clksel_set_rate,
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* clkdev
|
|
|
|
*/
|
|
|
|
|
|
|
|
static struct omap_clk omap44xx_clks[] = {
|
|
|
|
CLK(NULL, "extalt_clkin_ck", &extalt_clkin_ck, CK_443X),
|
|
|
|
CLK(NULL, "pad_clks_ck", &pad_clks_ck, CK_443X),
|
|
|
|
CLK(NULL, "pad_slimbus_core_clks_ck", &pad_slimbus_core_clks_ck, CK_443X),
|
|
|
|
CLK(NULL, "secure_32k_clk_src_ck", &secure_32k_clk_src_ck, CK_443X),
|
|
|
|
CLK(NULL, "slimbus_clk", &slimbus_clk, CK_443X),
|
|
|
|
CLK(NULL, "sys_32k_ck", &sys_32k_ck, CK_443X),
|
|
|
|
CLK(NULL, "virt_12000000_ck", &virt_12000000_ck, CK_443X),
|
|
|
|
CLK(NULL, "virt_13000000_ck", &virt_13000000_ck, CK_443X),
|
|
|
|
CLK(NULL, "virt_16800000_ck", &virt_16800000_ck, CK_443X),
|
|
|
|
CLK(NULL, "virt_19200000_ck", &virt_19200000_ck, CK_443X),
|
|
|
|
CLK(NULL, "virt_26000000_ck", &virt_26000000_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, "sys_clkin_ck", &sys_clkin_ck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "tie_low_clock_ck", &tie_low_clock_ck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "utmi_phy_clkout_ck", &utmi_phy_clkout_ck, CK_443X),
|
|
|
|
CLK(NULL, "xclk60mhsp1_ck", &xclk60mhsp1_ck, CK_443X),
|
|
|
|
CLK(NULL, "xclk60mhsp2_ck", &xclk60mhsp2_ck, CK_443X),
|
|
|
|
CLK(NULL, "xclk60motg_ck", &xclk60motg_ck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "abe_dpll_bypass_clk_mux_ck", &abe_dpll_bypass_clk_mux_ck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
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_m2x2_ck", &dpll_abe_m2x2_ck, CK_443X),
|
|
|
|
CLK(NULL, "abe_24m_fclk", &abe_24m_fclk, CK_443X),
|
|
|
|
CLK(NULL, "abe_clk", &abe_clk, CK_443X),
|
|
|
|
CLK(NULL, "aess_fclk", &aess_fclk, CK_443X),
|
|
|
|
CLK(NULL, "dpll_abe_m3_ck", &dpll_abe_m3_ck, CK_443X),
|
|
|
|
CLK(NULL, "core_hsd_byp_clk_mux_ck", &core_hsd_byp_clk_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_core_ck", &dpll_core_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_core_m6_ck", &dpll_core_m6_ck, CK_443X),
|
|
|
|
CLK(NULL, "dbgclk_mux_ck", &dbgclk_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_core_m2_ck", &dpll_core_m2_ck, CK_443X),
|
|
|
|
CLK(NULL, "ddrphy_ck", &ddrphy_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_core_m5_ck", &dpll_core_m5_ck, CK_443X),
|
|
|
|
CLK(NULL, "div_core_ck", &div_core_ck, CK_443X),
|
|
|
|
CLK(NULL, "div_iva_hs_clk", &div_iva_hs_clk, CK_443X),
|
|
|
|
CLK(NULL, "div_mpu_hs_clk", &div_mpu_hs_clk, CK_443X),
|
|
|
|
CLK(NULL, "dpll_core_m4_ck", &dpll_core_m4_ck, CK_443X),
|
|
|
|
CLK(NULL, "dll_clk_div_ck", &dll_clk_div_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_abe_m2_ck", &dpll_abe_m2_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_core_m3_ck", &dpll_core_m3_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_core_m7_ck", &dpll_core_m7_ck, CK_443X),
|
|
|
|
CLK(NULL, "iva_hsd_byp_clk_mux_ck", &iva_hsd_byp_clk_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_iva_ck", &dpll_iva_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_iva_m4_ck", &dpll_iva_m4_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_iva_m5_ck", &dpll_iva_m5_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_mpu_ck", &dpll_mpu_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_mpu_m2_ck", &dpll_mpu_m2_ck, CK_443X),
|
|
|
|
CLK(NULL, "per_hs_clk_div_ck", &per_hs_clk_div_ck, CK_443X),
|
|
|
|
CLK(NULL, "per_hsd_byp_clk_mux_ck", &per_hsd_byp_clk_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_ck", &dpll_per_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_m2_ck", &dpll_per_m2_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_m2x2_ck", &dpll_per_m2x2_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_m3_ck", &dpll_per_m3_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_m4_ck", &dpll_per_m4_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_m5_ck", &dpll_per_m5_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_m6_ck", &dpll_per_m6_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_per_m7_ck", &dpll_per_m7_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_unipro_ck", &dpll_unipro_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_unipro_m2x2_ck", &dpll_unipro_m2x2_ck, CK_443X),
|
|
|
|
CLK(NULL, "usb_hs_clk_div_ck", &usb_hs_clk_div_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_usb_ck", &dpll_usb_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_usb_clkdcoldo_ck", &dpll_usb_clkdcoldo_ck, CK_443X),
|
|
|
|
CLK(NULL, "dpll_usb_m2_ck", &dpll_usb_m2_ck, CK_443X),
|
|
|
|
CLK(NULL, "ducati_clk_mux_ck", &ducati_clk_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "func_12m_fclk", &func_12m_fclk, CK_443X),
|
|
|
|
CLK(NULL, "func_24m_clk", &func_24m_clk, CK_443X),
|
|
|
|
CLK(NULL, "func_24mc_fclk", &func_24mc_fclk, CK_443X),
|
|
|
|
CLK(NULL, "func_48m_fclk", &func_48m_fclk, CK_443X),
|
|
|
|
CLK(NULL, "func_48mc_fclk", &func_48mc_fclk, CK_443X),
|
|
|
|
CLK(NULL, "func_64m_fclk", &func_64m_fclk, CK_443X),
|
|
|
|
CLK(NULL, "func_96m_fclk", &func_96m_fclk, CK_443X),
|
|
|
|
CLK(NULL, "hsmmc6_fclk", &hsmmc6_fclk, CK_443X),
|
|
|
|
CLK(NULL, "init_60m_fclk", &init_60m_fclk, CK_443X),
|
|
|
|
CLK(NULL, "l3_div_ck", &l3_div_ck, CK_443X),
|
|
|
|
CLK(NULL, "l4_div_ck", &l4_div_ck, CK_443X),
|
|
|
|
CLK(NULL, "lp_clk_div_ck", &lp_clk_div_ck, CK_443X),
|
|
|
|
CLK(NULL, "l4_wkup_clk_mux_ck", &l4_wkup_clk_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "per_abe_nc_fclk", &per_abe_nc_fclk, CK_443X),
|
|
|
|
CLK(NULL, "mcasp2_fclk", &mcasp2_fclk, CK_443X),
|
|
|
|
CLK(NULL, "mcasp3_fclk", &mcasp3_fclk, CK_443X),
|
|
|
|
CLK(NULL, "ocp_abe_iclk", &ocp_abe_iclk, CK_443X),
|
|
|
|
CLK(NULL, "per_abe_24m_fclk", &per_abe_24m_fclk, CK_443X),
|
|
|
|
CLK(NULL, "pmd_stm_clock_mux_ck", &pmd_stm_clock_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "pmd_trace_clk_mux_ck", &pmd_trace_clk_mux_ck, CK_443X),
|
|
|
|
CLK(NULL, "syc_clk_div_ck", &syc_clk_div_ck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "aes1_fck", &aes1_fck, CK_443X),
|
|
|
|
CLK(NULL, "aes2_fck", &aes2_fck, CK_443X),
|
|
|
|
CLK(NULL, "aess_fck", &aess_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "bandgap_fclk", &bandgap_fclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "des3des_fck", &des3des_fck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "dmic_sync_mux_ck", &dmic_sync_mux_ck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "dmic_fck", &dmic_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "dsp_fck", &dsp_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "dss_sys_clk", &dss_sys_clk, CK_443X),
|
|
|
|
CLK(NULL, "dss_tv_clk", &dss_tv_clk, CK_443X),
|
|
|
|
CLK(NULL, "dss_dss_clk", &dss_dss_clk, CK_443X),
|
|
|
|
CLK(NULL, "dss_48mhz_clk", &dss_48mhz_clk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "dss_fck", &dss_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "efuse_ctrl_cust_fck", &efuse_ctrl_cust_fck, CK_443X),
|
|
|
|
CLK(NULL, "emif1_fck", &emif1_fck, CK_443X),
|
|
|
|
CLK(NULL, "emif2_fck", &emif2_fck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "fdif_fck", &fdif_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "fpka_fck", &fpka_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "gpio1_dbck", &gpio1_dbclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "gpio1_ick", &gpio1_ick, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "gpio2_dbck", &gpio2_dbclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "gpio2_ick", &gpio2_ick, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "gpio3_dbck", &gpio3_dbclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "gpio3_ick", &gpio3_ick, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "gpio4_dbck", &gpio4_dbclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "gpio4_ick", &gpio4_ick, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "gpio5_dbck", &gpio5_dbclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "gpio5_ick", &gpio5_ick, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "gpio6_dbck", &gpio6_dbclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "gpio6_ick", &gpio6_ick, CK_443X),
|
|
|
|
CLK(NULL, "gpmc_ick", &gpmc_ick, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "gpu_fck", &gpu_fck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("omap2_hdq.0", "fck", &hdq1w_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "hsi_fck", &hsi_fck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("i2c_omap.1", "fck", &i2c1_fck, CK_443X),
|
|
|
|
CLK("i2c_omap.2", "fck", &i2c2_fck, CK_443X),
|
|
|
|
CLK("i2c_omap.3", "fck", &i2c3_fck, CK_443X),
|
|
|
|
CLK("i2c_omap.4", "fck", &i2c4_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "ipu_fck", &ipu_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "iss_ctrlclk", &iss_ctrlclk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "iss_fck", &iss_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "iva_fck", &iva_fck, CK_443X),
|
|
|
|
CLK(NULL, "kbd_fck", &kbd_fck, CK_443X),
|
|
|
|
CLK(NULL, "l3_instr_ick", &l3_instr_ick, CK_443X),
|
|
|
|
CLK(NULL, "l3_main_3_ick", &l3_main_3_ick, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "mcasp_sync_mux_ck", &mcasp_sync_mux_ck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "mcasp_fck", &mcasp_fck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "mcbsp1_sync_mux_ck", &mcbsp1_sync_mux_ck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("omap-mcbsp.1", "fck", &mcbsp1_fck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "mcbsp2_sync_mux_ck", &mcbsp2_sync_mux_ck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("omap-mcbsp.2", "fck", &mcbsp2_fck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "mcbsp3_sync_mux_ck", &mcbsp3_sync_mux_ck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("omap-mcbsp.3", "fck", &mcbsp3_fck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "mcbsp4_sync_mux_ck", &mcbsp4_sync_mux_ck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("omap-mcbsp.4", "fck", &mcbsp4_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "mcpdm_fck", &mcpdm_fck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("omap2_mcspi.1", "fck", &mcspi1_fck, CK_443X),
|
|
|
|
CLK("omap2_mcspi.2", "fck", &mcspi2_fck, CK_443X),
|
|
|
|
CLK("omap2_mcspi.3", "fck", &mcspi3_fck, CK_443X),
|
|
|
|
CLK("omap2_mcspi.4", "fck", &mcspi4_fck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.0", "fck", &mmc1_fck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.1", "fck", &mmc2_fck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.2", "fck", &mmc3_fck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.3", "fck", &mmc4_fck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.4", "fck", &mmc5_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "ocp2scp_usb_phy_phy_48m", &ocp2scp_usb_phy_phy_48m, CK_443X),
|
2010-09-27 14:02:56 -06:00
|
|
|
CLK(NULL, "ocp2scp_usb_phy_ick", &ocp2scp_usb_phy_ick, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "ocp_wp_noc_ick", &ocp_wp_noc_ick, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK("omap_rng", "ick", &rng_ick, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "sha2md5_fck", &sha2md5_fck, CK_443X),
|
|
|
|
CLK(NULL, "sl2if_ick", &sl2if_ick, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "slimbus1_fclk_1", &slimbus1_fclk_1, CK_443X),
|
|
|
|
CLK(NULL, "slimbus1_fclk_0", &slimbus1_fclk_0, CK_443X),
|
|
|
|
CLK(NULL, "slimbus1_fclk_2", &slimbus1_fclk_2, CK_443X),
|
|
|
|
CLK(NULL, "slimbus1_slimbus_clk", &slimbus1_slimbus_clk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "slimbus1_fck", &slimbus1_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "slimbus2_fclk_1", &slimbus2_fclk_1, CK_443X),
|
|
|
|
CLK(NULL, "slimbus2_fclk_0", &slimbus2_fclk_0, CK_443X),
|
|
|
|
CLK(NULL, "slimbus2_slimbus_clk", &slimbus2_slimbus_clk, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "slimbus2_fck", &slimbus2_fck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "smartreflex_core_fck", &smartreflex_core_fck, CK_443X),
|
|
|
|
CLK(NULL, "smartreflex_iva_fck", &smartreflex_iva_fck, CK_443X),
|
|
|
|
CLK(NULL, "smartreflex_mpu_fck", &smartreflex_mpu_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt1_fck", &timer1_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt10_fck", &timer10_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt11_fck", &timer11_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt2_fck", &timer2_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt3_fck", &timer3_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt4_fck", &timer4_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt5_fck", &timer5_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt6_fck", &timer6_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt7_fck", &timer7_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt8_fck", &timer8_fck, CK_443X),
|
|
|
|
CLK(NULL, "gpt9_fck", &timer9_fck, CK_443X),
|
2010-02-22 22:09:39 -07:00
|
|
|
CLK(NULL, "uart1_fck", &uart1_fck, CK_443X),
|
|
|
|
CLK(NULL, "uart2_fck", &uart2_fck, CK_443X),
|
|
|
|
CLK(NULL, "uart3_fck", &uart3_fck, CK_443X),
|
|
|
|
CLK(NULL, "uart4_fck", &uart4_fck, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_fs_fck", &usb_host_fs_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "usb_host_hs_utmi_p3_clk", &usb_host_hs_utmi_p3_clk, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_hs_hsic60m_p1_clk", &usb_host_hs_hsic60m_p1_clk, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_hs_hsic60m_p2_clk", &usb_host_hs_hsic60m_p2_clk, CK_443X),
|
|
|
|
CLK(NULL, "utmi_p1_gfclk", &utmi_p1_gfclk, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_hs_utmi_p1_clk", &usb_host_hs_utmi_p1_clk, CK_443X),
|
|
|
|
CLK(NULL, "utmi_p2_gfclk", &utmi_p2_gfclk, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_hs_utmi_p2_clk", &usb_host_hs_utmi_p2_clk, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_hs_hsic480m_p1_clk", &usb_host_hs_hsic480m_p1_clk, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_hs_hsic480m_p2_clk", &usb_host_hs_hsic480m_p2_clk, CK_443X),
|
|
|
|
CLK(NULL, "usb_host_hs_func48mclk", &usb_host_hs_func48mclk, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "usb_host_hs_fck", &usb_host_hs_fck, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "otg_60m_gfclk", &otg_60m_gfclk, CK_443X),
|
|
|
|
CLK(NULL, "usb_otg_hs_xclk", &usb_otg_hs_xclk, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK("musb_hdrc", "ick", &usb_otg_hs_ick, CK_443X),
|
2010-09-27 14:02:56 -06:00
|
|
|
CLK(NULL, "usb_phy_cm_clk32k", &usb_phy_cm_clk32k, CK_443X),
|
2010-09-27 14:02:55 -06:00
|
|
|
CLK(NULL, "usb_tll_hs_usb_ch2_clk", &usb_tll_hs_usb_ch2_clk, CK_443X),
|
|
|
|
CLK(NULL, "usb_tll_hs_usb_ch0_clk", &usb_tll_hs_usb_ch0_clk, CK_443X),
|
|
|
|
CLK(NULL, "usb_tll_hs_usb_ch1_clk", &usb_tll_hs_usb_ch1_clk, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "usb_tll_hs_ick", &usb_tll_hs_ick, CK_443X),
|
2010-09-27 14:02:56 -06:00
|
|
|
CLK(NULL, "usim_ck", &usim_ck, CK_443X),
|
|
|
|
CLK(NULL, "usim_fclk", &usim_fclk, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK(NULL, "usim_fck", &usim_fck, CK_443X),
|
|
|
|
CLK("omap_wdt", "fck", &wd_timer2_fck, CK_443X),
|
|
|
|
CLK(NULL, "wd_timer3_fck", &wd_timer3_fck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
CLK(NULL, "stm_clk_div_ck", &stm_clk_div_ck, CK_443X),
|
|
|
|
CLK(NULL, "trace_clk_div_ck", &trace_clk_div_ck, CK_443X),
|
2010-02-22 22:09:40 -07:00
|
|
|
CLK(NULL, "gpmc_ck", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt1_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt2_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt3_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt4_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt5_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt6_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt7_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt8_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt9_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt10_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "gpt11_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("i2c_omap.1", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("i2c_omap.2", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("i2c_omap.3", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("i2c_omap.4", "ick", &dummy_ck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK("mmci-omap-hs.0", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.1", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.2", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.3", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("mmci-omap-hs.4", "ick", &dummy_ck, CK_443X),
|
2010-02-22 22:09:40 -07:00
|
|
|
CLK("omap-mcbsp.1", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("omap-mcbsp.2", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("omap-mcbsp.3", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("omap-mcbsp.4", "ick", &dummy_ck, CK_443X),
|
2010-09-27 14:02:54 -06:00
|
|
|
CLK("omap2_mcspi.1", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("omap2_mcspi.2", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("omap2_mcspi.3", "ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("omap2_mcspi.4", "ick", &dummy_ck, CK_443X),
|
2010-02-22 22:09:40 -07:00
|
|
|
CLK(NULL, "uart1_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "uart2_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "uart3_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK(NULL, "uart4_ick", &dummy_ck, CK_443X),
|
|
|
|
CLK("omap_wdt", "ick", &dummy_ck, CK_443X),
|
2009-12-08 18:46:28 -07:00
|
|
|
};
|
|
|
|
|
2010-01-26 20:13:12 -07:00
|
|
|
int __init omap4xxx_clk_init(void)
|
2009-12-08 18:46:28 -07:00
|
|
|
{
|
|
|
|
struct omap_clk *c;
|
|
|
|
u32 cpu_clkflg;
|
|
|
|
|
|
|
|
if (cpu_is_omap44xx()) {
|
|
|
|
cpu_mask = RATE_IN_4430;
|
|
|
|
cpu_clkflg = CK_443X;
|
|
|
|
}
|
|
|
|
|
|
|
|
clk_init(&omap2_clk_functions);
|
|
|
|
|
|
|
|
for (c = omap44xx_clks; c < omap44xx_clks + ARRAY_SIZE(omap44xx_clks);
|
|
|
|
c++)
|
|
|
|
clk_preinit(c->lk.clk);
|
|
|
|
|
|
|
|
for (c = omap44xx_clks; c < omap44xx_clks + ARRAY_SIZE(omap44xx_clks);
|
|
|
|
c++)
|
|
|
|
if (c->cpu & cpu_clkflg) {
|
|
|
|
clkdev_add(&c->lk);
|
|
|
|
clk_register(c->lk.clk);
|
|
|
|
omap2_init_clk_clkdm(c->lk.clk);
|
|
|
|
}
|
|
|
|
|
|
|
|
recalculate_root_clocks();
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Only enable those clocks we will need, let the drivers
|
|
|
|
* enable other clocks as necessary
|
|
|
|
*/
|
|
|
|
clk_enable_init_clocks();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|