/* * Clock framework definitions for SPEAr platform * * Copyright (C) 2012 ST Microelectronics * Viresh Kumar * * This file is licensed under the terms of the GNU General Public * License version 2. This program is licensed "as is" without any * warranty of any kind, whether express or implied. */ #ifndef __SPEAR_CLK_H #define __SPEAR_CLK_H #include #include #include /* VCO-PLL clk */ struct pll_rate_tbl { u8 mode; u16 m; u8 n; u8 p; }; struct clk_vco { struct clk_hw hw; void __iomem *mode_reg; void __iomem *cfg_reg; struct pll_rate_tbl *rtbl; u8 rtbl_cnt; spinlock_t *lock; }; struct clk_pll { struct clk_hw hw; struct clk_vco *vco; const char *parent[1]; spinlock_t *lock; }; typedef unsigned long (*clk_calc_rate)(struct clk_hw *hw, unsigned long prate, int index); /* clk register routines */ struct clk *clk_register_vco_pll(const char *vco_name, const char *pll_name, const char *vco_gate_name, const char *parent_name, unsigned long flags, void __iomem *mode_reg, void __iomem *cfg_reg, struct pll_rate_tbl *rtbl, u8 rtbl_cnt, spinlock_t *lock, struct clk **pll_clk, struct clk **vco_gate_clk); long clk_round_rate_index(struct clk_hw *hw, unsigned long drate, unsigned long parent_rate, clk_calc_rate calc_rate, u8 rtbl_cnt, int *index); #endif /* __SPEAR_CLK_H */