/* * OMAP3 Legacy clock data * * Copyright (C) 2014 Texas Instruments, Inc * Tero Kristo (t-kristo@ti.com) * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation version 2. * * This program is distributed "as is" WITHOUT ANY WARRANTY of any * kind, whether express or implied; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #include <linux/kernel.h> #include <linux/clk.h> #include <linux/clk-provider.h> #include <linux/clk/ti.h> #include "clock.h" static struct ti_clk_fixed virt_12m_ck_data = { .frequency = 12000000, }; static struct ti_clk virt_12m_ck = { .name = "virt_12m_ck", .type = TI_CLK_FIXED, .data = &virt_12m_ck_data, }; static struct ti_clk_fixed virt_13m_ck_data = { .frequency = 13000000, }; static struct ti_clk virt_13m_ck = { .name = "virt_13m_ck", .type = TI_CLK_FIXED, .data = &virt_13m_ck_data, }; static struct ti_clk_fixed virt_19200000_ck_data = { .frequency = 19200000, }; static struct ti_clk virt_19200000_ck = { .name = "virt_19200000_ck", .type = TI_CLK_FIXED, .data = &virt_19200000_ck_data, }; static struct ti_clk_fixed virt_26000000_ck_data = { .frequency = 26000000, }; static struct ti_clk virt_26000000_ck = { .name = "virt_26000000_ck", .type = TI_CLK_FIXED, .data = &virt_26000000_ck_data, }; static struct ti_clk_fixed virt_38_4m_ck_data = { .frequency = 38400000, }; static struct ti_clk virt_38_4m_ck = { .name = "virt_38_4m_ck", .type = TI_CLK_FIXED, .data = &virt_38_4m_ck_data, }; static struct ti_clk_fixed virt_16_8m_ck_data = { .frequency = 16800000, }; static struct ti_clk virt_16_8m_ck = { .name = "virt_16_8m_ck", .type = TI_CLK_FIXED, .data = &virt_16_8m_ck_data, }; static const char *osc_sys_ck_parents[] = { "virt_12m_ck", "virt_13m_ck", "virt_19200000_ck", "virt_26000000_ck", "virt_38_4m_ck", "virt_16_8m_ck", }; static struct ti_clk_mux osc_sys_ck_data = { .num_parents = ARRAY_SIZE(osc_sys_ck_parents), .reg = 0xd40, .module = TI_CLKM_PRM, .parents = osc_sys_ck_parents, }; static struct ti_clk osc_sys_ck = { .name = "osc_sys_ck", .type = TI_CLK_MUX, .data = &osc_sys_ck_data, }; static struct ti_clk_divider sys_ck_data = { .parent = "osc_sys_ck", .bit_shift = 6, .max_div = 3, .reg = 0x1270, .module = TI_CLKM_PRM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk sys_ck = { .name = "sys_ck", .type = TI_CLK_DIVIDER, .data = &sys_ck_data, }; static const char *dpll3_ck_parents[] = { "sys_ck", "sys_ck", }; static struct ti_clk_dpll dpll3_ck_data = { .num_parents = ARRAY_SIZE(dpll3_ck_parents), .control_reg = 0xd00, .idlest_reg = 0xd20, .mult_div1_reg = 0xd40, .autoidle_reg = 0xd30, .module = TI_CLKM_CM, .parents = dpll3_ck_parents, .flags = CLKF_CORE, .freqsel_mask = 0xf0, .div1_mask = 0x7f00, .idlest_mask = 0x1, .auto_recal_bit = 0x3, .max_divider = 0x80, .min_divider = 0x1, .recal_en_bit = 0x5, .max_multiplier = 0x7ff, .enable_mask = 0x7, .mult_mask = 0x7ff0000, .recal_st_bit = 0x5, .autoidle_mask = 0x7, }; static struct ti_clk dpll3_ck = { .name = "dpll3_ck", .clkdm_name = "dpll3_clkdm", .type = TI_CLK_DPLL, .data = &dpll3_ck_data, }; static struct ti_clk_divider dpll3_m2_ck_data = { .parent = "dpll3_ck", .bit_shift = 27, .max_div = 31, .reg = 0xd40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll3_m2_ck = { .name = "dpll3_m2_ck", .type = TI_CLK_DIVIDER, .data = &dpll3_m2_ck_data, }; static struct ti_clk_fixed_factor core_ck_data = { .parent = "dpll3_m2_ck", .div = 1, .mult = 1, }; static struct ti_clk core_ck = { .name = "core_ck", .type = TI_CLK_FIXED_FACTOR, .data = &core_ck_data, }; static struct ti_clk_divider l3_ick_data = { .parent = "core_ck", .max_div = 3, .reg = 0xa40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk l3_ick = { .name = "l3_ick", .type = TI_CLK_DIVIDER, .data = &l3_ick_data, }; static struct ti_clk_fixed_factor security_l3_ick_data = { .parent = "l3_ick", .div = 1, .mult = 1, }; static struct ti_clk security_l3_ick = { .name = "security_l3_ick", .type = TI_CLK_FIXED_FACTOR, .data = &security_l3_ick_data, }; static struct ti_clk_fixed_factor wkup_l4_ick_data = { .parent = "sys_ck", .div = 1, .mult = 1, }; static struct ti_clk wkup_l4_ick = { .name = "wkup_l4_ick", .type = TI_CLK_FIXED_FACTOR, .data = &wkup_l4_ick_data, }; static struct ti_clk_gate usim_ick_data = { .parent = "wkup_l4_ick", .bit_shift = 9, .reg = 0xc10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk usim_ick = { .name = "usim_ick", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &usim_ick_data, }; static struct ti_clk_gate dss2_alwon_fck_data = { .parent = "sys_ck", .bit_shift = 1, .reg = 0xe00, .module = TI_CLKM_CM, }; static struct ti_clk dss2_alwon_fck = { .name = "dss2_alwon_fck", .clkdm_name = "dss_clkdm", .type = TI_CLK_GATE, .data = &dss2_alwon_fck_data, }; static struct ti_clk_divider l4_ick_data = { .parent = "l3_ick", .bit_shift = 2, .max_div = 3, .reg = 0xa40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk l4_ick = { .name = "l4_ick", .type = TI_CLK_DIVIDER, .data = &l4_ick_data, }; static struct ti_clk_fixed_factor core_l4_ick_data = { .parent = "l4_ick", .div = 1, .mult = 1, }; static struct ti_clk core_l4_ick = { .name = "core_l4_ick", .type = TI_CLK_FIXED_FACTOR, .data = &core_l4_ick_data, }; static struct ti_clk_gate mmchs2_ick_data = { .parent = "core_l4_ick", .bit_shift = 25, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mmchs2_ick = { .name = "mmchs2_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mmchs2_ick_data, }; static const char *dpll4_ck_parents[] = { "sys_ck", "sys_ck", }; static struct ti_clk_dpll dpll4_ck_data = { .num_parents = ARRAY_SIZE(dpll4_ck_parents), .control_reg = 0xd00, .idlest_reg = 0xd20, .mult_div1_reg = 0xd44, .autoidle_reg = 0xd30, .module = TI_CLKM_CM, .parents = dpll4_ck_parents, .flags = CLKF_PER, .freqsel_mask = 0xf00000, .modes = 0x82, .div1_mask = 0x7f, .idlest_mask = 0x2, .auto_recal_bit = 0x13, .max_divider = 0x80, .min_divider = 0x1, .recal_en_bit = 0x6, .max_multiplier = 0x7ff, .enable_mask = 0x70000, .mult_mask = 0x7ff00, .recal_st_bit = 0x6, .autoidle_mask = 0x38, }; static struct ti_clk dpll4_ck = { .name = "dpll4_ck", .clkdm_name = "dpll4_clkdm", .type = TI_CLK_DPLL, .data = &dpll4_ck_data, }; static struct ti_clk_divider dpll4_m2_ck_data = { .parent = "dpll4_ck", .max_div = 63, .reg = 0xd48, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll4_m2_ck = { .name = "dpll4_m2_ck", .type = TI_CLK_DIVIDER, .data = &dpll4_m2_ck_data, }; static struct ti_clk_fixed_factor dpll4_m2x2_mul_ck_data = { .parent = "dpll4_m2_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll4_m2x2_mul_ck = { .name = "dpll4_m2x2_mul_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll4_m2x2_mul_ck_data, }; static struct ti_clk_gate dpll4_m2x2_ck_data = { .parent = "dpll4_m2x2_mul_ck", .bit_shift = 0x1b, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m2x2_ck = { .name = "dpll4_m2x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m2x2_ck_data, }; static struct ti_clk_fixed_factor omap_96m_alwon_fck_data = { .parent = "dpll4_m2x2_ck", .div = 1, .mult = 1, }; static struct ti_clk omap_96m_alwon_fck = { .name = "omap_96m_alwon_fck", .type = TI_CLK_FIXED_FACTOR, .data = &omap_96m_alwon_fck_data, }; static struct ti_clk_fixed_factor cm_96m_fck_data = { .parent = "omap_96m_alwon_fck", .div = 1, .mult = 1, }; static struct ti_clk cm_96m_fck = { .name = "cm_96m_fck", .type = TI_CLK_FIXED_FACTOR, .data = &cm_96m_fck_data, }; static const char *omap_96m_fck_parents[] = { "cm_96m_fck", "sys_ck", }; static struct ti_clk_mux omap_96m_fck_data = { .bit_shift = 6, .num_parents = ARRAY_SIZE(omap_96m_fck_parents), .reg = 0xd40, .module = TI_CLKM_CM, .parents = omap_96m_fck_parents, }; static struct ti_clk omap_96m_fck = { .name = "omap_96m_fck", .type = TI_CLK_MUX, .data = &omap_96m_fck_data, }; static struct ti_clk_fixed_factor core_96m_fck_data = { .parent = "omap_96m_fck", .div = 1, .mult = 1, }; static struct ti_clk core_96m_fck = { .name = "core_96m_fck", .type = TI_CLK_FIXED_FACTOR, .data = &core_96m_fck_data, }; static struct ti_clk_gate mspro_fck_data = { .parent = "core_96m_fck", .bit_shift = 23, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mspro_fck = { .name = "mspro_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mspro_fck_data, }; static struct ti_clk_gate dss_ick_3430es2_data = { .parent = "l4_ick", .bit_shift = 0, .reg = 0xe10, .module = TI_CLKM_CM, .flags = CLKF_DSS | CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk dss_ick_3430es2 = { .name = "dss_ick", .clkdm_name = "dss_clkdm", .type = TI_CLK_GATE, .data = &dss_ick_3430es2_data, }; static struct ti_clk_gate uart4_ick_am35xx_data = { .parent = "core_l4_ick", .bit_shift = 23, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk uart4_ick_am35xx = { .name = "uart4_ick_am35xx", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &uart4_ick_am35xx_data, }; static struct ti_clk_fixed_factor security_l4_ick2_data = { .parent = "l4_ick", .div = 1, .mult = 1, }; static struct ti_clk security_l4_ick2 = { .name = "security_l4_ick2", .type = TI_CLK_FIXED_FACTOR, .data = &security_l4_ick2_data, }; static struct ti_clk_gate aes1_ick_data = { .parent = "security_l4_ick2", .bit_shift = 3, .reg = 0xa14, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk aes1_ick = { .name = "aes1_ick", .type = TI_CLK_GATE, .data = &aes1_ick_data, }; static const char *dpll5_ck_parents[] = { "sys_ck", "sys_ck", }; static struct ti_clk_dpll dpll5_ck_data = { .num_parents = ARRAY_SIZE(dpll5_ck_parents), .control_reg = 0xd04, .idlest_reg = 0xd24, .mult_div1_reg = 0xd4c, .autoidle_reg = 0xd34, .module = TI_CLKM_CM, .parents = dpll5_ck_parents, .freqsel_mask = 0xf0, .modes = 0x82, .div1_mask = 0x7f, .idlest_mask = 0x1, .auto_recal_bit = 0x3, .max_divider = 0x80, .min_divider = 0x1, .recal_en_bit = 0x19, .max_multiplier = 0x7ff, .enable_mask = 0x7, .mult_mask = 0x7ff00, .recal_st_bit = 0x19, .autoidle_mask = 0x7, }; static struct ti_clk dpll5_ck = { .name = "dpll5_ck", .clkdm_name = "dpll5_clkdm", .type = TI_CLK_DPLL, .data = &dpll5_ck_data, }; static struct ti_clk_divider dpll5_m2_ck_data = { .parent = "dpll5_ck", .max_div = 31, .reg = 0xd50, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll5_m2_ck = { .name = "dpll5_m2_ck", .type = TI_CLK_DIVIDER, .data = &dpll5_m2_ck_data, }; static struct ti_clk_gate usbhost_120m_fck_data = { .parent = "dpll5_m2_ck", .bit_shift = 1, .reg = 0x1400, .module = TI_CLKM_CM, }; static struct ti_clk usbhost_120m_fck = { .name = "usbhost_120m_fck", .clkdm_name = "usbhost_clkdm", .type = TI_CLK_GATE, .data = &usbhost_120m_fck_data, }; static struct ti_clk_fixed_factor cm_96m_d2_fck_data = { .parent = "cm_96m_fck", .div = 2, .mult = 1, }; static struct ti_clk cm_96m_d2_fck = { .name = "cm_96m_d2_fck", .type = TI_CLK_FIXED_FACTOR, .data = &cm_96m_d2_fck_data, }; static struct ti_clk_fixed sys_altclk_data = { .frequency = 0x0, }; static struct ti_clk sys_altclk = { .name = "sys_altclk", .type = TI_CLK_FIXED, .data = &sys_altclk_data, }; static const char *omap_48m_fck_parents[] = { "cm_96m_d2_fck", "sys_altclk", }; static struct ti_clk_mux omap_48m_fck_data = { .bit_shift = 3, .num_parents = ARRAY_SIZE(omap_48m_fck_parents), .reg = 0xd40, .module = TI_CLKM_CM, .parents = omap_48m_fck_parents, }; static struct ti_clk omap_48m_fck = { .name = "omap_48m_fck", .type = TI_CLK_MUX, .data = &omap_48m_fck_data, }; static struct ti_clk_fixed_factor core_48m_fck_data = { .parent = "omap_48m_fck", .div = 1, .mult = 1, }; static struct ti_clk core_48m_fck = { .name = "core_48m_fck", .type = TI_CLK_FIXED_FACTOR, .data = &core_48m_fck_data, }; static struct ti_clk_fixed mcbsp_clks_data = { .frequency = 0x0, }; static struct ti_clk mcbsp_clks = { .name = "mcbsp_clks", .type = TI_CLK_FIXED, .data = &mcbsp_clks_data, }; static struct ti_clk_gate mcbsp2_gate_fck_data = { .parent = "mcbsp_clks", .bit_shift = 0, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk_fixed_factor per_96m_fck_data = { .parent = "omap_96m_alwon_fck", .div = 1, .mult = 1, }; static struct ti_clk per_96m_fck = { .name = "per_96m_fck", .type = TI_CLK_FIXED_FACTOR, .data = &per_96m_fck_data, }; static const char *mcbsp2_mux_fck_parents[] = { "per_96m_fck", "mcbsp_clks", }; static struct ti_clk_mux mcbsp2_mux_fck_data = { .bit_shift = 6, .num_parents = ARRAY_SIZE(mcbsp2_mux_fck_parents), .reg = 0x274, .module = TI_CLKM_SCRM, .parents = mcbsp2_mux_fck_parents, }; static struct ti_clk_composite mcbsp2_fck_data = { .mux = &mcbsp2_mux_fck_data, .gate = &mcbsp2_gate_fck_data, }; static struct ti_clk mcbsp2_fck = { .name = "mcbsp2_fck", .type = TI_CLK_COMPOSITE, .data = &mcbsp2_fck_data, }; static struct ti_clk_fixed_factor dpll3_m2x2_ck_data = { .parent = "dpll3_m2_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll3_m2x2_ck = { .name = "dpll3_m2x2_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll3_m2x2_ck_data, }; static struct ti_clk_fixed_factor corex2_fck_data = { .parent = "dpll3_m2x2_ck", .div = 1, .mult = 1, }; static struct ti_clk corex2_fck = { .name = "corex2_fck", .type = TI_CLK_FIXED_FACTOR, .data = &corex2_fck_data, }; static struct ti_clk_gate ssi_ssr_gate_fck_3430es1_data = { .parent = "corex2_fck", .bit_shift = 0, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_NO_WAIT, }; static int ssi_ssr_div_fck_3430es1_divs[] = { 0, 1, 2, 3, 4, 0, 6, 0, 8, }; static struct ti_clk_divider ssi_ssr_div_fck_3430es1_data = { .num_dividers = ARRAY_SIZE(ssi_ssr_div_fck_3430es1_divs), .parent = "corex2_fck", .bit_shift = 8, .dividers = ssi_ssr_div_fck_3430es1_divs, .reg = 0xa40, .module = TI_CLKM_CM, }; static struct ti_clk_composite ssi_ssr_fck_3430es1_data = { .gate = &ssi_ssr_gate_fck_3430es1_data, .divider = &ssi_ssr_div_fck_3430es1_data, }; static struct ti_clk ssi_ssr_fck_3430es1 = { .name = "ssi_ssr_fck", .type = TI_CLK_COMPOSITE, .data = &ssi_ssr_fck_3430es1_data, }; static struct ti_clk_fixed_factor ssi_sst_fck_3430es1_data = { .parent = "ssi_ssr_fck", .div = 2, .mult = 1, }; static struct ti_clk ssi_sst_fck_3430es1 = { .name = "ssi_sst_fck", .type = TI_CLK_FIXED_FACTOR, .data = &ssi_sst_fck_3430es1_data, }; static struct ti_clk_fixed omap_32k_fck_data = { .frequency = 32768, }; static struct ti_clk omap_32k_fck = { .name = "omap_32k_fck", .type = TI_CLK_FIXED, .data = &omap_32k_fck_data, }; static struct ti_clk_fixed_factor per_32k_alwon_fck_data = { .parent = "omap_32k_fck", .div = 1, .mult = 1, }; static struct ti_clk per_32k_alwon_fck = { .name = "per_32k_alwon_fck", .type = TI_CLK_FIXED_FACTOR, .data = &per_32k_alwon_fck_data, }; static struct ti_clk_gate gpio5_dbck_data = { .parent = "per_32k_alwon_fck", .bit_shift = 16, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk gpio5_dbck = { .name = "gpio5_dbck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio5_dbck_data, }; static struct ti_clk_gate gpt1_ick_data = { .parent = "wkup_l4_ick", .bit_shift = 0, .reg = 0xc10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt1_ick = { .name = "gpt1_ick", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &gpt1_ick_data, }; static struct ti_clk_gate mcspi3_fck_data = { .parent = "core_48m_fck", .bit_shift = 20, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mcspi3_fck = { .name = "mcspi3_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi3_fck_data, }; static struct ti_clk_gate gpt2_gate_fck_data = { .parent = "sys_ck", .bit_shift = 3, .reg = 0x1000, .module = TI_CLKM_CM, }; static const char *gpt2_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt2_mux_fck_data = { .num_parents = ARRAY_SIZE(gpt2_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt2_mux_fck_parents, }; static struct ti_clk_composite gpt2_fck_data = { .mux = &gpt2_mux_fck_data, .gate = &gpt2_gate_fck_data, }; static struct ti_clk gpt2_fck = { .name = "gpt2_fck", .type = TI_CLK_COMPOSITE, .data = &gpt2_fck_data, }; static struct ti_clk_gate gpt10_ick_data = { .parent = "core_l4_ick", .bit_shift = 11, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt10_ick = { .name = "gpt10_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &gpt10_ick_data, }; static struct ti_clk_gate uart2_fck_data = { .parent = "core_48m_fck", .bit_shift = 14, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk uart2_fck = { .name = "uart2_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &uart2_fck_data, }; static struct ti_clk_fixed_factor sr_l4_ick_data = { .parent = "l4_ick", .div = 1, .mult = 1, }; static struct ti_clk sr_l4_ick = { .name = "sr_l4_ick", .type = TI_CLK_FIXED_FACTOR, .data = &sr_l4_ick_data, }; static struct ti_clk_fixed_factor omap_96m_d8_fck_data = { .parent = "omap_96m_fck", .div = 8, .mult = 1, }; static struct ti_clk omap_96m_d8_fck = { .name = "omap_96m_d8_fck", .type = TI_CLK_FIXED_FACTOR, .data = &omap_96m_d8_fck_data, }; static struct ti_clk_divider dpll4_m5_ck_data = { .parent = "dpll4_ck", .max_div = 63, .reg = 0xf40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll4_m5_ck = { .name = "dpll4_m5_ck", .type = TI_CLK_DIVIDER, .data = &dpll4_m5_ck_data, }; static struct ti_clk_fixed_factor dpll4_m5x2_mul_ck_data = { .parent = "dpll4_m5_ck", .div = 1, .mult = 2, .flags = CLKF_SET_RATE_PARENT, }; static struct ti_clk dpll4_m5x2_mul_ck = { .name = "dpll4_m5x2_mul_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll4_m5x2_mul_ck_data, }; static struct ti_clk_gate dpll4_m5x2_ck_data = { .parent = "dpll4_m5x2_mul_ck", .bit_shift = 0x1e, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m5x2_ck = { .name = "dpll4_m5x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m5x2_ck_data, }; static struct ti_clk_gate cam_mclk_data = { .parent = "dpll4_m5x2_ck", .bit_shift = 0, .reg = 0xf00, .module = TI_CLKM_CM, .flags = CLKF_SET_RATE_PARENT, }; static struct ti_clk cam_mclk = { .name = "cam_mclk", .type = TI_CLK_GATE, .data = &cam_mclk_data, }; static struct ti_clk_gate mcbsp3_gate_fck_data = { .parent = "mcbsp_clks", .bit_shift = 1, .reg = 0x1000, .module = TI_CLKM_CM, }; static const char *mcbsp3_mux_fck_parents[] = { "per_96m_fck", "mcbsp_clks", }; static struct ti_clk_mux mcbsp3_mux_fck_data = { .num_parents = ARRAY_SIZE(mcbsp3_mux_fck_parents), .reg = 0x2d8, .module = TI_CLKM_SCRM, .parents = mcbsp3_mux_fck_parents, }; static struct ti_clk_composite mcbsp3_fck_data = { .mux = &mcbsp3_mux_fck_data, .gate = &mcbsp3_gate_fck_data, }; static struct ti_clk mcbsp3_fck = { .name = "mcbsp3_fck", .type = TI_CLK_COMPOSITE, .data = &mcbsp3_fck_data, }; static struct ti_clk_gate csi2_96m_fck_data = { .parent = "core_96m_fck", .bit_shift = 1, .reg = 0xf00, .module = TI_CLKM_CM, }; static struct ti_clk csi2_96m_fck = { .name = "csi2_96m_fck", .clkdm_name = "cam_clkdm", .type = TI_CLK_GATE, .data = &csi2_96m_fck_data, }; static struct ti_clk_gate gpt9_gate_fck_data = { .parent = "sys_ck", .bit_shift = 10, .reg = 0x1000, .module = TI_CLKM_CM, }; static const char *gpt9_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt9_mux_fck_data = { .bit_shift = 7, .num_parents = ARRAY_SIZE(gpt9_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt9_mux_fck_parents, }; static struct ti_clk_composite gpt9_fck_data = { .mux = &gpt9_mux_fck_data, .gate = &gpt9_gate_fck_data, }; static struct ti_clk gpt9_fck = { .name = "gpt9_fck", .type = TI_CLK_COMPOSITE, .data = &gpt9_fck_data, }; static struct ti_clk_divider dpll3_m3_ck_data = { .parent = "dpll3_ck", .bit_shift = 16, .max_div = 31, .reg = 0x1140, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll3_m3_ck = { .name = "dpll3_m3_ck", .type = TI_CLK_DIVIDER, .data = &dpll3_m3_ck_data, }; static struct ti_clk_fixed_factor dpll3_m3x2_mul_ck_data = { .parent = "dpll3_m3_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll3_m3x2_mul_ck = { .name = "dpll3_m3x2_mul_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll3_m3x2_mul_ck_data, }; static struct ti_clk_gate sr2_fck_data = { .parent = "sys_ck", .bit_shift = 7, .reg = 0xc00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk sr2_fck = { .name = "sr2_fck", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &sr2_fck_data, }; static struct ti_clk_fixed pclk_ck_data = { .frequency = 27000000, }; static struct ti_clk pclk_ck = { .name = "pclk_ck", .type = TI_CLK_FIXED, .data = &pclk_ck_data, }; static struct ti_clk_gate wdt2_ick_data = { .parent = "wkup_l4_ick", .bit_shift = 5, .reg = 0xc10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk wdt2_ick = { .name = "wdt2_ick", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &wdt2_ick_data, }; static struct ti_clk_fixed_factor core_l3_ick_data = { .parent = "l3_ick", .div = 1, .mult = 1, }; static struct ti_clk core_l3_ick = { .name = "core_l3_ick", .type = TI_CLK_FIXED_FACTOR, .data = &core_l3_ick_data, }; static struct ti_clk_gate mcspi4_fck_data = { .parent = "core_48m_fck", .bit_shift = 21, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mcspi4_fck = { .name = "mcspi4_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi4_fck_data, }; static struct ti_clk_fixed_factor per_48m_fck_data = { .parent = "omap_48m_fck", .div = 1, .mult = 1, }; static struct ti_clk per_48m_fck = { .name = "per_48m_fck", .type = TI_CLK_FIXED_FACTOR, .data = &per_48m_fck_data, }; static struct ti_clk_gate uart4_fck_data = { .parent = "per_48m_fck", .bit_shift = 18, .reg = 0x1000, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk uart4_fck = { .name = "uart4_fck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &uart4_fck_data, }; static struct ti_clk_fixed_factor omap_96m_d10_fck_data = { .parent = "omap_96m_fck", .div = 10, .mult = 1, }; static struct ti_clk omap_96m_d10_fck = { .name = "omap_96m_d10_fck", .type = TI_CLK_FIXED_FACTOR, .data = &omap_96m_d10_fck_data, }; static struct ti_clk_gate usim_gate_fck_data = { .parent = "omap_96m_fck", .bit_shift = 9, .reg = 0xc00, .module = TI_CLKM_CM, }; static struct ti_clk_fixed_factor per_l4_ick_data = { .parent = "l4_ick", .div = 1, .mult = 1, }; static struct ti_clk per_l4_ick = { .name = "per_l4_ick", .type = TI_CLK_FIXED_FACTOR, .data = &per_l4_ick_data, }; static struct ti_clk_gate gpt5_ick_data = { .parent = "per_l4_ick", .bit_shift = 6, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt5_ick = { .name = "gpt5_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt5_ick_data, }; static struct ti_clk_gate mcspi2_ick_data = { .parent = "core_l4_ick", .bit_shift = 19, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcspi2_ick = { .name = "mcspi2_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi2_ick_data, }; static struct ti_clk_fixed_factor ssi_l4_ick_data = { .parent = "l4_ick", .div = 1, .mult = 1, }; static struct ti_clk ssi_l4_ick = { .name = "ssi_l4_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_FIXED_FACTOR, .data = &ssi_l4_ick_data, }; static struct ti_clk_gate ssi_ick_3430es1_data = { .parent = "ssi_l4_ick", .bit_shift = 0, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_NO_WAIT | CLKF_INTERFACE, }; static struct ti_clk ssi_ick_3430es1 = { .name = "ssi_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &ssi_ick_3430es1_data, }; static struct ti_clk_gate i2c2_fck_data = { .parent = "core_96m_fck", .bit_shift = 16, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk i2c2_fck = { .name = "i2c2_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &i2c2_fck_data, }; static struct ti_clk_divider dpll1_fck_data = { .parent = "core_ck", .bit_shift = 19, .max_div = 7, .reg = 0x940, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll1_fck = { .name = "dpll1_fck", .type = TI_CLK_DIVIDER, .data = &dpll1_fck_data, }; static const char *dpll1_ck_parents[] = { "sys_ck", "dpll1_fck", }; static struct ti_clk_dpll dpll1_ck_data = { .num_parents = ARRAY_SIZE(dpll1_ck_parents), .control_reg = 0x904, .idlest_reg = 0x924, .mult_div1_reg = 0x940, .autoidle_reg = 0x934, .module = TI_CLKM_CM, .parents = dpll1_ck_parents, .freqsel_mask = 0xf0, .modes = 0xa0, .div1_mask = 0x7f, .idlest_mask = 0x1, .auto_recal_bit = 0x3, .max_divider = 0x80, .min_divider = 0x1, .recal_en_bit = 0x7, .max_multiplier = 0x7ff, .enable_mask = 0x7, .mult_mask = 0x7ff00, .recal_st_bit = 0x7, .autoidle_mask = 0x7, }; static struct ti_clk dpll1_ck = { .name = "dpll1_ck", .clkdm_name = "dpll1_clkdm", .type = TI_CLK_DPLL, .data = &dpll1_ck_data, }; static struct ti_clk_fixed secure_32k_fck_data = { .frequency = 32768, }; static struct ti_clk secure_32k_fck = { .name = "secure_32k_fck", .type = TI_CLK_FIXED, .data = &secure_32k_fck_data, }; static struct ti_clk_gate gpio5_ick_data = { .parent = "per_l4_ick", .bit_shift = 16, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpio5_ick = { .name = "gpio5_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio5_ick_data, }; static struct ti_clk_divider dpll4_m4_ck_data = { .parent = "dpll4_ck", .max_div = 32, .reg = 0xe40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll4_m4_ck = { .name = "dpll4_m4_ck", .type = TI_CLK_DIVIDER, .data = &dpll4_m4_ck_data, }; static struct ti_clk_fixed_factor dpll4_m4x2_mul_ck_data = { .parent = "dpll4_m4_ck", .div = 1, .mult = 2, .flags = CLKF_SET_RATE_PARENT, }; static struct ti_clk dpll4_m4x2_mul_ck = { .name = "dpll4_m4x2_mul_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll4_m4x2_mul_ck_data, }; static struct ti_clk_gate dpll4_m4x2_ck_data = { .parent = "dpll4_m4x2_mul_ck", .bit_shift = 0x1d, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_SET_RATE_PARENT | CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m4x2_ck = { .name = "dpll4_m4x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m4x2_ck_data, }; static struct ti_clk_gate dss1_alwon_fck_3430es2_data = { .parent = "dpll4_m4x2_ck", .bit_shift = 0, .reg = 0xe00, .module = TI_CLKM_CM, .flags = CLKF_DSS | CLKF_SET_RATE_PARENT, }; static struct ti_clk dss1_alwon_fck_3430es2 = { .name = "dss1_alwon_fck", .clkdm_name = "dss_clkdm", .type = TI_CLK_GATE, .data = &dss1_alwon_fck_3430es2_data, }; static struct ti_clk_gate uart3_ick_data = { .parent = "per_l4_ick", .bit_shift = 11, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk uart3_ick = { .name = "uart3_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &uart3_ick_data, }; static struct ti_clk_divider dpll4_m3_ck_data = { .parent = "dpll4_ck", .bit_shift = 8, .max_div = 32, .reg = 0xe40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll4_m3_ck = { .name = "dpll4_m3_ck", .type = TI_CLK_DIVIDER, .data = &dpll4_m3_ck_data, }; static struct ti_clk_gate mcbsp3_ick_data = { .parent = "per_l4_ick", .bit_shift = 1, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcbsp3_ick = { .name = "mcbsp3_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &mcbsp3_ick_data, }; static struct ti_clk_gate gpio3_dbck_data = { .parent = "per_32k_alwon_fck", .bit_shift = 14, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk gpio3_dbck = { .name = "gpio3_dbck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio3_dbck_data, }; static struct ti_clk_gate fac_ick_data = { .parent = "core_l4_ick", .bit_shift = 8, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk fac_ick = { .name = "fac_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &fac_ick_data, }; static struct ti_clk_gate clkout2_src_gate_ck_data = { .parent = "core_ck", .bit_shift = 7, .reg = 0xd70, .module = TI_CLKM_CM, .flags = CLKF_NO_WAIT, }; static struct ti_clk_fixed_factor dpll4_m3x2_mul_ck_data = { .parent = "dpll4_m3_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll4_m3x2_mul_ck = { .name = "dpll4_m3x2_mul_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll4_m3x2_mul_ck_data, }; static struct ti_clk_gate dpll4_m3x2_ck_data = { .parent = "dpll4_m3x2_mul_ck", .bit_shift = 0x1c, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m3x2_ck = { .name = "dpll4_m3x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m3x2_ck_data, }; static const char *omap_54m_fck_parents[] = { "dpll4_m3x2_ck", "sys_altclk", }; static struct ti_clk_mux omap_54m_fck_data = { .bit_shift = 5, .num_parents = ARRAY_SIZE(omap_54m_fck_parents), .reg = 0xd40, .module = TI_CLKM_CM, .parents = omap_54m_fck_parents, }; static struct ti_clk omap_54m_fck = { .name = "omap_54m_fck", .type = TI_CLK_MUX, .data = &omap_54m_fck_data, }; static const char *clkout2_src_mux_ck_parents[] = { "core_ck", "sys_ck", "cm_96m_fck", "omap_54m_fck", }; static struct ti_clk_mux clkout2_src_mux_ck_data = { .num_parents = ARRAY_SIZE(clkout2_src_mux_ck_parents), .reg = 0xd70, .module = TI_CLKM_CM, .parents = clkout2_src_mux_ck_parents, }; static struct ti_clk_composite clkout2_src_ck_data = { .mux = &clkout2_src_mux_ck_data, .gate = &clkout2_src_gate_ck_data, }; static struct ti_clk clkout2_src_ck = { .name = "clkout2_src_ck", .type = TI_CLK_COMPOSITE, .data = &clkout2_src_ck_data, }; static struct ti_clk_gate i2c1_fck_data = { .parent = "core_96m_fck", .bit_shift = 15, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk i2c1_fck = { .name = "i2c1_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &i2c1_fck_data, }; static struct ti_clk_gate wdt3_fck_data = { .parent = "per_32k_alwon_fck", .bit_shift = 12, .reg = 0x1000, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk wdt3_fck = { .name = "wdt3_fck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &wdt3_fck_data, }; static struct ti_clk_gate gpt7_gate_fck_data = { .parent = "sys_ck", .bit_shift = 8, .reg = 0x1000, .module = TI_CLKM_CM, }; static const char *gpt7_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt7_mux_fck_data = { .bit_shift = 5, .num_parents = ARRAY_SIZE(gpt7_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt7_mux_fck_parents, }; static struct ti_clk_composite gpt7_fck_data = { .mux = &gpt7_mux_fck_data, .gate = &gpt7_gate_fck_data, }; static struct ti_clk gpt7_fck = { .name = "gpt7_fck", .type = TI_CLK_COMPOSITE, .data = &gpt7_fck_data, }; static struct ti_clk_gate usb_l4_gate_ick_data = { .parent = "l4_ick", .bit_shift = 5, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_INTERFACE, }; static struct ti_clk_divider usb_l4_div_ick_data = { .parent = "l4_ick", .bit_shift = 4, .max_div = 1, .reg = 0xa40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk_composite usb_l4_ick_data = { .gate = &usb_l4_gate_ick_data, .divider = &usb_l4_div_ick_data, }; static struct ti_clk usb_l4_ick = { .name = "usb_l4_ick", .type = TI_CLK_COMPOSITE, .data = &usb_l4_ick_data, }; static struct ti_clk_gate uart4_ick_data = { .parent = "per_l4_ick", .bit_shift = 18, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk uart4_ick = { .name = "uart4_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &uart4_ick_data, }; static struct ti_clk_fixed dummy_ck_data = { .frequency = 0, }; static struct ti_clk dummy_ck = { .name = "dummy_ck", .type = TI_CLK_FIXED, .data = &dummy_ck_data, }; static const char *gpt3_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt3_mux_fck_data = { .bit_shift = 1, .num_parents = ARRAY_SIZE(gpt3_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt3_mux_fck_parents, }; static struct ti_clk_gate gpt9_ick_data = { .parent = "per_l4_ick", .bit_shift = 10, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt9_ick = { .name = "gpt9_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt9_ick_data, }; static struct ti_clk_gate gpt10_gate_fck_data = { .parent = "sys_ck", .bit_shift = 11, .reg = 0xa00, .module = TI_CLKM_CM, }; static struct ti_clk_gate dss_ick_3430es1_data = { .parent = "l4_ick", .bit_shift = 0, .reg = 0xe10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_NO_WAIT | CLKF_INTERFACE, }; static struct ti_clk dss_ick_3430es1 = { .name = "dss_ick", .clkdm_name = "dss_clkdm", .type = TI_CLK_GATE, .data = &dss_ick_3430es1_data, }; static struct ti_clk_gate gpt11_ick_data = { .parent = "core_l4_ick", .bit_shift = 12, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt11_ick = { .name = "gpt11_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &gpt11_ick_data, }; static struct ti_clk_divider dpll2_fck_data = { .parent = "core_ck", .bit_shift = 19, .max_div = 7, .reg = 0x40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll2_fck = { .name = "dpll2_fck", .type = TI_CLK_DIVIDER, .data = &dpll2_fck_data, }; static struct ti_clk_gate uart1_fck_data = { .parent = "core_48m_fck", .bit_shift = 13, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk uart1_fck = { .name = "uart1_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &uart1_fck_data, }; static struct ti_clk_gate hsotgusb_ick_3430es1_data = { .parent = "core_l3_ick", .bit_shift = 4, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_NO_WAIT | CLKF_INTERFACE, }; static struct ti_clk hsotgusb_ick_3430es1 = { .name = "hsotgusb_ick_3430es1", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &hsotgusb_ick_3430es1_data, }; static struct ti_clk_gate gpio2_ick_data = { .parent = "per_l4_ick", .bit_shift = 13, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpio2_ick = { .name = "gpio2_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio2_ick_data, }; static struct ti_clk_gate mmchs1_ick_data = { .parent = "core_l4_ick", .bit_shift = 24, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mmchs1_ick = { .name = "mmchs1_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mmchs1_ick_data, }; static struct ti_clk_gate modem_fck_data = { .parent = "sys_ck", .bit_shift = 31, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk modem_fck = { .name = "modem_fck", .clkdm_name = "d2d_clkdm", .type = TI_CLK_GATE, .data = &modem_fck_data, }; static struct ti_clk_gate mcbsp4_ick_data = { .parent = "per_l4_ick", .bit_shift = 2, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcbsp4_ick = { .name = "mcbsp4_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &mcbsp4_ick_data, }; static struct ti_clk_gate gpio1_ick_data = { .parent = "wkup_l4_ick", .bit_shift = 3, .reg = 0xc10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpio1_ick = { .name = "gpio1_ick", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &gpio1_ick_data, }; static const char *gpt6_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt6_mux_fck_data = { .bit_shift = 4, .num_parents = ARRAY_SIZE(gpt6_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt6_mux_fck_parents, }; static struct ti_clk_fixed_factor dpll1_x2_ck_data = { .parent = "dpll1_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll1_x2_ck = { .name = "dpll1_x2_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll1_x2_ck_data, }; static struct ti_clk_divider dpll1_x2m2_ck_data = { .parent = "dpll1_x2_ck", .max_div = 31, .reg = 0x944, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll1_x2m2_ck = { .name = "dpll1_x2m2_ck", .type = TI_CLK_DIVIDER, .data = &dpll1_x2m2_ck_data, }; static struct ti_clk_fixed_factor mpu_ck_data = { .parent = "dpll1_x2m2_ck", .div = 1, .mult = 1, }; static struct ti_clk mpu_ck = { .name = "mpu_ck", .type = TI_CLK_FIXED_FACTOR, .data = &mpu_ck_data, }; static struct ti_clk_divider arm_fck_data = { .parent = "mpu_ck", .max_div = 2, .reg = 0x924, .module = TI_CLKM_CM, }; static struct ti_clk arm_fck = { .name = "arm_fck", .type = TI_CLK_DIVIDER, .data = &arm_fck_data, }; static struct ti_clk_fixed_factor core_d3_ck_data = { .parent = "core_ck", .div = 3, .mult = 1, }; static struct ti_clk core_d3_ck = { .name = "core_d3_ck", .type = TI_CLK_FIXED_FACTOR, .data = &core_d3_ck_data, }; static struct ti_clk_gate gpt11_gate_fck_data = { .parent = "sys_ck", .bit_shift = 12, .reg = 0xa00, .module = TI_CLKM_CM, }; static const char *gpt11_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt11_mux_fck_data = { .bit_shift = 7, .num_parents = ARRAY_SIZE(gpt11_mux_fck_parents), .reg = 0xa40, .module = TI_CLKM_CM, .parents = gpt11_mux_fck_parents, }; static struct ti_clk_composite gpt11_fck_data = { .mux = &gpt11_mux_fck_data, .gate = &gpt11_gate_fck_data, }; static struct ti_clk gpt11_fck = { .name = "gpt11_fck", .type = TI_CLK_COMPOSITE, .data = &gpt11_fck_data, }; static struct ti_clk_fixed_factor core_d6_ck_data = { .parent = "core_ck", .div = 6, .mult = 1, }; static struct ti_clk core_d6_ck = { .name = "core_d6_ck", .type = TI_CLK_FIXED_FACTOR, .data = &core_d6_ck_data, }; static struct ti_clk_gate uart4_fck_am35xx_data = { .parent = "core_48m_fck", .bit_shift = 23, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk uart4_fck_am35xx = { .name = "uart4_fck_am35xx", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &uart4_fck_am35xx_data, }; static struct ti_clk_gate dpll3_m3x2_ck_data = { .parent = "dpll3_m3x2_mul_ck", .bit_shift = 0xc, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll3_m3x2_ck = { .name = "dpll3_m3x2_ck", .type = TI_CLK_GATE, .data = &dpll3_m3x2_ck_data, }; static struct ti_clk_fixed_factor emu_core_alwon_ck_data = { .parent = "dpll3_m3x2_ck", .div = 1, .mult = 1, }; static struct ti_clk emu_core_alwon_ck = { .name = "emu_core_alwon_ck", .type = TI_CLK_FIXED_FACTOR, .data = &emu_core_alwon_ck_data, }; static struct ti_clk_divider dpll4_m6_ck_data = { .parent = "dpll4_ck", .bit_shift = 24, .max_div = 63, .reg = 0x1140, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll4_m6_ck = { .name = "dpll4_m6_ck", .type = TI_CLK_DIVIDER, .data = &dpll4_m6_ck_data, }; static struct ti_clk_fixed_factor dpll4_m6x2_mul_ck_data = { .parent = "dpll4_m6_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll4_m6x2_mul_ck = { .name = "dpll4_m6x2_mul_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll4_m6x2_mul_ck_data, }; static struct ti_clk_gate dpll4_m6x2_ck_data = { .parent = "dpll4_m6x2_mul_ck", .bit_shift = 0x1f, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m6x2_ck = { .name = "dpll4_m6x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m6x2_ck_data, }; static struct ti_clk_fixed_factor emu_per_alwon_ck_data = { .parent = "dpll4_m6x2_ck", .div = 1, .mult = 1, }; static struct ti_clk emu_per_alwon_ck = { .name = "emu_per_alwon_ck", .type = TI_CLK_FIXED_FACTOR, .data = &emu_per_alwon_ck_data, }; static struct ti_clk_fixed_factor emu_mpu_alwon_ck_data = { .parent = "mpu_ck", .div = 1, .mult = 1, }; static struct ti_clk emu_mpu_alwon_ck = { .name = "emu_mpu_alwon_ck", .type = TI_CLK_FIXED_FACTOR, .data = &emu_mpu_alwon_ck_data, }; static const char *emu_src_mux_ck_parents[] = { "sys_ck", "emu_core_alwon_ck", "emu_per_alwon_ck", "emu_mpu_alwon_ck", }; static struct ti_clk_mux emu_src_mux_ck_data = { .num_parents = ARRAY_SIZE(emu_src_mux_ck_parents), .reg = 0x1140, .module = TI_CLKM_CM, .parents = emu_src_mux_ck_parents, }; static struct ti_clk emu_src_mux_ck = { .name = "emu_src_mux_ck", .type = TI_CLK_MUX, .data = &emu_src_mux_ck_data, }; static struct ti_clk_gate emu_src_ck_data = { .parent = "emu_src_mux_ck", .flags = CLKF_CLKDM, }; static struct ti_clk emu_src_ck = { .name = "emu_src_ck", .clkdm_name = "emu_clkdm", .type = TI_CLK_GATE, .data = &emu_src_ck_data, }; static struct ti_clk_divider atclk_fck_data = { .parent = "emu_src_ck", .bit_shift = 4, .max_div = 3, .reg = 0x1140, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk atclk_fck = { .name = "atclk_fck", .type = TI_CLK_DIVIDER, .data = &atclk_fck_data, }; static struct ti_clk_gate ipss_ick_data = { .parent = "core_l3_ick", .bit_shift = 4, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_AM35XX | CLKF_INTERFACE, }; static struct ti_clk ipss_ick = { .name = "ipss_ick", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &ipss_ick_data, }; static struct ti_clk_gate emac_ick_data = { .parent = "ipss_ick", .bit_shift = 1, .reg = 0x59c, .module = TI_CLKM_SCRM, .flags = CLKF_AM35XX, }; static struct ti_clk emac_ick = { .name = "emac_ick", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &emac_ick_data, }; static struct ti_clk_gate vpfe_ick_data = { .parent = "ipss_ick", .bit_shift = 2, .reg = 0x59c, .module = TI_CLKM_SCRM, .flags = CLKF_AM35XX, }; static struct ti_clk vpfe_ick = { .name = "vpfe_ick", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &vpfe_ick_data, }; static const char *dpll2_ck_parents[] = { "sys_ck", "dpll2_fck", }; static struct ti_clk_dpll dpll2_ck_data = { .num_parents = ARRAY_SIZE(dpll2_ck_parents), .control_reg = 0x4, .idlest_reg = 0x24, .mult_div1_reg = 0x40, .autoidle_reg = 0x34, .module = TI_CLKM_CM, .parents = dpll2_ck_parents, .freqsel_mask = 0xf0, .modes = 0xa2, .div1_mask = 0x7f, .idlest_mask = 0x1, .auto_recal_bit = 0x3, .max_divider = 0x80, .min_divider = 0x1, .recal_en_bit = 0x8, .max_multiplier = 0x7ff, .enable_mask = 0x7, .mult_mask = 0x7ff00, .recal_st_bit = 0x8, .autoidle_mask = 0x7, }; static struct ti_clk dpll2_ck = { .name = "dpll2_ck", .clkdm_name = "dpll2_clkdm", .type = TI_CLK_DPLL, .data = &dpll2_ck_data, }; static struct ti_clk_divider dpll2_m2_ck_data = { .parent = "dpll2_ck", .max_div = 31, .reg = 0x44, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk dpll2_m2_ck = { .name = "dpll2_m2_ck", .type = TI_CLK_DIVIDER, .data = &dpll2_m2_ck_data, }; static const char *mcbsp4_mux_fck_parents[] = { "per_96m_fck", "mcbsp_clks", }; static struct ti_clk_mux mcbsp4_mux_fck_data = { .bit_shift = 2, .num_parents = ARRAY_SIZE(mcbsp4_mux_fck_parents), .reg = 0x2d8, .module = TI_CLKM_SCRM, .parents = mcbsp4_mux_fck_parents, }; static const char *mcbsp1_mux_fck_parents[] = { "core_96m_fck", "mcbsp_clks", }; static struct ti_clk_mux mcbsp1_mux_fck_data = { .bit_shift = 2, .num_parents = ARRAY_SIZE(mcbsp1_mux_fck_parents), .reg = 0x274, .module = TI_CLKM_SCRM, .parents = mcbsp1_mux_fck_parents, }; static struct ti_clk_gate gpt8_gate_fck_data = { .parent = "sys_ck", .bit_shift = 9, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk_gate gpt8_ick_data = { .parent = "per_l4_ick", .bit_shift = 9, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt8_ick = { .name = "gpt8_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt8_ick_data, }; static const char *gpt10_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt10_mux_fck_data = { .bit_shift = 6, .num_parents = ARRAY_SIZE(gpt10_mux_fck_parents), .reg = 0xa40, .module = TI_CLKM_CM, .parents = gpt10_mux_fck_parents, }; static struct ti_clk_gate mmchs3_ick_data = { .parent = "core_l4_ick", .bit_shift = 30, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mmchs3_ick = { .name = "mmchs3_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mmchs3_ick_data, }; static struct ti_clk_gate gpio3_ick_data = { .parent = "per_l4_ick", .bit_shift = 14, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpio3_ick = { .name = "gpio3_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio3_ick_data, }; static const char *traceclk_src_fck_parents[] = { "sys_ck", "emu_core_alwon_ck", "emu_per_alwon_ck", "emu_mpu_alwon_ck", }; static struct ti_clk_mux traceclk_src_fck_data = { .bit_shift = 2, .num_parents = ARRAY_SIZE(traceclk_src_fck_parents), .reg = 0x1140, .module = TI_CLKM_CM, .parents = traceclk_src_fck_parents, }; static struct ti_clk traceclk_src_fck = { .name = "traceclk_src_fck", .type = TI_CLK_MUX, .data = &traceclk_src_fck_data, }; static struct ti_clk_divider traceclk_fck_data = { .parent = "traceclk_src_fck", .bit_shift = 11, .max_div = 7, .reg = 0x1140, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk traceclk_fck = { .name = "traceclk_fck", .type = TI_CLK_DIVIDER, .data = &traceclk_fck_data, }; static struct ti_clk_gate mcbsp5_gate_fck_data = { .parent = "mcbsp_clks", .bit_shift = 10, .reg = 0xa00, .module = TI_CLKM_CM, }; static struct ti_clk_gate sad2d_ick_data = { .parent = "l3_ick", .bit_shift = 3, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk sad2d_ick = { .name = "sad2d_ick", .clkdm_name = "d2d_clkdm", .type = TI_CLK_GATE, .data = &sad2d_ick_data, }; static const char *gpt1_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt1_mux_fck_data = { .num_parents = ARRAY_SIZE(gpt1_mux_fck_parents), .reg = 0xc40, .module = TI_CLKM_CM, .parents = gpt1_mux_fck_parents, }; static struct ti_clk_gate hecc_ck_data = { .parent = "sys_ck", .bit_shift = 3, .reg = 0x59c, .module = TI_CLKM_SCRM, .flags = CLKF_AM35XX, }; static struct ti_clk hecc_ck = { .name = "hecc_ck", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &hecc_ck_data, }; static struct ti_clk_gate gpt1_gate_fck_data = { .parent = "sys_ck", .bit_shift = 0, .reg = 0xc00, .module = TI_CLKM_CM, }; static struct ti_clk_composite gpt1_fck_data = { .mux = &gpt1_mux_fck_data, .gate = &gpt1_gate_fck_data, }; static struct ti_clk gpt1_fck = { .name = "gpt1_fck", .type = TI_CLK_COMPOSITE, .data = &gpt1_fck_data, }; static struct ti_clk_gate dpll4_m2x2_ck_omap36xx_data = { .parent = "dpll4_m2x2_mul_ck", .bit_shift = 0x1b, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_HSDIV | CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m2x2_ck_omap36xx = { .name = "dpll4_m2x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m2x2_ck_omap36xx_data, .patch = &dpll4_m2x2_ck, }; static struct ti_clk_divider gfx_l3_fck_data = { .parent = "l3_ick", .max_div = 7, .reg = 0xb40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk gfx_l3_fck = { .name = "gfx_l3_fck", .type = TI_CLK_DIVIDER, .data = &gfx_l3_fck_data, }; static struct ti_clk_gate gfx_cg1_ck_data = { .parent = "gfx_l3_fck", .bit_shift = 1, .reg = 0xb00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk gfx_cg1_ck = { .name = "gfx_cg1_ck", .clkdm_name = "gfx_3430es1_clkdm", .type = TI_CLK_GATE, .data = &gfx_cg1_ck_data, }; static struct ti_clk_gate mailboxes_ick_data = { .parent = "core_l4_ick", .bit_shift = 7, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mailboxes_ick = { .name = "mailboxes_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mailboxes_ick_data, }; static struct ti_clk_gate sha11_ick_data = { .parent = "security_l4_ick2", .bit_shift = 1, .reg = 0xa14, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk sha11_ick = { .name = "sha11_ick", .type = TI_CLK_GATE, .data = &sha11_ick_data, }; static struct ti_clk_gate hsotgusb_ick_am35xx_data = { .parent = "ipss_ick", .bit_shift = 0, .reg = 0x59c, .module = TI_CLKM_SCRM, .flags = CLKF_AM35XX, }; static struct ti_clk hsotgusb_ick_am35xx = { .name = "hsotgusb_ick_am35xx", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &hsotgusb_ick_am35xx_data, }; static struct ti_clk_gate mmchs3_fck_data = { .parent = "core_96m_fck", .bit_shift = 30, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mmchs3_fck = { .name = "mmchs3_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mmchs3_fck_data, }; static struct ti_clk_divider pclk_fck_data = { .parent = "emu_src_ck", .bit_shift = 8, .max_div = 7, .reg = 0x1140, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk pclk_fck = { .name = "pclk_fck", .type = TI_CLK_DIVIDER, .data = &pclk_fck_data, }; static const char *dpll4_ck_omap36xx_parents[] = { "sys_ck", "sys_ck", }; static struct ti_clk_dpll dpll4_ck_omap36xx_data = { .num_parents = ARRAY_SIZE(dpll4_ck_omap36xx_parents), .control_reg = 0xd00, .idlest_reg = 0xd20, .mult_div1_reg = 0xd44, .autoidle_reg = 0xd30, .module = TI_CLKM_CM, .parents = dpll4_ck_omap36xx_parents, .modes = 0x82, .div1_mask = 0x7f, .idlest_mask = 0x2, .auto_recal_bit = 0x13, .max_divider = 0x80, .min_divider = 0x1, .recal_en_bit = 0x6, .max_multiplier = 0xfff, .enable_mask = 0x70000, .mult_mask = 0xfff00, .recal_st_bit = 0x6, .autoidle_mask = 0x38, .sddiv_mask = 0xff000000, .dco_mask = 0xe00000, .flags = CLKF_PER | CLKF_J_TYPE, }; static struct ti_clk dpll4_ck_omap36xx = { .name = "dpll4_ck", .type = TI_CLK_DPLL, .data = &dpll4_ck_omap36xx_data, .patch = &dpll4_ck, }; static struct ti_clk_gate uart3_fck_data = { .parent = "per_48m_fck", .bit_shift = 11, .reg = 0x1000, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk uart3_fck = { .name = "uart3_fck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &uart3_fck_data, }; static struct ti_clk_fixed_factor wkup_32k_fck_data = { .parent = "omap_32k_fck", .div = 1, .mult = 1, }; static struct ti_clk wkup_32k_fck = { .name = "wkup_32k_fck", .type = TI_CLK_FIXED_FACTOR, .data = &wkup_32k_fck_data, }; static struct ti_clk_gate sys_clkout1_data = { .parent = "osc_sys_ck", .bit_shift = 7, .reg = 0xd70, .module = TI_CLKM_PRM, }; static struct ti_clk sys_clkout1 = { .name = "sys_clkout1", .type = TI_CLK_GATE, .data = &sys_clkout1_data, }; static struct ti_clk_fixed_factor gpmc_fck_data = { .parent = "core_l3_ick", .div = 1, .mult = 1, }; static struct ti_clk gpmc_fck = { .name = "gpmc_fck", .type = TI_CLK_FIXED_FACTOR, .data = &gpmc_fck_data, }; static struct ti_clk_fixed_factor dpll5_m2_d20_ck_data = { .parent = "dpll5_m2_ck", .div = 20, .mult = 1, }; static struct ti_clk dpll5_m2_d20_ck = { .name = "dpll5_m2_d20_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll5_m2_d20_ck_data, }; static struct ti_clk_gate dpll4_m5x2_ck_omap36xx_data = { .parent = "dpll4_m5x2_mul_ck", .bit_shift = 0x1e, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_HSDIV | CLKF_SET_RATE_PARENT | CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m5x2_ck_omap36xx = { .name = "dpll4_m5x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m5x2_ck_omap36xx_data, .patch = &dpll4_m5x2_ck, }; static struct ti_clk_gate ssi_ssr_gate_fck_3430es2_data = { .parent = "corex2_fck", .bit_shift = 0, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_NO_WAIT, }; static struct ti_clk_gate uart1_ick_data = { .parent = "core_l4_ick", .bit_shift = 13, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk uart1_ick = { .name = "uart1_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &uart1_ick_data, }; static struct ti_clk_gate iva2_ck_data = { .parent = "dpll2_m2_ck", .bit_shift = 0, .reg = 0x0, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk iva2_ck = { .name = "iva2_ck", .clkdm_name = "iva2_clkdm", .type = TI_CLK_GATE, .data = &iva2_ck_data, }; static struct ti_clk_gate pka_ick_data = { .parent = "security_l3_ick", .bit_shift = 4, .reg = 0xa14, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk pka_ick = { .name = "pka_ick", .type = TI_CLK_GATE, .data = &pka_ick_data, }; static struct ti_clk_gate gpt12_ick_data = { .parent = "wkup_l4_ick", .bit_shift = 1, .reg = 0xc10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt12_ick = { .name = "gpt12_ick", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &gpt12_ick_data, }; static const char *mcbsp5_mux_fck_parents[] = { "core_96m_fck", "mcbsp_clks", }; static struct ti_clk_mux mcbsp5_mux_fck_data = { .bit_shift = 4, .num_parents = ARRAY_SIZE(mcbsp5_mux_fck_parents), .reg = 0x2d8, .module = TI_CLKM_SCRM, .parents = mcbsp5_mux_fck_parents, }; static struct ti_clk_composite mcbsp5_fck_data = { .mux = &mcbsp5_mux_fck_data, .gate = &mcbsp5_gate_fck_data, }; static struct ti_clk mcbsp5_fck = { .name = "mcbsp5_fck", .type = TI_CLK_COMPOSITE, .data = &mcbsp5_fck_data, }; static struct ti_clk_gate usbhost_48m_fck_data = { .parent = "omap_48m_fck", .bit_shift = 0, .reg = 0x1400, .module = TI_CLKM_CM, .flags = CLKF_DSS, }; static struct ti_clk usbhost_48m_fck = { .name = "usbhost_48m_fck", .clkdm_name = "usbhost_clkdm", .type = TI_CLK_GATE, .data = &usbhost_48m_fck_data, }; static struct ti_clk_gate des1_ick_data = { .parent = "security_l4_ick2", .bit_shift = 0, .reg = 0xa14, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk des1_ick = { .name = "des1_ick", .type = TI_CLK_GATE, .data = &des1_ick_data, }; static struct ti_clk_gate sgx_gate_fck_data = { .parent = "core_ck", .bit_shift = 1, .reg = 0xb00, .module = TI_CLKM_CM, }; static struct ti_clk_fixed_factor core_d4_ck_data = { .parent = "core_ck", .div = 4, .mult = 1, }; static struct ti_clk core_d4_ck = { .name = "core_d4_ck", .type = TI_CLK_FIXED_FACTOR, .data = &core_d4_ck_data, }; static struct ti_clk_fixed_factor omap_192m_alwon_fck_data = { .parent = "dpll4_m2x2_ck", .div = 1, .mult = 1, }; static struct ti_clk omap_192m_alwon_fck = { .name = "omap_192m_alwon_fck", .type = TI_CLK_FIXED_FACTOR, .data = &omap_192m_alwon_fck_data, }; static struct ti_clk_fixed_factor core_d2_ck_data = { .parent = "core_ck", .div = 2, .mult = 1, }; static struct ti_clk core_d2_ck = { .name = "core_d2_ck", .type = TI_CLK_FIXED_FACTOR, .data = &core_d2_ck_data, }; static struct ti_clk_fixed_factor corex2_d3_fck_data = { .parent = "corex2_fck", .div = 3, .mult = 1, }; static struct ti_clk corex2_d3_fck = { .name = "corex2_d3_fck", .type = TI_CLK_FIXED_FACTOR, .data = &corex2_d3_fck_data, }; static struct ti_clk_fixed_factor corex2_d5_fck_data = { .parent = "corex2_fck", .div = 5, .mult = 1, }; static struct ti_clk corex2_d5_fck = { .name = "corex2_d5_fck", .type = TI_CLK_FIXED_FACTOR, .data = &corex2_d5_fck_data, }; static const char *sgx_mux_fck_parents[] = { "core_d3_ck", "core_d4_ck", "core_d6_ck", "cm_96m_fck", "omap_192m_alwon_fck", "core_d2_ck", "corex2_d3_fck", "corex2_d5_fck", }; static struct ti_clk_mux sgx_mux_fck_data = { .num_parents = ARRAY_SIZE(sgx_mux_fck_parents), .reg = 0xb40, .module = TI_CLKM_CM, .parents = sgx_mux_fck_parents, }; static struct ti_clk_composite sgx_fck_data = { .mux = &sgx_mux_fck_data, .gate = &sgx_gate_fck_data, }; static struct ti_clk sgx_fck = { .name = "sgx_fck", .type = TI_CLK_COMPOSITE, .data = &sgx_fck_data, }; static struct ti_clk_gate mcspi1_fck_data = { .parent = "core_48m_fck", .bit_shift = 18, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mcspi1_fck = { .name = "mcspi1_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi1_fck_data, }; static struct ti_clk_gate mmchs2_fck_data = { .parent = "core_96m_fck", .bit_shift = 25, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mmchs2_fck = { .name = "mmchs2_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mmchs2_fck_data, }; static struct ti_clk_gate mcspi2_fck_data = { .parent = "core_48m_fck", .bit_shift = 19, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mcspi2_fck = { .name = "mcspi2_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi2_fck_data, }; static struct ti_clk_gate vpfe_fck_data = { .parent = "pclk_ck", .bit_shift = 10, .reg = 0x59c, .module = TI_CLKM_SCRM, }; static struct ti_clk vpfe_fck = { .name = "vpfe_fck", .type = TI_CLK_GATE, .data = &vpfe_fck_data, }; static struct ti_clk_gate gpt4_gate_fck_data = { .parent = "sys_ck", .bit_shift = 5, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk_gate mcbsp1_gate_fck_data = { .parent = "mcbsp_clks", .bit_shift = 9, .reg = 0xa00, .module = TI_CLKM_CM, }; static struct ti_clk_gate gpt5_gate_fck_data = { .parent = "sys_ck", .bit_shift = 6, .reg = 0x1000, .module = TI_CLKM_CM, }; static const char *gpt5_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt5_mux_fck_data = { .bit_shift = 3, .num_parents = ARRAY_SIZE(gpt5_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt5_mux_fck_parents, }; static struct ti_clk_composite gpt5_fck_data = { .mux = &gpt5_mux_fck_data, .gate = &gpt5_gate_fck_data, }; static struct ti_clk gpt5_fck = { .name = "gpt5_fck", .type = TI_CLK_COMPOSITE, .data = &gpt5_fck_data, }; static struct ti_clk_gate ts_fck_data = { .parent = "omap_32k_fck", .bit_shift = 1, .reg = 0xa08, .module = TI_CLKM_CM, }; static struct ti_clk ts_fck = { .name = "ts_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &ts_fck_data, }; static struct ti_clk_fixed_factor wdt1_fck_data = { .parent = "secure_32k_fck", .div = 1, .mult = 1, }; static struct ti_clk wdt1_fck = { .name = "wdt1_fck", .type = TI_CLK_FIXED_FACTOR, .data = &wdt1_fck_data, }; static struct ti_clk_gate dpll4_m6x2_ck_omap36xx_data = { .parent = "dpll4_m6x2_mul_ck", .bit_shift = 0x1f, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_HSDIV | CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m6x2_ck_omap36xx = { .name = "dpll4_m6x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m6x2_ck_omap36xx_data, .patch = &dpll4_m6x2_ck, }; static const char *gpt4_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt4_mux_fck_data = { .bit_shift = 2, .num_parents = ARRAY_SIZE(gpt4_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt4_mux_fck_parents, }; static struct ti_clk_gate usbhost_ick_data = { .parent = "l4_ick", .bit_shift = 0, .reg = 0x1410, .module = TI_CLKM_CM, .flags = CLKF_DSS | CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk usbhost_ick = { .name = "usbhost_ick", .clkdm_name = "usbhost_clkdm", .type = TI_CLK_GATE, .data = &usbhost_ick_data, }; static struct ti_clk_gate mcbsp2_ick_data = { .parent = "per_l4_ick", .bit_shift = 0, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcbsp2_ick = { .name = "mcbsp2_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &mcbsp2_ick_data, }; static struct ti_clk_gate omapctrl_ick_data = { .parent = "core_l4_ick", .bit_shift = 6, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk omapctrl_ick = { .name = "omapctrl_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &omapctrl_ick_data, }; static struct ti_clk_fixed_factor omap_96m_d4_fck_data = { .parent = "omap_96m_fck", .div = 4, .mult = 1, }; static struct ti_clk omap_96m_d4_fck = { .name = "omap_96m_d4_fck", .type = TI_CLK_FIXED_FACTOR, .data = &omap_96m_d4_fck_data, }; static struct ti_clk_gate gpt6_ick_data = { .parent = "per_l4_ick", .bit_shift = 7, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt6_ick = { .name = "gpt6_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt6_ick_data, }; static struct ti_clk_gate dpll3_m3x2_ck_omap36xx_data = { .parent = "dpll3_m3x2_mul_ck", .bit_shift = 0xc, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_HSDIV | CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll3_m3x2_ck_omap36xx = { .name = "dpll3_m3x2_ck", .type = TI_CLK_GATE, .data = &dpll3_m3x2_ck_omap36xx_data, .patch = &dpll3_m3x2_ck, }; static struct ti_clk_gate i2c3_ick_data = { .parent = "core_l4_ick", .bit_shift = 17, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk i2c3_ick = { .name = "i2c3_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &i2c3_ick_data, }; static struct ti_clk_gate gpio6_ick_data = { .parent = "per_l4_ick", .bit_shift = 17, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpio6_ick = { .name = "gpio6_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio6_ick_data, }; static struct ti_clk_gate mspro_ick_data = { .parent = "core_l4_ick", .bit_shift = 23, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mspro_ick = { .name = "mspro_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mspro_ick_data, }; static struct ti_clk_composite mcbsp1_fck_data = { .mux = &mcbsp1_mux_fck_data, .gate = &mcbsp1_gate_fck_data, }; static struct ti_clk mcbsp1_fck = { .name = "mcbsp1_fck", .type = TI_CLK_COMPOSITE, .data = &mcbsp1_fck_data, }; static struct ti_clk_gate gpt3_gate_fck_data = { .parent = "sys_ck", .bit_shift = 4, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk_fixed rmii_ck_data = { .frequency = 50000000, }; static struct ti_clk rmii_ck = { .name = "rmii_ck", .type = TI_CLK_FIXED, .data = &rmii_ck_data, }; static struct ti_clk_gate gpt6_gate_fck_data = { .parent = "sys_ck", .bit_shift = 7, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk_composite gpt6_fck_data = { .mux = &gpt6_mux_fck_data, .gate = &gpt6_gate_fck_data, }; static struct ti_clk gpt6_fck = { .name = "gpt6_fck", .type = TI_CLK_COMPOSITE, .data = &gpt6_fck_data, }; static struct ti_clk_fixed_factor dpll5_m2_d4_ck_data = { .parent = "dpll5_m2_ck", .div = 4, .mult = 1, }; static struct ti_clk dpll5_m2_d4_ck = { .name = "dpll5_m2_d4_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll5_m2_d4_ck_data, }; static struct ti_clk_fixed_factor sys_d2_ck_data = { .parent = "sys_ck", .div = 2, .mult = 1, }; static struct ti_clk sys_d2_ck = { .name = "sys_d2_ck", .type = TI_CLK_FIXED_FACTOR, .data = &sys_d2_ck_data, }; static struct ti_clk_fixed_factor omap_96m_d2_fck_data = { .parent = "omap_96m_fck", .div = 2, .mult = 1, }; static struct ti_clk omap_96m_d2_fck = { .name = "omap_96m_d2_fck", .type = TI_CLK_FIXED_FACTOR, .data = &omap_96m_d2_fck_data, }; static struct ti_clk_fixed_factor dpll5_m2_d8_ck_data = { .parent = "dpll5_m2_ck", .div = 8, .mult = 1, }; static struct ti_clk dpll5_m2_d8_ck = { .name = "dpll5_m2_d8_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll5_m2_d8_ck_data, }; static struct ti_clk_fixed_factor dpll5_m2_d16_ck_data = { .parent = "dpll5_m2_ck", .div = 16, .mult = 1, }; static struct ti_clk dpll5_m2_d16_ck = { .name = "dpll5_m2_d16_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll5_m2_d16_ck_data, }; static const char *usim_mux_fck_parents[] = { "sys_ck", "sys_d2_ck", "omap_96m_d2_fck", "omap_96m_d4_fck", "omap_96m_d8_fck", "omap_96m_d10_fck", "dpll5_m2_d4_ck", "dpll5_m2_d8_ck", "dpll5_m2_d16_ck", "dpll5_m2_d20_ck", }; static struct ti_clk_mux usim_mux_fck_data = { .bit_shift = 3, .num_parents = ARRAY_SIZE(usim_mux_fck_parents), .reg = 0xc40, .module = TI_CLKM_CM, .parents = usim_mux_fck_parents, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk_composite usim_fck_data = { .mux = &usim_mux_fck_data, .gate = &usim_gate_fck_data, }; static struct ti_clk usim_fck = { .name = "usim_fck", .type = TI_CLK_COMPOSITE, .data = &usim_fck_data, }; static int ssi_ssr_div_fck_3430es2_divs[] = { 0, 1, 2, 3, 4, 0, 6, 0, 8, }; static struct ti_clk_divider ssi_ssr_div_fck_3430es2_data = { .num_dividers = ARRAY_SIZE(ssi_ssr_div_fck_3430es2_divs), .parent = "corex2_fck", .bit_shift = 8, .dividers = ssi_ssr_div_fck_3430es2_divs, .reg = 0xa40, .module = TI_CLKM_CM, }; static struct ti_clk_composite ssi_ssr_fck_3430es2_data = { .gate = &ssi_ssr_gate_fck_3430es2_data, .divider = &ssi_ssr_div_fck_3430es2_data, }; static struct ti_clk ssi_ssr_fck_3430es2 = { .name = "ssi_ssr_fck", .type = TI_CLK_COMPOSITE, .data = &ssi_ssr_fck_3430es2_data, }; static struct ti_clk_gate dss1_alwon_fck_3430es1_data = { .parent = "dpll4_m4x2_ck", .bit_shift = 0, .reg = 0xe00, .module = TI_CLKM_CM, .flags = CLKF_SET_RATE_PARENT, }; static struct ti_clk dss1_alwon_fck_3430es1 = { .name = "dss1_alwon_fck", .clkdm_name = "dss_clkdm", .type = TI_CLK_GATE, .data = &dss1_alwon_fck_3430es1_data, }; static struct ti_clk_gate gpt3_ick_data = { .parent = "per_l4_ick", .bit_shift = 4, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt3_ick = { .name = "gpt3_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt3_ick_data, }; static struct ti_clk_fixed_factor omap_12m_fck_data = { .parent = "omap_48m_fck", .div = 4, .mult = 1, }; static struct ti_clk omap_12m_fck = { .name = "omap_12m_fck", .type = TI_CLK_FIXED_FACTOR, .data = &omap_12m_fck_data, }; static struct ti_clk_fixed_factor core_12m_fck_data = { .parent = "omap_12m_fck", .div = 1, .mult = 1, }; static struct ti_clk core_12m_fck = { .name = "core_12m_fck", .type = TI_CLK_FIXED_FACTOR, .data = &core_12m_fck_data, }; static struct ti_clk_gate hdq_fck_data = { .parent = "core_12m_fck", .bit_shift = 22, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk hdq_fck = { .name = "hdq_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &hdq_fck_data, }; static struct ti_clk_gate usbtll_fck_data = { .parent = "dpll5_m2_ck", .bit_shift = 2, .reg = 0xa08, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk usbtll_fck = { .name = "usbtll_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &usbtll_fck_data, }; static struct ti_clk_gate hsotgusb_fck_am35xx_data = { .parent = "sys_ck", .bit_shift = 8, .reg = 0x59c, .module = TI_CLKM_SCRM, }; static struct ti_clk hsotgusb_fck_am35xx = { .name = "hsotgusb_fck_am35xx", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &hsotgusb_fck_am35xx_data, }; static struct ti_clk_gate hsotgusb_ick_3430es2_data = { .parent = "core_l3_ick", .bit_shift = 4, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_HSOTGUSB | CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk hsotgusb_ick_3430es2 = { .name = "hsotgusb_ick_3430es2", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &hsotgusb_ick_3430es2_data, }; static struct ti_clk_gate gfx_l3_ck_data = { .parent = "l3_ick", .bit_shift = 0, .reg = 0xb10, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk gfx_l3_ck = { .name = "gfx_l3_ck", .clkdm_name = "gfx_3430es1_clkdm", .type = TI_CLK_GATE, .data = &gfx_l3_ck_data, }; static struct ti_clk_fixed_factor gfx_l3_ick_data = { .parent = "gfx_l3_ck", .div = 1, .mult = 1, }; static struct ti_clk gfx_l3_ick = { .name = "gfx_l3_ick", .type = TI_CLK_FIXED_FACTOR, .data = &gfx_l3_ick_data, }; static struct ti_clk_gate mcbsp1_ick_data = { .parent = "core_l4_ick", .bit_shift = 9, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcbsp1_ick = { .name = "mcbsp1_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcbsp1_ick_data, }; static struct ti_clk_fixed_factor gpt12_fck_data = { .parent = "secure_32k_fck", .div = 1, .mult = 1, }; static struct ti_clk gpt12_fck = { .name = "gpt12_fck", .type = TI_CLK_FIXED_FACTOR, .data = &gpt12_fck_data, }; static struct ti_clk_gate gfx_cg2_ck_data = { .parent = "gfx_l3_fck", .bit_shift = 2, .reg = 0xb00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk gfx_cg2_ck = { .name = "gfx_cg2_ck", .clkdm_name = "gfx_3430es1_clkdm", .type = TI_CLK_GATE, .data = &gfx_cg2_ck_data, }; static struct ti_clk_gate i2c2_ick_data = { .parent = "core_l4_ick", .bit_shift = 16, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk i2c2_ick = { .name = "i2c2_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &i2c2_ick_data, }; static struct ti_clk_gate gpio4_dbck_data = { .parent = "per_32k_alwon_fck", .bit_shift = 15, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk gpio4_dbck = { .name = "gpio4_dbck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio4_dbck_data, }; static struct ti_clk_gate i2c3_fck_data = { .parent = "core_96m_fck", .bit_shift = 17, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk i2c3_fck = { .name = "i2c3_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &i2c3_fck_data, }; static struct ti_clk_composite gpt3_fck_data = { .mux = &gpt3_mux_fck_data, .gate = &gpt3_gate_fck_data, }; static struct ti_clk gpt3_fck = { .name = "gpt3_fck", .type = TI_CLK_COMPOSITE, .data = &gpt3_fck_data, }; static struct ti_clk_gate i2c1_ick_data = { .parent = "core_l4_ick", .bit_shift = 15, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk i2c1_ick = { .name = "i2c1_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &i2c1_ick_data, }; static struct ti_clk_gate omap_32ksync_ick_data = { .parent = "wkup_l4_ick", .bit_shift = 2, .reg = 0xc10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk omap_32ksync_ick = { .name = "omap_32ksync_ick", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &omap_32ksync_ick_data, }; static struct ti_clk_gate aes2_ick_data = { .parent = "core_l4_ick", .bit_shift = 28, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk aes2_ick = { .name = "aes2_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &aes2_ick_data, }; static const char *gpt8_mux_fck_parents[] = { "omap_32k_fck", "sys_ck", }; static struct ti_clk_mux gpt8_mux_fck_data = { .bit_shift = 6, .num_parents = ARRAY_SIZE(gpt8_mux_fck_parents), .reg = 0x1040, .module = TI_CLKM_CM, .parents = gpt8_mux_fck_parents, }; static struct ti_clk_composite gpt8_fck_data = { .mux = &gpt8_mux_fck_data, .gate = &gpt8_gate_fck_data, }; static struct ti_clk gpt8_fck = { .name = "gpt8_fck", .type = TI_CLK_COMPOSITE, .data = &gpt8_fck_data, }; static struct ti_clk_gate mcbsp4_gate_fck_data = { .parent = "mcbsp_clks", .bit_shift = 2, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk_composite mcbsp4_fck_data = { .mux = &mcbsp4_mux_fck_data, .gate = &mcbsp4_gate_fck_data, }; static struct ti_clk mcbsp4_fck = { .name = "mcbsp4_fck", .type = TI_CLK_COMPOSITE, .data = &mcbsp4_fck_data, }; static struct ti_clk_gate gpio2_dbck_data = { .parent = "per_32k_alwon_fck", .bit_shift = 13, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk gpio2_dbck = { .name = "gpio2_dbck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio2_dbck_data, }; static struct ti_clk_gate usbtll_ick_data = { .parent = "core_l4_ick", .bit_shift = 2, .reg = 0xa18, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk usbtll_ick = { .name = "usbtll_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &usbtll_ick_data, }; static struct ti_clk_gate mcspi4_ick_data = { .parent = "core_l4_ick", .bit_shift = 21, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcspi4_ick = { .name = "mcspi4_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi4_ick_data, }; static struct ti_clk_gate dss_96m_fck_data = { .parent = "omap_96m_fck", .bit_shift = 2, .reg = 0xe00, .module = TI_CLKM_CM, }; static struct ti_clk dss_96m_fck = { .name = "dss_96m_fck", .clkdm_name = "dss_clkdm", .type = TI_CLK_GATE, .data = &dss_96m_fck_data, }; static struct ti_clk_divider rm_ick_data = { .parent = "l4_ick", .bit_shift = 1, .max_div = 3, .reg = 0xc40, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk rm_ick = { .name = "rm_ick", .type = TI_CLK_DIVIDER, .data = &rm_ick_data, }; static struct ti_clk_gate hdq_ick_data = { .parent = "core_l4_ick", .bit_shift = 22, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk hdq_ick = { .name = "hdq_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &hdq_ick_data, }; static struct ti_clk_fixed_factor dpll3_x2_ck_data = { .parent = "dpll3_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll3_x2_ck = { .name = "dpll3_x2_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll3_x2_ck_data, }; static struct ti_clk_gate mad2d_ick_data = { .parent = "l3_ick", .bit_shift = 3, .reg = 0xa18, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mad2d_ick = { .name = "mad2d_ick", .clkdm_name = "d2d_clkdm", .type = TI_CLK_GATE, .data = &mad2d_ick_data, }; static struct ti_clk_gate fshostusb_fck_data = { .parent = "core_48m_fck", .bit_shift = 5, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk fshostusb_fck = { .name = "fshostusb_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &fshostusb_fck_data, }; static struct ti_clk_gate sr1_fck_data = { .parent = "sys_ck", .bit_shift = 6, .reg = 0xc00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk sr1_fck = { .name = "sr1_fck", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &sr1_fck_data, }; static struct ti_clk_gate des2_ick_data = { .parent = "core_l4_ick", .bit_shift = 26, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk des2_ick = { .name = "des2_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &des2_ick_data, }; static struct ti_clk_gate sdrc_ick_data = { .parent = "core_l3_ick", .bit_shift = 1, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk sdrc_ick = { .name = "sdrc_ick", .clkdm_name = "core_l3_clkdm", .type = TI_CLK_GATE, .data = &sdrc_ick_data, }; static struct ti_clk_composite gpt4_fck_data = { .mux = &gpt4_mux_fck_data, .gate = &gpt4_gate_fck_data, }; static struct ti_clk gpt4_fck = { .name = "gpt4_fck", .type = TI_CLK_COMPOSITE, .data = &gpt4_fck_data, }; static struct ti_clk_gate dpll4_m3x2_ck_omap36xx_data = { .parent = "dpll4_m3x2_mul_ck", .bit_shift = 0x1c, .reg = 0xd00, .module = TI_CLKM_CM, .flags = CLKF_HSDIV | CLKF_SET_BIT_TO_DISABLE, }; static struct ti_clk dpll4_m3x2_ck_omap36xx = { .name = "dpll4_m3x2_ck", .type = TI_CLK_GATE, .data = &dpll4_m3x2_ck_omap36xx_data, .patch = &dpll4_m3x2_ck, }; static struct ti_clk_gate cpefuse_fck_data = { .parent = "sys_ck", .bit_shift = 0, .reg = 0xa08, .module = TI_CLKM_CM, }; static struct ti_clk cpefuse_fck = { .name = "cpefuse_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &cpefuse_fck_data, }; static struct ti_clk_gate mcspi3_ick_data = { .parent = "core_l4_ick", .bit_shift = 20, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcspi3_ick = { .name = "mcspi3_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi3_ick_data, }; static struct ti_clk_fixed_factor ssi_sst_fck_3430es2_data = { .parent = "ssi_ssr_fck", .div = 2, .mult = 1, }; static struct ti_clk ssi_sst_fck_3430es2 = { .name = "ssi_sst_fck", .type = TI_CLK_FIXED_FACTOR, .data = &ssi_sst_fck_3430es2_data, }; static struct ti_clk_gate gpio1_dbck_data = { .parent = "wkup_32k_fck", .bit_shift = 3, .reg = 0xc00, .module = TI_CLKM_CM, }; static struct ti_clk gpio1_dbck = { .name = "gpio1_dbck", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &gpio1_dbck_data, }; static struct ti_clk_gate gpt4_ick_data = { .parent = "per_l4_ick", .bit_shift = 5, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt4_ick = { .name = "gpt4_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt4_ick_data, }; static struct ti_clk_gate gpt2_ick_data = { .parent = "per_l4_ick", .bit_shift = 3, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt2_ick = { .name = "gpt2_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt2_ick_data, }; static struct ti_clk_gate mmchs1_fck_data = { .parent = "core_96m_fck", .bit_shift = 24, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk mmchs1_fck = { .name = "mmchs1_fck", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mmchs1_fck_data, }; static struct ti_clk_fixed dummy_apb_pclk_data = { .frequency = 0x0, }; static struct ti_clk dummy_apb_pclk = { .name = "dummy_apb_pclk", .type = TI_CLK_FIXED, .data = &dummy_apb_pclk_data, }; static struct ti_clk_gate gpio6_dbck_data = { .parent = "per_32k_alwon_fck", .bit_shift = 17, .reg = 0x1000, .module = TI_CLKM_CM, }; static struct ti_clk gpio6_dbck = { .name = "gpio6_dbck", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio6_dbck_data, }; static struct ti_clk_gate uart2_ick_data = { .parent = "core_l4_ick", .bit_shift = 14, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk uart2_ick = { .name = "uart2_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &uart2_ick_data, }; static struct ti_clk_fixed_factor dpll4_x2_ck_data = { .parent = "dpll4_ck", .div = 1, .mult = 2, }; static struct ti_clk dpll4_x2_ck = { .name = "dpll4_x2_ck", .type = TI_CLK_FIXED_FACTOR, .data = &dpll4_x2_ck_data, }; static struct ti_clk_gate gpt7_ick_data = { .parent = "per_l4_ick", .bit_shift = 8, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpt7_ick = { .name = "gpt7_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpt7_ick_data, }; static struct ti_clk_gate dss_tv_fck_data = { .parent = "omap_54m_fck", .bit_shift = 2, .reg = 0xe00, .module = TI_CLKM_CM, }; static struct ti_clk dss_tv_fck = { .name = "dss_tv_fck", .clkdm_name = "dss_clkdm", .type = TI_CLK_GATE, .data = &dss_tv_fck_data, }; static struct ti_clk_gate mcbsp5_ick_data = { .parent = "core_l4_ick", .bit_shift = 10, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcbsp5_ick = { .name = "mcbsp5_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcbsp5_ick_data, }; static struct ti_clk_gate mcspi1_ick_data = { .parent = "core_l4_ick", .bit_shift = 18, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk mcspi1_ick = { .name = "mcspi1_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &mcspi1_ick_data, }; static struct ti_clk_gate d2d_26m_fck_data = { .parent = "sys_ck", .bit_shift = 3, .reg = 0xa00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk d2d_26m_fck = { .name = "d2d_26m_fck", .clkdm_name = "d2d_clkdm", .type = TI_CLK_GATE, .data = &d2d_26m_fck_data, }; static struct ti_clk_gate wdt3_ick_data = { .parent = "per_l4_ick", .bit_shift = 12, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk wdt3_ick = { .name = "wdt3_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &wdt3_ick_data, }; static struct ti_clk_divider pclkx2_fck_data = { .parent = "emu_src_ck", .bit_shift = 6, .max_div = 3, .reg = 0x1140, .module = TI_CLKM_CM, .flags = CLKF_INDEX_STARTS_AT_ONE, }; static struct ti_clk pclkx2_fck = { .name = "pclkx2_fck", .type = TI_CLK_DIVIDER, .data = &pclkx2_fck_data, }; static struct ti_clk_gate sha12_ick_data = { .parent = "core_l4_ick", .bit_shift = 27, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk sha12_ick = { .name = "sha12_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &sha12_ick_data, }; static struct ti_clk_gate emac_fck_data = { .parent = "rmii_ck", .bit_shift = 9, .reg = 0x59c, .module = TI_CLKM_SCRM, }; static struct ti_clk emac_fck = { .name = "emac_fck", .type = TI_CLK_GATE, .data = &emac_fck_data, }; static struct ti_clk_composite gpt10_fck_data = { .mux = &gpt10_mux_fck_data, .gate = &gpt10_gate_fck_data, }; static struct ti_clk gpt10_fck = { .name = "gpt10_fck", .type = TI_CLK_COMPOSITE, .data = &gpt10_fck_data, }; static struct ti_clk_gate wdt2_fck_data = { .parent = "wkup_32k_fck", .bit_shift = 5, .reg = 0xc00, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk wdt2_fck = { .name = "wdt2_fck", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &wdt2_fck_data, }; static struct ti_clk_gate cam_ick_data = { .parent = "l4_ick", .bit_shift = 0, .reg = 0xf10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_NO_WAIT | CLKF_INTERFACE, }; static struct ti_clk cam_ick = { .name = "cam_ick", .clkdm_name = "cam_clkdm", .type = TI_CLK_GATE, .data = &cam_ick_data, }; static struct ti_clk_gate ssi_ick_3430es2_data = { .parent = "ssi_l4_ick", .bit_shift = 0, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_SSI | CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk ssi_ick_3430es2 = { .name = "ssi_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &ssi_ick_3430es2_data, }; static struct ti_clk_gate gpio4_ick_data = { .parent = "per_l4_ick", .bit_shift = 15, .reg = 0x1010, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk gpio4_ick = { .name = "gpio4_ick", .clkdm_name = "per_clkdm", .type = TI_CLK_GATE, .data = &gpio4_ick_data, }; static struct ti_clk_gate wdt1_ick_data = { .parent = "wkup_l4_ick", .bit_shift = 4, .reg = 0xc10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk wdt1_ick = { .name = "wdt1_ick", .clkdm_name = "wkup_clkdm", .type = TI_CLK_GATE, .data = &wdt1_ick_data, }; static struct ti_clk_gate rng_ick_data = { .parent = "security_l4_ick2", .bit_shift = 2, .reg = 0xa14, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk rng_ick = { .name = "rng_ick", .type = TI_CLK_GATE, .data = &rng_ick_data, }; static struct ti_clk_gate icr_ick_data = { .parent = "core_l4_ick", .bit_shift = 29, .reg = 0xa10, .module = TI_CLKM_CM, .flags = CLKF_OMAP3 | CLKF_INTERFACE, }; static struct ti_clk icr_ick = { .name = "icr_ick", .clkdm_name = "core_l4_clkdm", .type = TI_CLK_GATE, .data = &icr_ick_data, }; static struct ti_clk_gate sgx_ick_data = { .parent = "l3_ick", .bit_shift = 0, .reg = 0xb10, .module = TI_CLKM_CM, .flags = CLKF_WAIT, }; static struct ti_clk sgx_ick = { .name = "sgx_ick", .clkdm_name = "sgx_clkdm", .type = TI_CLK_GATE, .data = &sgx_ick_data, }; static struct ti_clk_divider sys_clkout2_data = { .parent = "clkout2_src_ck", .bit_shift = 3, .max_div = 64, .reg = 0xd70, .module = TI_CLKM_CM, .flags = CLKF_INDEX_POWER_OF_TWO, }; static struct ti_clk sys_clkout2 = { .name = "sys_clkout2", .type = TI_CLK_DIVIDER, .data = &sys_clkout2_data, }; static struct ti_clk_alias omap34xx_omap36xx_clks[] = { CLK(NULL, "security_l4_ick2", &security_l4_ick2), CLK(NULL, "aes1_ick", &aes1_ick), CLK("omap_rng", "ick", &rng_ick), CLK("omap3-rom-rng", "ick", &rng_ick), CLK(NULL, "sha11_ick", &sha11_ick), CLK(NULL, "des1_ick", &des1_ick), CLK(NULL, "cam_mclk", &cam_mclk), CLK(NULL, "cam_ick", &cam_ick), CLK(NULL, "csi2_96m_fck", &csi2_96m_fck), CLK(NULL, "security_l3_ick", &security_l3_ick), CLK(NULL, "pka_ick", &pka_ick), CLK(NULL, "icr_ick", &icr_ick), CLK(NULL, "des2_ick", &des2_ick), CLK(NULL, "mspro_ick", &mspro_ick), CLK(NULL, "mailboxes_ick", &mailboxes_ick), CLK(NULL, "ssi_l4_ick", &ssi_l4_ick), CLK(NULL, "sr1_fck", &sr1_fck), CLK(NULL, "sr2_fck", &sr2_fck), CLK(NULL, "sr_l4_ick", &sr_l4_ick), CLK(NULL, "dpll2_fck", &dpll2_fck), CLK(NULL, "dpll2_ck", &dpll2_ck), CLK(NULL, "dpll2_m2_ck", &dpll2_m2_ck), CLK(NULL, "iva2_ck", &iva2_ck), CLK(NULL, "modem_fck", &modem_fck), CLK(NULL, "sad2d_ick", &sad2d_ick), CLK(NULL, "mad2d_ick", &mad2d_ick), CLK(NULL, "mspro_fck", &mspro_fck), { NULL }, }; static struct ti_clk_alias omap36xx_omap3430es2plus_clks[] = { CLK(NULL, "ssi_ssr_fck", &ssi_ssr_fck_3430es2), CLK(NULL, "ssi_sst_fck", &ssi_sst_fck_3430es2), CLK("musb-omap2430", "ick", &hsotgusb_ick_3430es2), CLK(NULL, "hsotgusb_ick", &hsotgusb_ick_3430es2), CLK(NULL, "ssi_ick", &ssi_ick_3430es2), CLK(NULL, "sys_d2_ck", &sys_d2_ck), CLK(NULL, "omap_96m_d2_fck", &omap_96m_d2_fck), CLK(NULL, "omap_96m_d4_fck", &omap_96m_d4_fck), CLK(NULL, "omap_96m_d8_fck", &omap_96m_d8_fck), CLK(NULL, "omap_96m_d10_fck", &omap_96m_d10_fck), CLK(NULL, "dpll5_m2_d4_ck", &dpll5_m2_d4_ck), CLK(NULL, "dpll5_m2_d8_ck", &dpll5_m2_d8_ck), CLK(NULL, "dpll5_m2_d16_ck", &dpll5_m2_d16_ck), CLK(NULL, "dpll5_m2_d20_ck", &dpll5_m2_d20_ck), CLK(NULL, "usim_fck", &usim_fck), CLK(NULL, "usim_ick", &usim_ick), { NULL }, }; static struct ti_clk_alias omap3xxx_clks[] = { CLK(NULL, "apb_pclk", &dummy_apb_pclk), CLK(NULL, "omap_32k_fck", &omap_32k_fck), CLK(NULL, "virt_12m_ck", &virt_12m_ck), CLK(NULL, "virt_13m_ck", &virt_13m_ck), CLK(NULL, "virt_19200000_ck", &virt_19200000_ck), CLK(NULL, "virt_26000000_ck", &virt_26000000_ck), CLK(NULL, "virt_38_4m_ck", &virt_38_4m_ck), CLK(NULL, "virt_16_8m_ck", &virt_16_8m_ck), CLK(NULL, "osc_sys_ck", &osc_sys_ck), CLK("twl", "fck", &osc_sys_ck), CLK(NULL, "sys_ck", &sys_ck), CLK(NULL, "timer_sys_ck", &sys_ck), CLK(NULL, "dpll4_ck", &dpll4_ck), CLK(NULL, "dpll4_m2_ck", &dpll4_m2_ck), CLK(NULL, "dpll4_m2x2_mul_ck", &dpll4_m2x2_mul_ck), CLK(NULL, "dpll4_m2x2_ck", &dpll4_m2x2_ck), CLK(NULL, "omap_96m_alwon_fck", &omap_96m_alwon_fck), CLK(NULL, "dpll3_ck", &dpll3_ck), CLK(NULL, "dpll3_m3_ck", &dpll3_m3_ck), CLK(NULL, "dpll3_m3x2_mul_ck", &dpll3_m3x2_mul_ck), CLK(NULL, "dpll3_m3x2_ck", &dpll3_m3x2_ck), CLK("etb", "emu_core_alwon_ck", &emu_core_alwon_ck), CLK(NULL, "sys_altclk", &sys_altclk), CLK(NULL, "sys_clkout1", &sys_clkout1), CLK(NULL, "dpll3_m2_ck", &dpll3_m2_ck), CLK(NULL, "core_ck", &core_ck), CLK(NULL, "dpll1_fck", &dpll1_fck), CLK(NULL, "dpll1_ck", &dpll1_ck), CLK(NULL, "cpufreq_ck", &dpll1_ck), CLK(NULL, "dpll1_x2_ck", &dpll1_x2_ck), CLK(NULL, "dpll1_x2m2_ck", &dpll1_x2m2_ck), CLK(NULL, "dpll3_x2_ck", &dpll3_x2_ck), CLK(NULL, "dpll3_m2x2_ck", &dpll3_m2x2_ck), CLK(NULL, "dpll4_x2_ck", &dpll4_x2_ck), CLK(NULL, "cm_96m_fck", &cm_96m_fck), CLK(NULL, "omap_96m_fck", &omap_96m_fck), CLK(NULL, "dpll4_m3_ck", &dpll4_m3_ck), CLK(NULL, "dpll4_m3x2_mul_ck", &dpll4_m3x2_mul_ck), CLK(NULL, "dpll4_m3x2_ck", &dpll4_m3x2_ck), CLK(NULL, "omap_54m_fck", &omap_54m_fck), CLK(NULL, "cm_96m_d2_fck", &cm_96m_d2_fck), CLK(NULL, "omap_48m_fck", &omap_48m_fck), CLK(NULL, "omap_12m_fck", &omap_12m_fck), CLK(NULL, "dpll4_m4_ck", &dpll4_m4_ck), CLK(NULL, "dpll4_m4x2_mul_ck", &dpll4_m4x2_mul_ck), CLK(NULL, "dpll4_m4x2_ck", &dpll4_m4x2_ck), CLK(NULL, "dpll4_m5_ck", &dpll4_m5_ck), CLK(NULL, "dpll4_m5x2_mul_ck", &dpll4_m5x2_mul_ck), CLK(NULL, "dpll4_m5x2_ck", &dpll4_m5x2_ck), CLK(NULL, "dpll4_m6_ck", &dpll4_m6_ck), CLK(NULL, "dpll4_m6x2_mul_ck", &dpll4_m6x2_mul_ck), CLK(NULL, "dpll4_m6x2_ck", &dpll4_m6x2_ck), CLK("etb", "emu_per_alwon_ck", &emu_per_alwon_ck), CLK(NULL, "clkout2_src_ck", &clkout2_src_ck), CLK(NULL, "sys_clkout2", &sys_clkout2), CLK(NULL, "corex2_fck", &corex2_fck), CLK(NULL, "mpu_ck", &mpu_ck), CLK(NULL, "arm_fck", &arm_fck), CLK("etb", "emu_mpu_alwon_ck", &emu_mpu_alwon_ck), CLK(NULL, "l3_ick", &l3_ick), CLK(NULL, "l4_ick", &l4_ick), CLK(NULL, "rm_ick", &rm_ick), CLK(NULL, "timer_32k_ck", &omap_32k_fck), CLK(NULL, "gpt10_fck", &gpt10_fck), CLK(NULL, "gpt11_fck", &gpt11_fck), CLK(NULL, "core_96m_fck", &core_96m_fck), CLK(NULL, "mmchs2_fck", &mmchs2_fck), CLK(NULL, "mmchs1_fck", &mmchs1_fck), CLK(NULL, "i2c3_fck", &i2c3_fck), CLK(NULL, "i2c2_fck", &i2c2_fck), CLK(NULL, "i2c1_fck", &i2c1_fck), CLK(NULL, "core_48m_fck", &core_48m_fck), CLK(NULL, "mcspi4_fck", &mcspi4_fck), CLK(NULL, "mcspi3_fck", &mcspi3_fck), CLK(NULL, "mcspi2_fck", &mcspi2_fck), CLK(NULL, "mcspi1_fck", &mcspi1_fck), CLK(NULL, "uart2_fck", &uart2_fck), CLK(NULL, "uart1_fck", &uart1_fck), CLK(NULL, "core_12m_fck", &core_12m_fck), CLK("omap_hdq.0", "fck", &hdq_fck), CLK(NULL, "hdq_fck", &hdq_fck), CLK(NULL, "core_l3_ick", &core_l3_ick), CLK(NULL, "sdrc_ick", &sdrc_ick), CLK(NULL, "gpmc_fck", &gpmc_fck), CLK(NULL, "core_l4_ick", &core_l4_ick), CLK("omap_hsmmc.1", "ick", &mmchs2_ick), CLK("omap_hsmmc.0", "ick", &mmchs1_ick), CLK(NULL, "mmchs2_ick", &mmchs2_ick), CLK(NULL, "mmchs1_ick", &mmchs1_ick), CLK("omap_hdq.0", "ick", &hdq_ick), CLK(NULL, "hdq_ick", &hdq_ick), CLK("omap2_mcspi.4", "ick", &mcspi4_ick), CLK("omap2_mcspi.3", "ick", &mcspi3_ick), CLK("omap2_mcspi.2", "ick", &mcspi2_ick), CLK("omap2_mcspi.1", "ick", &mcspi1_ick), CLK(NULL, "mcspi4_ick", &mcspi4_ick), CLK(NULL, "mcspi3_ick", &mcspi3_ick), CLK(NULL, "mcspi2_ick", &mcspi2_ick), CLK(NULL, "mcspi1_ick", &mcspi1_ick), CLK("omap_i2c.3", "ick", &i2c3_ick), CLK("omap_i2c.2", "ick", &i2c2_ick), CLK("omap_i2c.1", "ick", &i2c1_ick), CLK(NULL, "i2c3_ick", &i2c3_ick), CLK(NULL, "i2c2_ick", &i2c2_ick), CLK(NULL, "i2c1_ick", &i2c1_ick), CLK(NULL, "uart2_ick", &uart2_ick), CLK(NULL, "uart1_ick", &uart1_ick), CLK(NULL, "gpt11_ick", &gpt11_ick), CLK(NULL, "gpt10_ick", &gpt10_ick), CLK(NULL, "mcbsp5_ick", &mcbsp5_ick), CLK(NULL, "mcbsp1_ick", &mcbsp1_ick), CLK(NULL, "omapctrl_ick", &omapctrl_ick), CLK(NULL, "dss_tv_fck", &dss_tv_fck), CLK(NULL, "dss_96m_fck", &dss_96m_fck), CLK(NULL, "dss2_alwon_fck", &dss2_alwon_fck), CLK(NULL, "init_60m_fclk", &dummy_ck), CLK(NULL, "gpt1_fck", &gpt1_fck), CLK(NULL, "aes2_ick", &aes2_ick), CLK(NULL, "wkup_32k_fck", &wkup_32k_fck), CLK(NULL, "gpio1_dbck", &gpio1_dbck), CLK(NULL, "sha12_ick", &sha12_ick), CLK(NULL, "wdt2_fck", &wdt2_fck), CLK(NULL, "wkup_l4_ick", &wkup_l4_ick), CLK("omap_wdt", "ick", &wdt2_ick), CLK(NULL, "wdt2_ick", &wdt2_ick), CLK(NULL, "wdt1_ick", &wdt1_ick), CLK(NULL, "gpio1_ick", &gpio1_ick), CLK(NULL, "omap_32ksync_ick", &omap_32ksync_ick), CLK(NULL, "gpt12_ick", &gpt12_ick), CLK(NULL, "gpt1_ick", &gpt1_ick), CLK(NULL, "per_96m_fck", &per_96m_fck), CLK(NULL, "per_48m_fck", &per_48m_fck), CLK(NULL, "uart3_fck", &uart3_fck), CLK(NULL, "gpt2_fck", &gpt2_fck), CLK(NULL, "gpt3_fck", &gpt3_fck), CLK(NULL, "gpt4_fck", &gpt4_fck), CLK(NULL, "gpt5_fck", &gpt5_fck), CLK(NULL, "gpt6_fck", &gpt6_fck), CLK(NULL, "gpt7_fck", &gpt7_fck), CLK(NULL, "gpt8_fck", &gpt8_fck), CLK(NULL, "gpt9_fck", &gpt9_fck), CLK(NULL, "per_32k_alwon_fck", &per_32k_alwon_fck), CLK(NULL, "gpio6_dbck", &gpio6_dbck), CLK(NULL, "gpio5_dbck", &gpio5_dbck), CLK(NULL, "gpio4_dbck", &gpio4_dbck), CLK(NULL, "gpio3_dbck", &gpio3_dbck), CLK(NULL, "gpio2_dbck", &gpio2_dbck), CLK(NULL, "wdt3_fck", &wdt3_fck), CLK(NULL, "per_l4_ick", &per_l4_ick), CLK(NULL, "gpio6_ick", &gpio6_ick), CLK(NULL, "gpio5_ick", &gpio5_ick), CLK(NULL, "gpio4_ick", &gpio4_ick), CLK(NULL, "gpio3_ick", &gpio3_ick), CLK(NULL, "gpio2_ick", &gpio2_ick), CLK(NULL, "wdt3_ick", &wdt3_ick), CLK(NULL, "uart3_ick", &uart3_ick), CLK(NULL, "uart4_ick", &uart4_ick), CLK(NULL, "gpt9_ick", &gpt9_ick), CLK(NULL, "gpt8_ick", &gpt8_ick), CLK(NULL, "gpt7_ick", &gpt7_ick), CLK(NULL, "gpt6_ick", &gpt6_ick), CLK(NULL, "gpt5_ick", &gpt5_ick), CLK(NULL, "gpt4_ick", &gpt4_ick), CLK(NULL, "gpt3_ick", &gpt3_ick), CLK(NULL, "gpt2_ick", &gpt2_ick), CLK(NULL, "mcbsp_clks", &mcbsp_clks), CLK("omap-mcbsp.1", "ick", &mcbsp1_ick), CLK("omap-mcbsp.2", "ick", &mcbsp2_ick), CLK("omap-mcbsp.3", "ick", &mcbsp3_ick), CLK("omap-mcbsp.4", "ick", &mcbsp4_ick), CLK("omap-mcbsp.5", "ick", &mcbsp5_ick), CLK(NULL, "mcbsp1_ick", &mcbsp1_ick), CLK(NULL, "mcbsp2_ick", &mcbsp2_ick), CLK(NULL, "mcbsp3_ick", &mcbsp3_ick), CLK(NULL, "mcbsp4_ick", &mcbsp4_ick), CLK(NULL, "mcbsp5_ick", &mcbsp5_ick), CLK(NULL, "mcbsp1_fck", &mcbsp1_fck), CLK(NULL, "mcbsp2_fck", &mcbsp2_fck), CLK(NULL, "mcbsp3_fck", &mcbsp3_fck), CLK(NULL, "mcbsp4_fck", &mcbsp4_fck), CLK(NULL, "mcbsp5_fck", &mcbsp5_fck), CLK(NULL, "emu_src_mux_ck", &emu_src_mux_ck), CLK("etb", "emu_src_ck", &emu_src_ck), CLK(NULL, "emu_src_mux_ck", &emu_src_mux_ck), CLK(NULL, "emu_src_ck", &emu_src_ck), CLK(NULL, "pclk_fck", &pclk_fck), CLK(NULL, "pclkx2_fck", &pclkx2_fck), CLK(NULL, "atclk_fck", &atclk_fck), CLK(NULL, "traceclk_src_fck", &traceclk_src_fck), CLK(NULL, "traceclk_fck", &traceclk_fck), CLK(NULL, "secure_32k_fck", &secure_32k_fck), CLK(NULL, "gpt12_fck", &gpt12_fck), CLK(NULL, "wdt1_fck", &wdt1_fck), { NULL }, }; static struct ti_clk_alias omap36xx_am35xx_omap3430es2plus_clks[] = { CLK(NULL, "dpll5_ck", &dpll5_ck), CLK(NULL, "dpll5_m2_ck", &dpll5_m2_ck), CLK(NULL, "core_d3_ck", &core_d3_ck), CLK(NULL, "core_d4_ck", &core_d4_ck), CLK(NULL, "core_d6_ck", &core_d6_ck), CLK(NULL, "omap_192m_alwon_fck", &omap_192m_alwon_fck), CLK(NULL, "core_d2_ck", &core_d2_ck), CLK(NULL, "corex2_d3_fck", &corex2_d3_fck), CLK(NULL, "corex2_d5_fck", &corex2_d5_fck), CLK(NULL, "sgx_fck", &sgx_fck), CLK(NULL, "sgx_ick", &sgx_ick), CLK(NULL, "cpefuse_fck", &cpefuse_fck), CLK(NULL, "ts_fck", &ts_fck), CLK(NULL, "usbtll_fck", &usbtll_fck), CLK(NULL, "usbtll_ick", &usbtll_ick), CLK("omap_hsmmc.2", "ick", &mmchs3_ick), CLK(NULL, "mmchs3_ick", &mmchs3_ick), CLK(NULL, "mmchs3_fck", &mmchs3_fck), CLK(NULL, "dss1_alwon_fck", &dss1_alwon_fck_3430es2), CLK("omapdss_dss", "ick", &dss_ick_3430es2), CLK(NULL, "dss_ick", &dss_ick_3430es2), CLK(NULL, "usbhost_120m_fck", &usbhost_120m_fck), CLK(NULL, "usbhost_48m_fck", &usbhost_48m_fck), CLK(NULL, "usbhost_ick", &usbhost_ick), { NULL }, }; static struct ti_clk_alias omap3430es1_clks[] = { CLK(NULL, "gfx_l3_ck", &gfx_l3_ck), CLK(NULL, "gfx_l3_fck", &gfx_l3_fck), CLK(NULL, "gfx_l3_ick", &gfx_l3_ick), CLK(NULL, "gfx_cg1_ck", &gfx_cg1_ck), CLK(NULL, "gfx_cg2_ck", &gfx_cg2_ck), CLK(NULL, "d2d_26m_fck", &d2d_26m_fck), CLK(NULL, "fshostusb_fck", &fshostusb_fck), CLK(NULL, "ssi_ssr_fck", &ssi_ssr_fck_3430es1), CLK(NULL, "ssi_sst_fck", &ssi_sst_fck_3430es1), CLK("musb-omap2430", "ick", &hsotgusb_ick_3430es1), CLK(NULL, "hsotgusb_ick", &hsotgusb_ick_3430es1), CLK(NULL, "fac_ick", &fac_ick), CLK(NULL, "ssi_ick", &ssi_ick_3430es1), CLK(NULL, "usb_l4_ick", &usb_l4_ick), CLK(NULL, "dss1_alwon_fck", &dss1_alwon_fck_3430es1), CLK("omapdss_dss", "ick", &dss_ick_3430es1), CLK(NULL, "dss_ick", &dss_ick_3430es1), { NULL }, }; static struct ti_clk_alias omap36xx_clks[] = { CLK(NULL, "uart4_fck", &uart4_fck), { NULL }, }; static struct ti_clk_alias am35xx_clks[] = { CLK(NULL, "ipss_ick", &ipss_ick), CLK(NULL, "rmii_ck", &rmii_ck), CLK(NULL, "pclk_ck", &pclk_ck), CLK(NULL, "emac_ick", &emac_ick), CLK(NULL, "emac_fck", &emac_fck), CLK("davinci_emac.0", NULL, &emac_ick), CLK("davinci_mdio.0", NULL, &emac_fck), CLK("vpfe-capture", "master", &vpfe_ick), CLK("vpfe-capture", "slave", &vpfe_fck), CLK(NULL, "hsotgusb_ick", &hsotgusb_ick_am35xx), CLK(NULL, "hsotgusb_fck", &hsotgusb_fck_am35xx), CLK(NULL, "hecc_ck", &hecc_ck), CLK(NULL, "uart4_ick", &uart4_ick_am35xx), CLK(NULL, "uart4_fck", &uart4_fck_am35xx), { NULL }, }; static struct ti_clk *omap36xx_clk_patches[] = { &dpll4_m3x2_ck_omap36xx, &dpll3_m3x2_ck_omap36xx, &dpll4_m6x2_ck_omap36xx, &dpll4_m2x2_ck_omap36xx, &dpll4_m5x2_ck_omap36xx, &dpll4_ck_omap36xx, NULL, }; static const char *enable_init_clks[] = { "sdrc_ick", "gpmc_fck", "omapctrl_ick", }; static void __init omap3_clk_legacy_common_init(void) { omap2_clk_disable_autoidle_all(); omap2_clk_enable_init_clocks(enable_init_clks, ARRAY_SIZE(enable_init_clks)); pr_info("Clocking rate (Crystal/Core/MPU): %ld.%01ld/%ld/%ld MHz\n", (clk_get_rate(osc_sys_ck.clk) / 1000000), (clk_get_rate(osc_sys_ck.clk) / 100000) % 10, (clk_get_rate(core_ck.clk) / 1000000), (clk_get_rate(arm_fck.clk) / 1000000)); } int __init omap3430es1_clk_legacy_init(void) { int r; r = ti_clk_register_legacy_clks(omap3430es1_clks); r |= ti_clk_register_legacy_clks(omap34xx_omap36xx_clks); r |= ti_clk_register_legacy_clks(omap3xxx_clks); omap3_clk_legacy_common_init(); return r; } int __init omap3430_clk_legacy_init(void) { int r; r = ti_clk_register_legacy_clks(omap34xx_omap36xx_clks); r |= ti_clk_register_legacy_clks(omap36xx_omap3430es2plus_clks); r |= ti_clk_register_legacy_clks(omap36xx_am35xx_omap3430es2plus_clks); r |= ti_clk_register_legacy_clks(omap3xxx_clks); omap3_clk_legacy_common_init(); omap3_clk_lock_dpll5(); return r; } int __init omap36xx_clk_legacy_init(void) { int r; ti_clk_patch_legacy_clks(omap36xx_clk_patches); r = ti_clk_register_legacy_clks(omap36xx_clks); r |= ti_clk_register_legacy_clks(omap36xx_omap3430es2plus_clks); r |= ti_clk_register_legacy_clks(omap34xx_omap36xx_clks); r |= ti_clk_register_legacy_clks(omap36xx_am35xx_omap3430es2plus_clks); r |= ti_clk_register_legacy_clks(omap3xxx_clks); omap3_clk_legacy_common_init(); omap3_clk_lock_dpll5(); return r; } int __init am35xx_clk_legacy_init(void) { int r; r = ti_clk_register_legacy_clks(am35xx_clks); r |= ti_clk_register_legacy_clks(omap36xx_am35xx_omap3430es2plus_clks); r |= ti_clk_register_legacy_clks(omap3xxx_clks); omap3_clk_legacy_common_init(); omap3_clk_lock_dpll5(); return r; }