ARM: shmobile: r8a7790: add div4 clocks
DIV4 clocks control SD* core clocks. Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
This commit is contained in:
parent
8d100c0454
commit
9f13ee6f83
|
@ -51,6 +51,7 @@
|
||||||
#define SMSTPCR7 0xe615014c
|
#define SMSTPCR7 0xe615014c
|
||||||
|
|
||||||
#define MODEMR 0xE6160060
|
#define MODEMR 0xE6160060
|
||||||
|
#define SDCKCR 0xE6150074
|
||||||
|
|
||||||
static struct clk_mapping cpg_mapping = {
|
static struct clk_mapping cpg_mapping = {
|
||||||
.phys = CPG_BASE,
|
.phys = CPG_BASE,
|
||||||
|
@ -131,6 +132,29 @@ static struct clk *main_clks[] = {
|
||||||
&cp_clk,
|
&cp_clk,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* SDHI (DIV4) clock */
|
||||||
|
static int divisors[] = { 2, 3, 4, 6, 8, 12, 16, 18, 24, 0, 36, 48, 10 };
|
||||||
|
|
||||||
|
static struct clk_div_mult_table div4_div_mult_table = {
|
||||||
|
.divisors = divisors,
|
||||||
|
.nr_divisors = ARRAY_SIZE(divisors),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct clk_div4_table div4_table = {
|
||||||
|
.div_mult_table = &div4_div_mult_table,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
DIV4_SDH, DIV4_SD0, DIV4_SD1, DIV4_NR
|
||||||
|
};
|
||||||
|
|
||||||
|
struct clk div4_clks[DIV4_NR] = {
|
||||||
|
[DIV4_SDH] = SH_CLK_DIV4(&pll1_clk, SDCKCR, 8, 0x0dff, CLK_ENABLE_ON_INIT),
|
||||||
|
[DIV4_SD0] = SH_CLK_DIV4(&pll1_clk, SDCKCR, 4, 0x1de0, CLK_ENABLE_ON_INIT),
|
||||||
|
[DIV4_SD1] = SH_CLK_DIV4(&pll1_clk, SDCKCR, 0, 0x1de0, CLK_ENABLE_ON_INIT),
|
||||||
|
};
|
||||||
|
|
||||||
|
/* MSTP */
|
||||||
enum { MSTP721, MSTP720,
|
enum { MSTP721, MSTP720,
|
||||||
MSTP216, MSTP207, MSTP206, MSTP204, MSTP203, MSTP202, MSTP_NR };
|
MSTP216, MSTP207, MSTP206, MSTP204, MSTP203, MSTP202, MSTP_NR };
|
||||||
static struct clk mstp_clks[MSTP_NR] = {
|
static struct clk mstp_clks[MSTP_NR] = {
|
||||||
|
@ -173,6 +197,11 @@ static struct clk_lookup lookups[] = {
|
||||||
CLKDEV_CON_ID("qspi", &qspi_clk),
|
CLKDEV_CON_ID("qspi", &qspi_clk),
|
||||||
CLKDEV_CON_ID("cp", &cp_clk),
|
CLKDEV_CON_ID("cp", &cp_clk),
|
||||||
|
|
||||||
|
/* DIV4 */
|
||||||
|
CLKDEV_CON_ID("sdh", &div4_clks[DIV4_SDH]),
|
||||||
|
CLKDEV_CON_ID("sd0", &div4_clks[DIV4_SD0]),
|
||||||
|
CLKDEV_CON_ID("sd1", &div4_clks[DIV4_SD1]),
|
||||||
|
|
||||||
/* MSTP */
|
/* MSTP */
|
||||||
CLKDEV_DEV_ID("sh-sci.0", &mstp_clks[MSTP204]),
|
CLKDEV_DEV_ID("sh-sci.0", &mstp_clks[MSTP204]),
|
||||||
CLKDEV_DEV_ID("sh-sci.1", &mstp_clks[MSTP203]),
|
CLKDEV_DEV_ID("sh-sci.1", &mstp_clks[MSTP203]),
|
||||||
|
@ -232,6 +261,9 @@ void __init r8a7790_clock_init(void)
|
||||||
for (k = 0; !ret && (k < ARRAY_SIZE(main_clks)); k++)
|
for (k = 0; !ret && (k < ARRAY_SIZE(main_clks)); k++)
|
||||||
ret = clk_register(main_clks[k]);
|
ret = clk_register(main_clks[k]);
|
||||||
|
|
||||||
|
if (!ret)
|
||||||
|
ret = sh_clk_div4_register(div4_clks, DIV4_NR, &div4_table);
|
||||||
|
|
||||||
if (!ret)
|
if (!ret)
|
||||||
ret = sh_clk_mstp_register(mstp_clks, MSTP_NR);
|
ret = sh_clk_mstp_register(mstp_clks, MSTP_NR);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue