mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-24 19:05:14 +00:00
5894ca007d
These are used by Panasonic UniPhier SoC family. Signed-off-by: Masahiro Yamada <yamada.m@jp.panasonic.com>
168 lines
3.7 KiB
C
168 lines
3.7 KiB
C
/*
|
|
* Copyright (C) 2011-2014 Panasonic Corporation
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <asm/io.h>
|
|
#include <asm/arch/sc-regs.h>
|
|
#include <asm/arch/sg-regs.h>
|
|
|
|
#undef DPLL_SSC_RATE_1PER
|
|
|
|
void dpll_init(void)
|
|
{
|
|
u32 tmp;
|
|
|
|
/*
|
|
* Set Frequency
|
|
* Set 0xc(1600MHz)/0xd(1333MHz)/0xe(1066MHz)
|
|
* to FOUT ( DPLLCTRL.bit[29:20] )
|
|
*/
|
|
tmp = readl(SC_DPLLCTRL);
|
|
tmp &= ~(0x000f0000);
|
|
#if CONFIG_DDR_FREQ == 1600
|
|
tmp |= 0x000c0000;
|
|
#elif CONFIG_DDR_FREQ == 1333
|
|
tmp |= 0x000d0000;
|
|
#else
|
|
# error "Unsupported frequency"
|
|
#endif
|
|
|
|
/*
|
|
* Set Moduration rate
|
|
* Set 0x0(1%)/0x1(2%) to SSC_RATE(DPLLCTRL.bit[15])
|
|
*/
|
|
#if defined(DPLL_SSC_RATE_1PER)
|
|
tmp &= ~0x00008000;
|
|
#else
|
|
tmp |= 0x00008000;
|
|
#endif
|
|
writel(tmp, SC_DPLLCTRL);
|
|
|
|
tmp = readl(SC_DPLLCTRL2);
|
|
tmp |= SC_DPLLCTRL2_NRSTDS;
|
|
writel(tmp, SC_DPLLCTRL2);
|
|
}
|
|
|
|
void stop_mpll(void)
|
|
{
|
|
u32 tmp;
|
|
|
|
tmp = readl(SC_MPLLOSCCTL);
|
|
|
|
if (!(tmp & SC_MPLLOSCCTL_MPLLST))
|
|
return; /* already stopped */
|
|
|
|
tmp &= ~SC_MPLLOSCCTL_MPLLEN;
|
|
writel(tmp, SC_MPLLOSCCTL);
|
|
|
|
while (readl(SC_MPLLOSCCTL) & SC_MPLLOSCCTL_MPLLST)
|
|
;
|
|
}
|
|
|
|
void vpll_init(void)
|
|
{
|
|
u32 tmp, clk_mode_axosel;
|
|
|
|
/* Set VPLL27A & VPLL27B */
|
|
tmp = readl(SG_PINMON0);
|
|
clk_mode_axosel = tmp & SG_PINMON0_CLK_MODE_AXOSEL_MASK;
|
|
|
|
#if defined(CONFIG_MACH_PH1_PRO4)
|
|
/* 25MHz or 6.25MHz is default for Pro4R, no need to set VPLLA/B */
|
|
if (clk_mode_axosel == SG_PINMON0_CLK_MODE_AXOSEL_25000KHZ ||
|
|
clk_mode_axosel == SG_PINMON0_CLK_MODE_AXOSEL_6250KHZ)
|
|
return;
|
|
#endif
|
|
|
|
/* Disable write protect of VPLL27ACTRL[2-7]*, VPLL27BCTRL[2-8] */
|
|
tmp = readl(SC_VPLL27ACTRL);
|
|
tmp |= 0x00000001;
|
|
writel(tmp, SC_VPLL27ACTRL);
|
|
tmp = readl(SC_VPLL27BCTRL);
|
|
tmp |= 0x00000001;
|
|
writel(tmp, SC_VPLL27BCTRL);
|
|
|
|
/* Unset VPLA_K_LD and VPLB_K_LD bit */
|
|
tmp = readl(SC_VPLL27ACTRL3);
|
|
tmp &= ~0x10000000;
|
|
writel(tmp, SC_VPLL27ACTRL3);
|
|
tmp = readl(SC_VPLL27BCTRL3);
|
|
tmp &= ~0x10000000;
|
|
writel(tmp, SC_VPLL27BCTRL3);
|
|
|
|
/* Set VPLA_M and VPLB_M to 0x20 */
|
|
tmp = readl(SC_VPLL27ACTRL2);
|
|
tmp &= ~0x0000007f;
|
|
tmp |= 0x00000020;
|
|
writel(tmp, SC_VPLL27ACTRL2);
|
|
tmp = readl(SC_VPLL27BCTRL2);
|
|
tmp &= ~0x0000007f;
|
|
tmp |= 0x00000020;
|
|
writel(tmp, SC_VPLL27BCTRL2);
|
|
|
|
if (clk_mode_axosel == SG_PINMON0_CLK_MODE_AXOSEL_25000KHZ ||
|
|
clk_mode_axosel == SG_PINMON0_CLK_MODE_AXOSEL_6250KHZ) {
|
|
/* Set VPLA_K and VPLB_K for AXO: 25MHz */
|
|
tmp = readl(SC_VPLL27ACTRL3);
|
|
tmp &= ~0x000fffff;
|
|
tmp |= 0x00066666;
|
|
writel(tmp, SC_VPLL27ACTRL3);
|
|
tmp = readl(SC_VPLL27BCTRL3);
|
|
tmp &= ~0x000fffff;
|
|
tmp |= 0x00066666;
|
|
writel(tmp, SC_VPLL27BCTRL3);
|
|
} else {
|
|
/* Set VPLA_K and VPLB_K for AXO: 24.576 MHz */
|
|
tmp = readl(SC_VPLL27ACTRL3);
|
|
tmp &= ~0x000fffff;
|
|
tmp |= 0x000f5800;
|
|
writel(tmp, SC_VPLL27ACTRL3);
|
|
tmp = readl(SC_VPLL27BCTRL3);
|
|
tmp &= ~0x000fffff;
|
|
tmp |= 0x000f5800;
|
|
writel(tmp, SC_VPLL27BCTRL3);
|
|
}
|
|
|
|
/* wait 1 usec */
|
|
udelay(1);
|
|
|
|
/* Set VPLA_K_LD and VPLB_K_LD to load K parameters */
|
|
tmp = readl(SC_VPLL27ACTRL3);
|
|
tmp |= 0x10000000;
|
|
writel(tmp, SC_VPLL27ACTRL3);
|
|
tmp = readl(SC_VPLL27BCTRL3);
|
|
tmp |= 0x10000000;
|
|
writel(tmp, SC_VPLL27BCTRL3);
|
|
|
|
/* Unset VPLA_SNRST and VPLB_SNRST bit */
|
|
tmp = readl(SC_VPLL27ACTRL2);
|
|
tmp |= 0x10000000;
|
|
writel(tmp, SC_VPLL27ACTRL2);
|
|
tmp = readl(SC_VPLL27BCTRL2);
|
|
tmp |= 0x10000000;
|
|
writel(tmp, SC_VPLL27BCTRL2);
|
|
|
|
/* Enable write protect of VPLL27ACTRL[2-7]*, VPLL27BCTRL[2-8] */
|
|
tmp = readl(SC_VPLL27ACTRL);
|
|
tmp &= ~0x00000001;
|
|
writel(tmp, SC_VPLL27ACTRL);
|
|
tmp = readl(SC_VPLL27BCTRL);
|
|
tmp &= ~0x00000001;
|
|
writel(tmp, SC_VPLL27BCTRL);
|
|
}
|
|
|
|
void pll_init(void)
|
|
{
|
|
dpll_init();
|
|
stop_mpll();
|
|
vpll_init();
|
|
|
|
/*
|
|
* Wait 500 usec until dpll get stable
|
|
* We wait 1 usec in vpll_init() so 1 usec can be saved here.
|
|
*/
|
|
udelay(499);
|
|
}
|