2011-09-28 12:06:52 +00:00
|
|
|
/* linux/arch/arm/plat-samsung/include/plat/s5p-clock.h
|
2010-01-13 23:13:37 +00:00
|
|
|
*
|
2010-09-01 06:35:30 +00:00
|
|
|
* Copyright (c) 2009-2010 Samsung Electronics Co., Ltd.
|
|
|
|
* http://www.samsung.com
|
2010-01-13 23:13:37 +00:00
|
|
|
*
|
|
|
|
* Header file for s5p clock support
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __ASM_PLAT_S5P_CLOCK_H
|
|
|
|
#define __ASM_PLAT_S5P_CLOCK_H __FILE__
|
|
|
|
|
|
|
|
#include <linux/clk.h>
|
|
|
|
|
|
|
|
#define GET_DIV(clk, field) ((((clk) & field##_MASK) >> field##_SHIFT) + 1)
|
|
|
|
|
|
|
|
#define clk_fin_apll clk_ext_xtal_mux
|
2012-01-22 12:46:13 +00:00
|
|
|
#define clk_fin_bpll clk_ext_xtal_mux
|
|
|
|
#define clk_fin_cpll clk_ext_xtal_mux
|
2010-01-13 23:13:37 +00:00
|
|
|
#define clk_fin_mpll clk_ext_xtal_mux
|
|
|
|
#define clk_fin_epll clk_ext_xtal_mux
|
2010-09-01 06:35:30 +00:00
|
|
|
#define clk_fin_dpll clk_ext_xtal_mux
|
2010-02-24 07:40:36 +00:00
|
|
|
#define clk_fin_vpll clk_ext_xtal_mux
|
2010-05-14 07:27:28 +00:00
|
|
|
#define clk_fin_hpll clk_ext_xtal_mux
|
2010-01-13 23:13:37 +00:00
|
|
|
|
|
|
|
extern struct clk clk_ext_xtal_mux;
|
2010-04-19 11:05:08 +00:00
|
|
|
extern struct clk clk_xusbxti;
|
2010-01-13 23:13:37 +00:00
|
|
|
extern struct clk clk_48m;
|
2010-05-14 07:27:28 +00:00
|
|
|
extern struct clk s5p_clk_27m;
|
2010-01-13 23:13:37 +00:00
|
|
|
extern struct clk clk_fout_apll;
|
2012-01-22 12:46:13 +00:00
|
|
|
extern struct clk clk_fout_bpll;
|
2012-04-24 21:54:15 +00:00
|
|
|
extern struct clk clk_fout_bpll_div2;
|
2012-01-22 12:46:13 +00:00
|
|
|
extern struct clk clk_fout_cpll;
|
2010-01-13 23:13:37 +00:00
|
|
|
extern struct clk clk_fout_mpll;
|
2012-04-24 21:54:15 +00:00
|
|
|
extern struct clk clk_fout_mpll_div2;
|
2010-01-13 23:13:37 +00:00
|
|
|
extern struct clk clk_fout_epll;
|
2010-09-01 06:35:30 +00:00
|
|
|
extern struct clk clk_fout_dpll;
|
2010-05-17 00:38:52 +00:00
|
|
|
extern struct clk clk_fout_vpll;
|
2010-01-13 23:13:37 +00:00
|
|
|
extern struct clk clk_arm;
|
2010-02-24 07:40:36 +00:00
|
|
|
extern struct clk clk_vpll;
|
2010-01-13 23:13:37 +00:00
|
|
|
|
|
|
|
extern struct clksrc_sources clk_src_apll;
|
2012-01-22 12:46:13 +00:00
|
|
|
extern struct clksrc_sources clk_src_bpll;
|
2012-04-24 21:54:15 +00:00
|
|
|
extern struct clksrc_sources clk_src_bpll_fout;
|
2012-01-22 12:46:13 +00:00
|
|
|
extern struct clksrc_sources clk_src_cpll;
|
2010-01-13 23:13:37 +00:00
|
|
|
extern struct clksrc_sources clk_src_mpll;
|
2012-04-24 21:54:15 +00:00
|
|
|
extern struct clksrc_sources clk_src_mpll_fout;
|
2010-01-13 23:13:37 +00:00
|
|
|
extern struct clksrc_sources clk_src_epll;
|
2010-09-01 06:35:30 +00:00
|
|
|
extern struct clksrc_sources clk_src_dpll;
|
2010-01-13 23:13:37 +00:00
|
|
|
|
|
|
|
extern int s5p_gatectrl(void __iomem *reg, struct clk *clk, int enable);
|
|
|
|
|
2010-10-14 01:39:08 +00:00
|
|
|
/* Common EPLL operations for S5P platform */
|
|
|
|
extern int s5p_epll_enable(struct clk *clk, int enable);
|
|
|
|
extern unsigned long s5p_epll_get_rate(struct clk *clk);
|
|
|
|
|
2011-07-18 05:44:19 +00:00
|
|
|
/* SPDIF clk operations common for S5PC100/V210/C110 and Exynos4 */
|
|
|
|
extern int s5p_spdif_set_rate(struct clk *clk, unsigned long rate);
|
|
|
|
extern unsigned long s5p_spdif_get_rate(struct clk *clk);
|
|
|
|
|
|
|
|
extern struct clk_ops s5p_sclk_spdif_ops;
|
2010-01-13 23:13:37 +00:00
|
|
|
#endif /* __ASM_PLAT_S5P_CLOCK_H */
|