mirror of
https://github.com/Stichting-MINIX-Research-Foundation/u-boot.git
synced 2025-08-19 11:46:07 -04:00
EXYNOS5: CLOCK: Add BPLL support
This patch adds support for BPLL clock. Signed-off-by: Rajeshwari Shinde <rajeshwari.s@samsung.com> Acked-by: Joonyoung Shim <jy0922.shim@samsung.com> Signed-off-by: Minkyu Kang <mk7.kang@samsung.com>
This commit is contained in:
parent
6071bcaec1
commit
10bc1a7f49
@ -98,7 +98,7 @@ static unsigned long exynos5_get_pll_clk(int pllreg)
|
|||||||
struct exynos5_clock *clk =
|
struct exynos5_clock *clk =
|
||||||
(struct exynos5_clock *)samsung_get_base_clock();
|
(struct exynos5_clock *)samsung_get_base_clock();
|
||||||
unsigned long r, m, p, s, k = 0, mask, fout;
|
unsigned long r, m, p, s, k = 0, mask, fout;
|
||||||
unsigned int freq, pll_div2_sel, mpll_fout_sel;
|
unsigned int freq, pll_div2_sel, fout_sel;
|
||||||
|
|
||||||
switch (pllreg) {
|
switch (pllreg) {
|
||||||
case APLL:
|
case APLL:
|
||||||
@ -115,6 +115,9 @@ static unsigned long exynos5_get_pll_clk(int pllreg)
|
|||||||
r = readl(&clk->vpll_con0);
|
r = readl(&clk->vpll_con0);
|
||||||
k = readl(&clk->vpll_con1);
|
k = readl(&clk->vpll_con1);
|
||||||
break;
|
break;
|
||||||
|
case BPLL:
|
||||||
|
r = readl(&clk->bpll_con0);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
printf("Unsupported PLL (%d)\n", pllreg);
|
printf("Unsupported PLL (%d)\n", pllreg);
|
||||||
return 0;
|
return 0;
|
||||||
@ -125,8 +128,9 @@ static unsigned long exynos5_get_pll_clk(int pllreg)
|
|||||||
* MPLL_CON: MIDV [25:16]
|
* MPLL_CON: MIDV [25:16]
|
||||||
* EPLL_CON: MIDV [24:16]
|
* EPLL_CON: MIDV [24:16]
|
||||||
* VPLL_CON: MIDV [24:16]
|
* VPLL_CON: MIDV [24:16]
|
||||||
|
* BPLL_CON: MIDV [25:16]
|
||||||
*/
|
*/
|
||||||
if (pllreg == APLL || pllreg == MPLL)
|
if (pllreg == APLL || pllreg == MPLL || pllreg == BPLL)
|
||||||
mask = 0x3ff;
|
mask = 0x3ff;
|
||||||
else
|
else
|
||||||
mask = 0x1ff;
|
mask = 0x1ff;
|
||||||
@ -155,13 +159,23 @@ static unsigned long exynos5_get_pll_clk(int pllreg)
|
|||||||
fout = m * (freq / (p * (1 << (s - 1))));
|
fout = m * (freq / (p * (1 << (s - 1))));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* According to the user manual, in EVT1 MPLL always gives
|
/* According to the user manual, in EVT1 MPLL and BPLL always gives
|
||||||
* 1.6GHz clock, so divide by 2 to get 800MHz MPLL clock.*/
|
* 1.6GHz clock, so divide by 2 to get 800MHz MPLL clock.*/
|
||||||
if (pllreg == MPLL) {
|
if (pllreg == MPLL || pllreg == BPLL) {
|
||||||
pll_div2_sel = readl(&clk->pll_div2_sel);
|
pll_div2_sel = readl(&clk->pll_div2_sel);
|
||||||
mpll_fout_sel = (pll_div2_sel >> MPLL_FOUT_SEL_SHIFT)
|
|
||||||
& MPLL_FOUT_SEL_MASK;
|
switch (pllreg) {
|
||||||
if (mpll_fout_sel == 0)
|
case MPLL:
|
||||||
|
fout_sel = (pll_div2_sel >> MPLL_FOUT_SEL_SHIFT)
|
||||||
|
& MPLL_FOUT_SEL_MASK;
|
||||||
|
break;
|
||||||
|
case BPLL:
|
||||||
|
fout_sel = (pll_div2_sel >> BPLL_FOUT_SEL_SHIFT)
|
||||||
|
& BPLL_FOUT_SEL_MASK;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fout_sel == 0)
|
||||||
fout /= 2;
|
fout /= 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#define EPLL 2
|
#define EPLL 2
|
||||||
#define HPLL 3
|
#define HPLL 3
|
||||||
#define VPLL 4
|
#define VPLL 4
|
||||||
|
#define BPLL 5
|
||||||
|
|
||||||
unsigned long get_pll_clk(int pllreg);
|
unsigned long get_pll_clk(int pllreg);
|
||||||
unsigned long get_arm_clk(void);
|
unsigned long get_arm_clk(void);
|
||||||
|
@ -599,4 +599,6 @@ struct exynos5_clock {
|
|||||||
|
|
||||||
#define MPLL_FOUT_SEL_SHIFT 4
|
#define MPLL_FOUT_SEL_SHIFT 4
|
||||||
#define MPLL_FOUT_SEL_MASK 0x1
|
#define MPLL_FOUT_SEL_MASK 0x1
|
||||||
|
#define BPLL_FOUT_SEL_SHIFT 0
|
||||||
|
#define BPLL_FOUT_SEL_MASK 0x1
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user