mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-17 18:28:55 +00:00
34 lines
865 B
C
34 lines
865 B
C
|
/*
|
||
|
* Exynos PLL helper functions for clock drivers.
|
||
|
* Copyright (C) 2016 Samsung Electronics
|
||
|
* Thomas Abraham <thomas.ab@samsung.com>
|
||
|
*
|
||
|
* SPDX-License-Identifier: GPL-2.0+
|
||
|
*/
|
||
|
|
||
|
#include <common.h>
|
||
|
#include <asm/io.h>
|
||
|
#include <div64.h>
|
||
|
|
||
|
#define PLL145X_MDIV_SHIFT 16
|
||
|
#define PLL145X_MDIV_MASK 0x3ff
|
||
|
#define PLL145X_PDIV_SHIFT 8
|
||
|
#define PLL145X_PDIV_MASK 0x3f
|
||
|
#define PLL145X_SDIV_SHIFT 0
|
||
|
#define PLL145X_SDIV_MASK 0x7
|
||
|
|
||
|
unsigned long pll145x_get_rate(unsigned int *con1, unsigned long fin_freq)
|
||
|
{
|
||
|
unsigned long pll_con1 = readl(con1);
|
||
|
unsigned long mdiv, sdiv, pdiv;
|
||
|
uint64_t fvco = fin_freq;
|
||
|
|
||
|
mdiv = (pll_con1 >> PLL145X_MDIV_SHIFT) & PLL145X_MDIV_MASK;
|
||
|
pdiv = (pll_con1 >> PLL145X_PDIV_SHIFT) & PLL145X_PDIV_MASK;
|
||
|
sdiv = (pll_con1 >> PLL145X_SDIV_SHIFT) & PLL145X_SDIV_MASK;
|
||
|
|
||
|
fvco *= mdiv;
|
||
|
do_div(fvco, (pdiv << sdiv));
|
||
|
return (unsigned long)fvco;
|
||
|
}
|