162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Marvell Kirkwood SoC clocks 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2012 Marvell 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Gregory CLEMENT <gregory.clement@free-electrons.com> 862306a36Sopenharmony_ci * Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> 962306a36Sopenharmony_ci * Andrew Lunn <andrew@lunn.ch> 1062306a36Sopenharmony_ci * 1162306a36Sopenharmony_ci */ 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#include <linux/kernel.h> 1462306a36Sopenharmony_ci#include <linux/slab.h> 1562306a36Sopenharmony_ci#include <linux/clk-provider.h> 1662306a36Sopenharmony_ci#include <linux/io.h> 1762306a36Sopenharmony_ci#include <linux/of.h> 1862306a36Sopenharmony_ci#include <linux/of_address.h> 1962306a36Sopenharmony_ci#include "common.h" 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci/* 2262306a36Sopenharmony_ci * Core Clocks 2362306a36Sopenharmony_ci * 2462306a36Sopenharmony_ci * Kirkwood PLL sample-at-reset configuration 2562306a36Sopenharmony_ci * (6180 has different SAR layout than other Kirkwood SoCs) 2662306a36Sopenharmony_ci * 2762306a36Sopenharmony_ci * SAR0[4:3,22,1] : CPU frequency (6281,6292,6282) 2862306a36Sopenharmony_ci * 4 = 600 MHz 2962306a36Sopenharmony_ci * 6 = 800 MHz 3062306a36Sopenharmony_ci * 7 = 1000 MHz 3162306a36Sopenharmony_ci * 9 = 1200 MHz 3262306a36Sopenharmony_ci * 12 = 1500 MHz 3362306a36Sopenharmony_ci * 13 = 1600 MHz 3462306a36Sopenharmony_ci * 14 = 1800 MHz 3562306a36Sopenharmony_ci * 15 = 2000 MHz 3662306a36Sopenharmony_ci * others reserved. 3762306a36Sopenharmony_ci * 3862306a36Sopenharmony_ci * SAR0[19,10:9] : CPU to L2 Clock divider ratio (6281,6292,6282) 3962306a36Sopenharmony_ci * 1 = (1/2) * CPU 4062306a36Sopenharmony_ci * 3 = (1/3) * CPU 4162306a36Sopenharmony_ci * 5 = (1/4) * CPU 4262306a36Sopenharmony_ci * others reserved. 4362306a36Sopenharmony_ci * 4462306a36Sopenharmony_ci * SAR0[8:5] : CPU to DDR DRAM Clock divider ratio (6281,6292,6282) 4562306a36Sopenharmony_ci * 2 = (1/2) * CPU 4662306a36Sopenharmony_ci * 4 = (1/3) * CPU 4762306a36Sopenharmony_ci * 6 = (1/4) * CPU 4862306a36Sopenharmony_ci * 7 = (2/9) * CPU 4962306a36Sopenharmony_ci * 8 = (1/5) * CPU 5062306a36Sopenharmony_ci * 9 = (1/6) * CPU 5162306a36Sopenharmony_ci * others reserved. 5262306a36Sopenharmony_ci * 5362306a36Sopenharmony_ci * SAR0[4:2] : Kirkwood 6180 cpu/l2/ddr clock configuration (6180 only) 5462306a36Sopenharmony_ci * 5 = [CPU = 600 MHz, L2 = (1/2) * CPU, DDR = 200 MHz = (1/3) * CPU] 5562306a36Sopenharmony_ci * 6 = [CPU = 800 MHz, L2 = (1/2) * CPU, DDR = 200 MHz = (1/4) * CPU] 5662306a36Sopenharmony_ci * 7 = [CPU = 1000 MHz, L2 = (1/2) * CPU, DDR = 200 MHz = (1/5) * CPU] 5762306a36Sopenharmony_ci * others reserved. 5862306a36Sopenharmony_ci * 5962306a36Sopenharmony_ci * SAR0[21] : TCLK frequency 6062306a36Sopenharmony_ci * 0 = 200 MHz 6162306a36Sopenharmony_ci * 1 = 166 MHz 6262306a36Sopenharmony_ci * others reserved. 6362306a36Sopenharmony_ci */ 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci#define SAR_KIRKWOOD_CPU_FREQ(x) \ 6662306a36Sopenharmony_ci (((x & (1 << 1)) >> 1) | \ 6762306a36Sopenharmony_ci ((x & (1 << 22)) >> 21) | \ 6862306a36Sopenharmony_ci ((x & (3 << 3)) >> 1)) 6962306a36Sopenharmony_ci#define SAR_KIRKWOOD_L2_RATIO(x) \ 7062306a36Sopenharmony_ci (((x & (3 << 9)) >> 9) | \ 7162306a36Sopenharmony_ci (((x & (1 << 19)) >> 17))) 7262306a36Sopenharmony_ci#define SAR_KIRKWOOD_DDR_RATIO 5 7362306a36Sopenharmony_ci#define SAR_KIRKWOOD_DDR_RATIO_MASK 0xf 7462306a36Sopenharmony_ci#define SAR_MV88F6180_CLK 2 7562306a36Sopenharmony_ci#define SAR_MV88F6180_CLK_MASK 0x7 7662306a36Sopenharmony_ci#define SAR_KIRKWOOD_TCLK_FREQ 21 7762306a36Sopenharmony_ci#define SAR_KIRKWOOD_TCLK_FREQ_MASK 0x1 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_cienum { KIRKWOOD_CPU_TO_L2, KIRKWOOD_CPU_TO_DDR }; 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_cistatic const struct coreclk_ratio kirkwood_coreclk_ratios[] __initconst = { 8262306a36Sopenharmony_ci { .id = KIRKWOOD_CPU_TO_L2, .name = "l2clk", }, 8362306a36Sopenharmony_ci { .id = KIRKWOOD_CPU_TO_DDR, .name = "ddrclk", } 8462306a36Sopenharmony_ci}; 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_cistatic u32 __init kirkwood_get_tclk_freq(void __iomem *sar) 8762306a36Sopenharmony_ci{ 8862306a36Sopenharmony_ci u32 opt = (readl(sar) >> SAR_KIRKWOOD_TCLK_FREQ) & 8962306a36Sopenharmony_ci SAR_KIRKWOOD_TCLK_FREQ_MASK; 9062306a36Sopenharmony_ci return (opt) ? 166666667 : 200000000; 9162306a36Sopenharmony_ci} 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_cistatic const u32 kirkwood_cpu_freqs[] __initconst = { 9462306a36Sopenharmony_ci 0, 0, 0, 0, 9562306a36Sopenharmony_ci 600000000, 9662306a36Sopenharmony_ci 0, 9762306a36Sopenharmony_ci 800000000, 9862306a36Sopenharmony_ci 1000000000, 9962306a36Sopenharmony_ci 0, 10062306a36Sopenharmony_ci 1200000000, 10162306a36Sopenharmony_ci 0, 0, 10262306a36Sopenharmony_ci 1500000000, 10362306a36Sopenharmony_ci 1600000000, 10462306a36Sopenharmony_ci 1800000000, 10562306a36Sopenharmony_ci 2000000000 10662306a36Sopenharmony_ci}; 10762306a36Sopenharmony_ci 10862306a36Sopenharmony_cistatic u32 __init kirkwood_get_cpu_freq(void __iomem *sar) 10962306a36Sopenharmony_ci{ 11062306a36Sopenharmony_ci u32 opt = SAR_KIRKWOOD_CPU_FREQ(readl(sar)); 11162306a36Sopenharmony_ci return kirkwood_cpu_freqs[opt]; 11262306a36Sopenharmony_ci} 11362306a36Sopenharmony_ci 11462306a36Sopenharmony_cistatic const int kirkwood_cpu_l2_ratios[8][2] __initconst = { 11562306a36Sopenharmony_ci { 0, 1 }, { 1, 2 }, { 0, 1 }, { 1, 3 }, 11662306a36Sopenharmony_ci { 0, 1 }, { 1, 4 }, { 0, 1 }, { 0, 1 } 11762306a36Sopenharmony_ci}; 11862306a36Sopenharmony_ci 11962306a36Sopenharmony_cistatic const int kirkwood_cpu_ddr_ratios[16][2] __initconst = { 12062306a36Sopenharmony_ci { 0, 1 }, { 0, 1 }, { 1, 2 }, { 0, 1 }, 12162306a36Sopenharmony_ci { 1, 3 }, { 0, 1 }, { 1, 4 }, { 2, 9 }, 12262306a36Sopenharmony_ci { 1, 5 }, { 1, 6 }, { 0, 1 }, { 0, 1 }, 12362306a36Sopenharmony_ci { 0, 1 }, { 0, 1 }, { 0, 1 }, { 0, 1 } 12462306a36Sopenharmony_ci}; 12562306a36Sopenharmony_ci 12662306a36Sopenharmony_cistatic void __init kirkwood_get_clk_ratio( 12762306a36Sopenharmony_ci void __iomem *sar, int id, int *mult, int *div) 12862306a36Sopenharmony_ci{ 12962306a36Sopenharmony_ci switch (id) { 13062306a36Sopenharmony_ci case KIRKWOOD_CPU_TO_L2: 13162306a36Sopenharmony_ci { 13262306a36Sopenharmony_ci u32 opt = SAR_KIRKWOOD_L2_RATIO(readl(sar)); 13362306a36Sopenharmony_ci *mult = kirkwood_cpu_l2_ratios[opt][0]; 13462306a36Sopenharmony_ci *div = kirkwood_cpu_l2_ratios[opt][1]; 13562306a36Sopenharmony_ci break; 13662306a36Sopenharmony_ci } 13762306a36Sopenharmony_ci case KIRKWOOD_CPU_TO_DDR: 13862306a36Sopenharmony_ci { 13962306a36Sopenharmony_ci u32 opt = (readl(sar) >> SAR_KIRKWOOD_DDR_RATIO) & 14062306a36Sopenharmony_ci SAR_KIRKWOOD_DDR_RATIO_MASK; 14162306a36Sopenharmony_ci *mult = kirkwood_cpu_ddr_ratios[opt][0]; 14262306a36Sopenharmony_ci *div = kirkwood_cpu_ddr_ratios[opt][1]; 14362306a36Sopenharmony_ci break; 14462306a36Sopenharmony_ci } 14562306a36Sopenharmony_ci } 14662306a36Sopenharmony_ci} 14762306a36Sopenharmony_ci 14862306a36Sopenharmony_cistatic const u32 mv88f6180_cpu_freqs[] __initconst = { 14962306a36Sopenharmony_ci 0, 0, 0, 0, 0, 15062306a36Sopenharmony_ci 600000000, 15162306a36Sopenharmony_ci 800000000, 15262306a36Sopenharmony_ci 1000000000 15362306a36Sopenharmony_ci}; 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_cistatic u32 __init mv88f6180_get_cpu_freq(void __iomem *sar) 15662306a36Sopenharmony_ci{ 15762306a36Sopenharmony_ci u32 opt = (readl(sar) >> SAR_MV88F6180_CLK) & SAR_MV88F6180_CLK_MASK; 15862306a36Sopenharmony_ci return mv88f6180_cpu_freqs[opt]; 15962306a36Sopenharmony_ci} 16062306a36Sopenharmony_ci 16162306a36Sopenharmony_cistatic const int mv88f6180_cpu_ddr_ratios[8][2] __initconst = { 16262306a36Sopenharmony_ci { 0, 1 }, { 0, 1 }, { 0, 1 }, { 0, 1 }, 16362306a36Sopenharmony_ci { 0, 1 }, { 1, 3 }, { 1, 4 }, { 1, 5 } 16462306a36Sopenharmony_ci}; 16562306a36Sopenharmony_ci 16662306a36Sopenharmony_cistatic void __init mv88f6180_get_clk_ratio( 16762306a36Sopenharmony_ci void __iomem *sar, int id, int *mult, int *div) 16862306a36Sopenharmony_ci{ 16962306a36Sopenharmony_ci switch (id) { 17062306a36Sopenharmony_ci case KIRKWOOD_CPU_TO_L2: 17162306a36Sopenharmony_ci { 17262306a36Sopenharmony_ci /* mv88f6180 has a fixed 1:2 CPU-to-L2 ratio */ 17362306a36Sopenharmony_ci *mult = 1; 17462306a36Sopenharmony_ci *div = 2; 17562306a36Sopenharmony_ci break; 17662306a36Sopenharmony_ci } 17762306a36Sopenharmony_ci case KIRKWOOD_CPU_TO_DDR: 17862306a36Sopenharmony_ci { 17962306a36Sopenharmony_ci u32 opt = (readl(sar) >> SAR_MV88F6180_CLK) & 18062306a36Sopenharmony_ci SAR_MV88F6180_CLK_MASK; 18162306a36Sopenharmony_ci *mult = mv88f6180_cpu_ddr_ratios[opt][0]; 18262306a36Sopenharmony_ci *div = mv88f6180_cpu_ddr_ratios[opt][1]; 18362306a36Sopenharmony_ci break; 18462306a36Sopenharmony_ci } 18562306a36Sopenharmony_ci } 18662306a36Sopenharmony_ci} 18762306a36Sopenharmony_ci 18862306a36Sopenharmony_cistatic u32 __init mv98dx1135_get_tclk_freq(void __iomem *sar) 18962306a36Sopenharmony_ci{ 19062306a36Sopenharmony_ci return 166666667; 19162306a36Sopenharmony_ci} 19262306a36Sopenharmony_ci 19362306a36Sopenharmony_cistatic const struct coreclk_soc_desc kirkwood_coreclks = { 19462306a36Sopenharmony_ci .get_tclk_freq = kirkwood_get_tclk_freq, 19562306a36Sopenharmony_ci .get_cpu_freq = kirkwood_get_cpu_freq, 19662306a36Sopenharmony_ci .get_clk_ratio = kirkwood_get_clk_ratio, 19762306a36Sopenharmony_ci .ratios = kirkwood_coreclk_ratios, 19862306a36Sopenharmony_ci .num_ratios = ARRAY_SIZE(kirkwood_coreclk_ratios), 19962306a36Sopenharmony_ci}; 20062306a36Sopenharmony_ci 20162306a36Sopenharmony_cistatic const struct coreclk_soc_desc mv88f6180_coreclks = { 20262306a36Sopenharmony_ci .get_tclk_freq = kirkwood_get_tclk_freq, 20362306a36Sopenharmony_ci .get_cpu_freq = mv88f6180_get_cpu_freq, 20462306a36Sopenharmony_ci .get_clk_ratio = mv88f6180_get_clk_ratio, 20562306a36Sopenharmony_ci .ratios = kirkwood_coreclk_ratios, 20662306a36Sopenharmony_ci .num_ratios = ARRAY_SIZE(kirkwood_coreclk_ratios), 20762306a36Sopenharmony_ci}; 20862306a36Sopenharmony_ci 20962306a36Sopenharmony_cistatic const struct coreclk_soc_desc mv98dx1135_coreclks = { 21062306a36Sopenharmony_ci .get_tclk_freq = mv98dx1135_get_tclk_freq, 21162306a36Sopenharmony_ci .get_cpu_freq = kirkwood_get_cpu_freq, 21262306a36Sopenharmony_ci .get_clk_ratio = kirkwood_get_clk_ratio, 21362306a36Sopenharmony_ci .ratios = kirkwood_coreclk_ratios, 21462306a36Sopenharmony_ci .num_ratios = ARRAY_SIZE(kirkwood_coreclk_ratios), 21562306a36Sopenharmony_ci}; 21662306a36Sopenharmony_ci 21762306a36Sopenharmony_ci/* 21862306a36Sopenharmony_ci * Clock Gating Control 21962306a36Sopenharmony_ci */ 22062306a36Sopenharmony_ci 22162306a36Sopenharmony_cistatic const struct clk_gating_soc_desc kirkwood_gating_desc[] __initconst = { 22262306a36Sopenharmony_ci { "ge0", NULL, 0, 0 }, 22362306a36Sopenharmony_ci { "pex0", NULL, 2, 0 }, 22462306a36Sopenharmony_ci { "usb0", NULL, 3, 0 }, 22562306a36Sopenharmony_ci { "sdio", NULL, 4, 0 }, 22662306a36Sopenharmony_ci { "tsu", NULL, 5, 0 }, 22762306a36Sopenharmony_ci { "runit", NULL, 7, 0 }, 22862306a36Sopenharmony_ci { "xor0", NULL, 8, 0 }, 22962306a36Sopenharmony_ci { "audio", NULL, 9, 0 }, 23062306a36Sopenharmony_ci { "sata0", NULL, 14, 0 }, 23162306a36Sopenharmony_ci { "sata1", NULL, 15, 0 }, 23262306a36Sopenharmony_ci { "xor1", NULL, 16, 0 }, 23362306a36Sopenharmony_ci { "crypto", NULL, 17, 0 }, 23462306a36Sopenharmony_ci { "pex1", NULL, 18, 0 }, 23562306a36Sopenharmony_ci { "ge1", NULL, 19, 0 }, 23662306a36Sopenharmony_ci { "tdm", NULL, 20, 0 }, 23762306a36Sopenharmony_ci { } 23862306a36Sopenharmony_ci}; 23962306a36Sopenharmony_ci 24062306a36Sopenharmony_ci 24162306a36Sopenharmony_ci/* 24262306a36Sopenharmony_ci * Clock Muxing Control 24362306a36Sopenharmony_ci */ 24462306a36Sopenharmony_ci 24562306a36Sopenharmony_cistruct clk_muxing_soc_desc { 24662306a36Sopenharmony_ci const char *name; 24762306a36Sopenharmony_ci const char **parents; 24862306a36Sopenharmony_ci int num_parents; 24962306a36Sopenharmony_ci int shift; 25062306a36Sopenharmony_ci int width; 25162306a36Sopenharmony_ci unsigned long flags; 25262306a36Sopenharmony_ci}; 25362306a36Sopenharmony_ci 25462306a36Sopenharmony_cistruct clk_muxing_ctrl { 25562306a36Sopenharmony_ci spinlock_t *lock; 25662306a36Sopenharmony_ci struct clk **muxes; 25762306a36Sopenharmony_ci int num_muxes; 25862306a36Sopenharmony_ci}; 25962306a36Sopenharmony_ci 26062306a36Sopenharmony_cistatic const char *powersave_parents[] = { 26162306a36Sopenharmony_ci "cpuclk", 26262306a36Sopenharmony_ci "ddrclk", 26362306a36Sopenharmony_ci}; 26462306a36Sopenharmony_ci 26562306a36Sopenharmony_cistatic const struct clk_muxing_soc_desc kirkwood_mux_desc[] __initconst = { 26662306a36Sopenharmony_ci { "powersave", powersave_parents, ARRAY_SIZE(powersave_parents), 26762306a36Sopenharmony_ci 11, 1, 0 }, 26862306a36Sopenharmony_ci { } 26962306a36Sopenharmony_ci}; 27062306a36Sopenharmony_ci 27162306a36Sopenharmony_cistatic struct clk *clk_muxing_get_src( 27262306a36Sopenharmony_ci struct of_phandle_args *clkspec, void *data) 27362306a36Sopenharmony_ci{ 27462306a36Sopenharmony_ci struct clk_muxing_ctrl *ctrl = (struct clk_muxing_ctrl *)data; 27562306a36Sopenharmony_ci int n; 27662306a36Sopenharmony_ci 27762306a36Sopenharmony_ci if (clkspec->args_count < 1) 27862306a36Sopenharmony_ci return ERR_PTR(-EINVAL); 27962306a36Sopenharmony_ci 28062306a36Sopenharmony_ci for (n = 0; n < ctrl->num_muxes; n++) { 28162306a36Sopenharmony_ci struct clk_mux *mux = 28262306a36Sopenharmony_ci to_clk_mux(__clk_get_hw(ctrl->muxes[n])); 28362306a36Sopenharmony_ci if (clkspec->args[0] == mux->shift) 28462306a36Sopenharmony_ci return ctrl->muxes[n]; 28562306a36Sopenharmony_ci } 28662306a36Sopenharmony_ci return ERR_PTR(-ENODEV); 28762306a36Sopenharmony_ci} 28862306a36Sopenharmony_ci 28962306a36Sopenharmony_cistatic void __init kirkwood_clk_muxing_setup(struct device_node *np, 29062306a36Sopenharmony_ci const struct clk_muxing_soc_desc *desc) 29162306a36Sopenharmony_ci{ 29262306a36Sopenharmony_ci struct clk_muxing_ctrl *ctrl; 29362306a36Sopenharmony_ci void __iomem *base; 29462306a36Sopenharmony_ci int n; 29562306a36Sopenharmony_ci 29662306a36Sopenharmony_ci base = of_iomap(np, 0); 29762306a36Sopenharmony_ci if (WARN_ON(!base)) 29862306a36Sopenharmony_ci return; 29962306a36Sopenharmony_ci 30062306a36Sopenharmony_ci ctrl = kzalloc(sizeof(*ctrl), GFP_KERNEL); 30162306a36Sopenharmony_ci if (WARN_ON(!ctrl)) 30262306a36Sopenharmony_ci goto ctrl_out; 30362306a36Sopenharmony_ci 30462306a36Sopenharmony_ci /* lock must already be initialized */ 30562306a36Sopenharmony_ci ctrl->lock = &ctrl_gating_lock; 30662306a36Sopenharmony_ci 30762306a36Sopenharmony_ci /* Count, allocate, and register clock muxes */ 30862306a36Sopenharmony_ci for (n = 0; desc[n].name;) 30962306a36Sopenharmony_ci n++; 31062306a36Sopenharmony_ci 31162306a36Sopenharmony_ci ctrl->num_muxes = n; 31262306a36Sopenharmony_ci ctrl->muxes = kcalloc(ctrl->num_muxes, sizeof(struct clk *), 31362306a36Sopenharmony_ci GFP_KERNEL); 31462306a36Sopenharmony_ci if (WARN_ON(!ctrl->muxes)) 31562306a36Sopenharmony_ci goto muxes_out; 31662306a36Sopenharmony_ci 31762306a36Sopenharmony_ci for (n = 0; n < ctrl->num_muxes; n++) { 31862306a36Sopenharmony_ci ctrl->muxes[n] = clk_register_mux(NULL, desc[n].name, 31962306a36Sopenharmony_ci desc[n].parents, desc[n].num_parents, 32062306a36Sopenharmony_ci desc[n].flags, base, desc[n].shift, 32162306a36Sopenharmony_ci desc[n].width, desc[n].flags, ctrl->lock); 32262306a36Sopenharmony_ci WARN_ON(IS_ERR(ctrl->muxes[n])); 32362306a36Sopenharmony_ci } 32462306a36Sopenharmony_ci 32562306a36Sopenharmony_ci of_clk_add_provider(np, clk_muxing_get_src, ctrl); 32662306a36Sopenharmony_ci 32762306a36Sopenharmony_ci return; 32862306a36Sopenharmony_cimuxes_out: 32962306a36Sopenharmony_ci kfree(ctrl); 33062306a36Sopenharmony_cictrl_out: 33162306a36Sopenharmony_ci iounmap(base); 33262306a36Sopenharmony_ci} 33362306a36Sopenharmony_ci 33462306a36Sopenharmony_cistatic void __init kirkwood_clk_init(struct device_node *np) 33562306a36Sopenharmony_ci{ 33662306a36Sopenharmony_ci struct device_node *cgnp = 33762306a36Sopenharmony_ci of_find_compatible_node(NULL, NULL, "marvell,kirkwood-gating-clock"); 33862306a36Sopenharmony_ci 33962306a36Sopenharmony_ci 34062306a36Sopenharmony_ci if (of_device_is_compatible(np, "marvell,mv88f6180-core-clock")) 34162306a36Sopenharmony_ci mvebu_coreclk_setup(np, &mv88f6180_coreclks); 34262306a36Sopenharmony_ci else if (of_device_is_compatible(np, "marvell,mv98dx1135-core-clock")) 34362306a36Sopenharmony_ci mvebu_coreclk_setup(np, &mv98dx1135_coreclks); 34462306a36Sopenharmony_ci else 34562306a36Sopenharmony_ci mvebu_coreclk_setup(np, &kirkwood_coreclks); 34662306a36Sopenharmony_ci 34762306a36Sopenharmony_ci if (cgnp) { 34862306a36Sopenharmony_ci mvebu_clk_gating_setup(cgnp, kirkwood_gating_desc); 34962306a36Sopenharmony_ci kirkwood_clk_muxing_setup(cgnp, kirkwood_mux_desc); 35062306a36Sopenharmony_ci 35162306a36Sopenharmony_ci of_node_put(cgnp); 35262306a36Sopenharmony_ci } 35362306a36Sopenharmony_ci} 35462306a36Sopenharmony_ciCLK_OF_DECLARE(kirkwood_clk, "marvell,kirkwood-core-clock", 35562306a36Sopenharmony_ci kirkwood_clk_init); 35662306a36Sopenharmony_ciCLK_OF_DECLARE(mv88f6180_clk, "marvell,mv88f6180-core-clock", 35762306a36Sopenharmony_ci kirkwood_clk_init); 35862306a36Sopenharmony_ciCLK_OF_DECLARE(98dx1135_clk, "marvell,mv98dx1135-core-clock", 35962306a36Sopenharmony_ci kirkwood_clk_init); 360