⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 clock-sh7785.c

📁 linux 内核源代码
💻 C
字号:
/* * arch/sh/kernel/cpu/sh4a/clock-sh7785.c * * SH7785 support for the clock framework * *  Copyright (C) 2007  Paul Mundt * * This file is subject to the terms and conditions of the GNU General Public * License.  See the file "COPYING" in the main directory of this archive * for more details. */#include <linux/init.h>#include <linux/kernel.h>#include <asm/clock.h>#include <asm/freq.h>#include <asm/io.h>static int ifc_divisors[] = { 1, 2, 4, 6 };static int ufc_divisors[] = { 1, 1, 4, 6 };static int sfc_divisors[] = { 1, 1, 4, 6 };static int bfc_divisors[] = { 1, 1, 1, 1, 1, 12, 16, 18,			     24, 32, 36, 48, 1, 1, 1, 1 };static int mfc_divisors[] = { 1, 1, 4, 6 };static int pfc_divisors[] = { 1, 1, 1, 1, 1, 1, 1, 18,			      24, 32, 36, 48, 1, 1, 1, 1 };static void master_clk_init(struct clk *clk){	clk->rate *= 36;}static struct clk_ops sh7785_master_clk_ops = {	.init		= master_clk_init,};static void module_clk_recalc(struct clk *clk){	int idx = (ctrl_inl(FRQMR1) & 0x000f);	clk->rate = clk->parent->rate / pfc_divisors[idx];}static struct clk_ops sh7785_module_clk_ops = {	.recalc		= module_clk_recalc,};static void bus_clk_recalc(struct clk *clk){	int idx = ((ctrl_inl(FRQMR1) >> 16) & 0x000f);	clk->rate = clk->parent->rate / bfc_divisors[idx];}static struct clk_ops sh7785_bus_clk_ops = {	.recalc		= bus_clk_recalc,};static void cpu_clk_recalc(struct clk *clk){	int idx = ((ctrl_inl(FRQMR1) >> 28) & 0x0003);	clk->rate = clk->parent->rate / ifc_divisors[idx];}static struct clk_ops sh7785_cpu_clk_ops = {	.recalc		= cpu_clk_recalc,};static struct clk_ops *sh7785_clk_ops[] = {	&sh7785_master_clk_ops,	&sh7785_module_clk_ops,	&sh7785_bus_clk_ops,	&sh7785_cpu_clk_ops,};void __init arch_init_clk_ops(struct clk_ops **ops, int idx){	if (idx < ARRAY_SIZE(sh7785_clk_ops))		*ops = sh7785_clk_ops[idx];}static void shyway_clk_recalc(struct clk *clk){	int idx = ((ctrl_inl(FRQMR1) >> 20) & 0x0003);	clk->rate = clk->parent->rate / sfc_divisors[idx];}static struct clk_ops sh7785_shyway_clk_ops = {	.recalc		= shyway_clk_recalc,};static struct clk sh7785_shyway_clk = {	.name		= "shyway_clk",	.flags		= CLK_ALWAYS_ENABLED,	.ops		= &sh7785_shyway_clk_ops,};static void ddr_clk_recalc(struct clk *clk){	int idx = ((ctrl_inl(FRQMR1) >> 12) & 0x0003);	clk->rate = clk->parent->rate / mfc_divisors[idx];}static struct clk_ops sh7785_ddr_clk_ops = {	.recalc		= ddr_clk_recalc,};static struct clk sh7785_ddr_clk = {	.name		= "ddr_clk",	.flags		= CLK_ALWAYS_ENABLED,	.ops		= &sh7785_ddr_clk_ops,};static void ram_clk_recalc(struct clk *clk){	int idx = ((ctrl_inl(FRQMR1) >> 24) & 0x0003);	clk->rate = clk->parent->rate / ufc_divisors[idx];}static struct clk_ops sh7785_ram_clk_ops = {	.recalc		= ram_clk_recalc,};static struct clk sh7785_ram_clk = {	.name		= "ram_clk",	.flags		= CLK_ALWAYS_ENABLED,	.ops		= &sh7785_ram_clk_ops,};/* * Additional SH7785-specific on-chip clocks that aren't already part of the * clock framework */static struct clk *sh7785_onchip_clocks[] = {	&sh7785_shyway_clk,	&sh7785_ddr_clk,	&sh7785_ram_clk,};static int __init sh7785_clk_init(void){	struct clk *clk = clk_get(NULL, "master_clk");	int i;	for (i = 0; i < ARRAY_SIZE(sh7785_onchip_clocks); i++) {		struct clk *clkp = sh7785_onchip_clocks[i];		clkp->parent = clk;		clk_register(clkp);		clk_enable(clkp);	}	/*	 * Now that we have the rest of the clocks registered, we need to	 * force the parent clock to propagate so that these clocks will	 * automatically figure out their rate. We cheat by handing the	 * parent clock its current rate and forcing child propagation.	 */	clk_set_rate(clk, clk_get_rate(clk));	clk_put(clk);	return 0;}arch_initcall(sh7785_clk_init);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -