mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-03-28 18:11:33 +00:00
arm: exynos: Add get_lcd_clk and set_lcd_clk callbacks for Exynos5420
Add get_lcd_clk and set_lcd_clk callbacks for Exynos5420 needed by exynos video driver. Also, configure ACLK_400_DISP1 as the parent for MUX_ACLK_400_DISP1_SUB_SEL. Signed-off-by: Ajay Kumar <ajaykumar.rs@samsung.com> Acked-by: Simon Glass <sjg@chromium.org> Tested-by: Simon Glass <sjg@chromium.org> Signed-off-by: Minkyu Kang <mk7.kang@samsung.com>
This commit is contained in:
parent
e6756f6a2e
commit
496f0e47e1
3 changed files with 80 additions and 6 deletions
|
@ -82,7 +82,8 @@ static int exynos_get_pll_clk(int pllreg, unsigned int r, unsigned int k)
|
||||||
* VPLL_CON: MIDV [24:16]
|
* VPLL_CON: MIDV [24:16]
|
||||||
* BPLL_CON: MIDV [25:16]: Exynos5
|
* BPLL_CON: MIDV [25:16]: Exynos5
|
||||||
*/
|
*/
|
||||||
if (pllreg == APLL || pllreg == MPLL || pllreg == BPLL)
|
if (pllreg == APLL || pllreg == MPLL || pllreg == BPLL ||
|
||||||
|
pllreg == SPLL)
|
||||||
mask = 0x3ff;
|
mask = 0x3ff;
|
||||||
else
|
else
|
||||||
mask = 0x1ff;
|
mask = 0x1ff;
|
||||||
|
@ -391,6 +392,9 @@ static unsigned long exynos5420_get_pll_clk(int pllreg)
|
||||||
r = readl(&clk->rpll_con0);
|
r = readl(&clk->rpll_con0);
|
||||||
k = readl(&clk->rpll_con1);
|
k = readl(&clk->rpll_con1);
|
||||||
break;
|
break;
|
||||||
|
case SPLL:
|
||||||
|
r = readl(&clk->spll_con0);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
printf("Unsupported PLL (%d)\n", pllreg);
|
printf("Unsupported PLL (%d)\n", pllreg);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1027,6 +1031,40 @@ static unsigned long exynos5_get_lcd_clk(void)
|
||||||
return pclk;
|
return pclk;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static unsigned long exynos5420_get_lcd_clk(void)
|
||||||
|
{
|
||||||
|
struct exynos5420_clock *clk =
|
||||||
|
(struct exynos5420_clock *)samsung_get_base_clock();
|
||||||
|
unsigned long pclk, sclk;
|
||||||
|
unsigned int sel;
|
||||||
|
unsigned int ratio;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CLK_SRC_DISP10
|
||||||
|
* FIMD1_SEL [4]
|
||||||
|
* 0: SCLK_RPLL
|
||||||
|
* 1: SCLK_SPLL
|
||||||
|
*/
|
||||||
|
sel = readl(&clk->src_disp10);
|
||||||
|
sel &= (1 << 4);
|
||||||
|
|
||||||
|
if (sel)
|
||||||
|
sclk = get_pll_clk(SPLL);
|
||||||
|
else
|
||||||
|
sclk = get_pll_clk(RPLL);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CLK_DIV_DISP10
|
||||||
|
* FIMD1_RATIO [3:0]
|
||||||
|
*/
|
||||||
|
ratio = readl(&clk->div_disp10);
|
||||||
|
ratio = ratio & 0xf;
|
||||||
|
|
||||||
|
pclk = sclk / (ratio + 1);
|
||||||
|
|
||||||
|
return pclk;
|
||||||
|
}
|
||||||
|
|
||||||
void exynos4_set_lcd_clk(void)
|
void exynos4_set_lcd_clk(void)
|
||||||
{
|
{
|
||||||
struct exynos4_clock *clk =
|
struct exynos4_clock *clk =
|
||||||
|
@ -1131,6 +1169,33 @@ void exynos5_set_lcd_clk(void)
|
||||||
clrsetbits_le32(&clk->div_disp1_0, 0xf, 0x0);
|
clrsetbits_le32(&clk->div_disp1_0, 0xf, 0x0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void exynos5420_set_lcd_clk(void)
|
||||||
|
{
|
||||||
|
struct exynos5420_clock *clk =
|
||||||
|
(struct exynos5420_clock *)samsung_get_base_clock();
|
||||||
|
unsigned int cfg;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CLK_SRC_DISP10
|
||||||
|
* FIMD1_SEL [4]
|
||||||
|
* 0: SCLK_RPLL
|
||||||
|
* 1: SCLK_SPLL
|
||||||
|
*/
|
||||||
|
cfg = readl(&clk->src_disp10);
|
||||||
|
cfg &= ~(0x1 << 4);
|
||||||
|
cfg |= (0 << 4);
|
||||||
|
writel(cfg, &clk->src_disp10);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CLK_DIV_DISP10
|
||||||
|
* FIMD1_RATIO [3:0]
|
||||||
|
*/
|
||||||
|
cfg = readl(&clk->div_disp10);
|
||||||
|
cfg &= ~(0xf << 0);
|
||||||
|
cfg |= (0 << 0);
|
||||||
|
writel(cfg, &clk->div_disp10);
|
||||||
|
}
|
||||||
|
|
||||||
void exynos4_set_mipi_clk(void)
|
void exynos4_set_mipi_clk(void)
|
||||||
{
|
{
|
||||||
struct exynos4_clock *clk =
|
struct exynos4_clock *clk =
|
||||||
|
@ -1602,16 +1667,24 @@ unsigned long get_lcd_clk(void)
|
||||||
{
|
{
|
||||||
if (cpu_is_exynos4())
|
if (cpu_is_exynos4())
|
||||||
return exynos4_get_lcd_clk();
|
return exynos4_get_lcd_clk();
|
||||||
|
else {
|
||||||
|
if (proid_is_exynos5420())
|
||||||
|
return exynos5420_get_lcd_clk();
|
||||||
else
|
else
|
||||||
return exynos5_get_lcd_clk();
|
return exynos5_get_lcd_clk();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void set_lcd_clk(void)
|
void set_lcd_clk(void)
|
||||||
{
|
{
|
||||||
if (cpu_is_exynos4())
|
if (cpu_is_exynos4())
|
||||||
exynos4_set_lcd_clk();
|
exynos4_set_lcd_clk();
|
||||||
else
|
else {
|
||||||
|
if (proid_is_exynos5250())
|
||||||
exynos5_set_lcd_clk();
|
exynos5_set_lcd_clk();
|
||||||
|
else if (proid_is_exynos5420())
|
||||||
|
exynos5420_set_lcd_clk();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_mipi_clk(void)
|
void set_mipi_clk(void)
|
||||||
|
|
|
@ -783,7 +783,7 @@
|
||||||
#define CLK_SRC_TOP2_VAL 0x11101000
|
#define CLK_SRC_TOP2_VAL 0x11101000
|
||||||
#define CLK_SRC_TOP3_VAL 0x11111111
|
#define CLK_SRC_TOP3_VAL 0x11111111
|
||||||
#define CLK_SRC_TOP4_VAL 0x11110111
|
#define CLK_SRC_TOP4_VAL 0x11110111
|
||||||
#define CLK_SRC_TOP5_VAL 0x11111100
|
#define CLK_SRC_TOP5_VAL 0x11111101
|
||||||
#define CLK_SRC_TOP6_VAL 0x11110111
|
#define CLK_SRC_TOP6_VAL 0x11110111
|
||||||
#define CLK_SRC_TOP7_VAL 0x00022200
|
#define CLK_SRC_TOP7_VAL 0x00022200
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#define VPLL 4
|
#define VPLL 4
|
||||||
#define BPLL 5
|
#define BPLL 5
|
||||||
#define RPLL 6
|
#define RPLL 6
|
||||||
|
#define SPLL 7
|
||||||
|
|
||||||
#define MASK_PRE_RATIO(x) (0xff << ((x << 4) + 8))
|
#define MASK_PRE_RATIO(x) (0xff << ((x << 4) + 8))
|
||||||
#define MASK_RATIO(x) (0xf << (x << 4))
|
#define MASK_RATIO(x) (0xf << (x << 4))
|
||||||
|
|
Loading…
Add table
Reference in a new issue