1// SPDX-License-Identifier: GPL-2.0+ 2/* 3 * Exynos PLL helper functions for clock drivers. 4 * Copyright (C) 2016 Samsung Electronics 5 * Thomas Abraham <thomas.ab@samsung.com> 6 */ 7 8#include <common.h> 9#include <asm/io.h> 10#include <div64.h> 11 12#define PLL145X_MDIV_SHIFT 16 13#define PLL145X_MDIV_MASK 0x3ff 14#define PLL145X_PDIV_SHIFT 8 15#define PLL145X_PDIV_MASK 0x3f 16#define PLL145X_SDIV_SHIFT 0 17#define PLL145X_SDIV_MASK 0x7 18 19unsigned long pll145x_get_rate(unsigned int *con1, unsigned long fin_freq) 20{ 21 unsigned long pll_con1 = readl(con1); 22 unsigned long mdiv, sdiv, pdiv; 23 uint64_t fvco = fin_freq; 24 25 mdiv = (pll_con1 >> PLL145X_MDIV_SHIFT) & PLL145X_MDIV_MASK; 26 pdiv = (pll_con1 >> PLL145X_PDIV_SHIFT) & PLL145X_PDIV_MASK; 27 sdiv = (pll_con1 >> PLL145X_SDIV_SHIFT) & PLL145X_SDIV_MASK; 28 29 fvco *= mdiv; 30 do_div(fvco, (pdiv << sdiv)); 31 return (unsigned long)fvco; 32} 33