2 * arch/sh/kernel/cpu/sh4/clock-sh7757.c
4 * SH7757 support for the clock framework
6 * Copyright (C) 2009-2010 Renesas Solutions Corp.
8 * This file is subject to the terms and conditions of the GNU General Public
9 * License. See the file "COPYING" in the main directory of this archive
12 #include <linux/init.h>
13 #include <linux/kernel.h>
15 #include <linux/clkdev.h>
16 #include <asm/clock.h>
20 * Default rate for the root input clock, reset this with clk_set_rate()
21 * from the platform code.
23 static struct clk extal_clk
= {
27 static unsigned long pll_recalc(struct clk
*clk
)
31 multiplier
= test_mode_pin(MODE_PIN0
) ? 24 : 16;
33 return clk
->parent
->rate
* multiplier
;
36 static struct clk_ops pll_clk_ops
= {
40 static struct clk pll_clk
= {
43 .flags
= CLK_ENABLE_ON_INIT
,
46 static struct clk
*clks
[] = {
51 static unsigned int div2
[] = { 1, 1, 2, 1, 1, 4, 1, 6,
52 1, 1, 1, 16, 1, 24, 1, 1 };
54 static struct clk_div_mult_table div4_div_mult_table
= {
56 .nr_divisors
= ARRAY_SIZE(div2
),
59 static struct clk_div4_table div4_table
= {
60 .div_mult_table
= &div4_div_mult_table
,
63 enum { DIV4_I
, DIV4_SH
, DIV4_P
, DIV4_NR
};
65 #define DIV4(_bit, _mask, _flags) \
66 SH_CLK_DIV4(&pll_clk, FRQCR, _bit, _mask, _flags)
68 struct clk div4_clks
[DIV4_NR
] = {
70 * P clock is always enable, because some P clock modules is used
73 [DIV4_P
] = DIV4(0, 0x2800, CLK_ENABLE_ON_INIT
),
74 [DIV4_SH
] = DIV4(12, 0x00a0, CLK_ENABLE_ON_INIT
),
75 [DIV4_I
] = DIV4(20, 0x0004, CLK_ENABLE_ON_INIT
),
78 #define MSTPCR0 0xffc80030
79 #define MSTPCR1 0xffc80034
80 #define MSTPCR2 0xffc10028
82 enum { MSTP004
, MSTP000
, MSTP114
, MSTP113
, MSTP112
,
83 MSTP111
, MSTP110
, MSTP103
, MSTP102
, MSTP220
,
86 static struct clk mstp_clks
[MSTP_NR
] = {
88 [MSTP004
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR0
, 4, 0),
89 [MSTP000
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR0
, 0, 0),
92 [MSTP114
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR1
, 14, 0),
93 [MSTP113
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR1
, 13, 0),
94 [MSTP112
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR1
, 12, 0),
95 [MSTP111
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR1
, 11, 0),
96 [MSTP110
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR1
, 10, 0),
97 [MSTP103
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR1
, 3, 0),
98 [MSTP102
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR1
, 2, 0),
101 [MSTP220
] = SH_CLK_MSTP32(&div4_clks
[DIV4_P
], MSTPCR2
, 20, 0),
104 #define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk }
106 static struct clk_lookup lookups
[] = {
108 CLKDEV_CON_ID("extal", &extal_clk
),
109 CLKDEV_CON_ID("pll_clk", &pll_clk
),
112 CLKDEV_CON_ID("peripheral_clk", &div4_clks
[DIV4_P
]),
113 CLKDEV_CON_ID("shyway_clk", &div4_clks
[DIV4_SH
]),
114 CLKDEV_CON_ID("cpu_clk", &div4_clks
[DIV4_I
]),
117 CLKDEV_CON_ID("sdhi0", &mstp_clks
[MSTP004
]),
118 CLKDEV_CON_ID("riic", &mstp_clks
[MSTP000
]),
121 .dev_id
= "sh_tmu.0",
123 .clk
= &mstp_clks
[MSTP113
],
126 .dev_id
= "sh_tmu.1",
128 .clk
= &mstp_clks
[MSTP114
],
131 /* SCIF4 (But, ID is 2) */
132 .dev_id
= "sh-sci.2",
134 .clk
= &mstp_clks
[MSTP112
],
137 .dev_id
= "sh-sci.1",
139 .clk
= &mstp_clks
[MSTP111
],
142 .dev_id
= "sh-sci.0",
144 .clk
= &mstp_clks
[MSTP110
],
146 CLKDEV_CON_ID("usb0", &mstp_clks
[MSTP102
]),
147 CLKDEV_CON_ID("mmc0", &mstp_clks
[MSTP220
]),
150 int __init
arch_clk_init(void)
154 for (i
= 0; i
< ARRAY_SIZE(clks
); i
++)
155 ret
|= clk_register(clks
[i
]);
156 for (i
= 0; i
< ARRAY_SIZE(lookups
); i
++)
157 clkdev_add(&lookups
[i
]);
160 ret
= sh_clk_div4_register(div4_clks
, ARRAY_SIZE(div4_clks
),
163 ret
= sh_clk_mstp32_register(mstp_clks
, MSTP_NR
);