mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 1221ae211f
			
		
	
	
		1221ae211f
		
	
	
	
	
		
			
			Add more data to 64bit SoCs for the cpufreq support. Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com> Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
		
			
				
	
	
		
			164 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			164 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2016 Socionext Inc.
 | |
|  *   Author: Masahiro Yamada <yamada.masahiro@socionext.com>
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation; either version 2 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  */
 | |
| 
 | |
| #ifndef __CLK_UNIPHIER_H__
 | |
| #define __CLK_UNIPHIER_H__
 | |
| 
 | |
| struct clk_hw;
 | |
| struct device;
 | |
| struct regmap;
 | |
| 
 | |
| #define UNIPHIER_CLK_CPUGEAR_MAX_PARENTS	16
 | |
| #define UNIPHIER_CLK_MUX_MAX_PARENTS		8
 | |
| 
 | |
| enum uniphier_clk_type {
 | |
| 	UNIPHIER_CLK_TYPE_CPUGEAR,
 | |
| 	UNIPHIER_CLK_TYPE_FIXED_FACTOR,
 | |
| 	UNIPHIER_CLK_TYPE_FIXED_RATE,
 | |
| 	UNIPHIER_CLK_TYPE_GATE,
 | |
| 	UNIPHIER_CLK_TYPE_MUX,
 | |
| };
 | |
| 
 | |
| struct uniphier_clk_cpugear_data {
 | |
| 	const char *parent_names[UNIPHIER_CLK_CPUGEAR_MAX_PARENTS];
 | |
| 	unsigned int num_parents;
 | |
| 	unsigned int regbase;
 | |
| 	unsigned int mask;
 | |
| };
 | |
| 
 | |
| struct uniphier_clk_fixed_factor_data {
 | |
| 	const char *parent_name;
 | |
| 	unsigned int mult;
 | |
| 	unsigned int div;
 | |
| };
 | |
| 
 | |
| struct uniphier_clk_fixed_rate_data {
 | |
| 	unsigned long fixed_rate;
 | |
| };
 | |
| 
 | |
| struct uniphier_clk_gate_data {
 | |
| 	const char *parent_name;
 | |
| 	unsigned int reg;
 | |
| 	unsigned int bit;
 | |
| };
 | |
| 
 | |
| struct uniphier_clk_mux_data {
 | |
| 	const char *parent_names[UNIPHIER_CLK_MUX_MAX_PARENTS];
 | |
| 	unsigned int num_parents;
 | |
| 	unsigned int reg;
 | |
| 	unsigned int masks[UNIPHIER_CLK_MUX_MAX_PARENTS];
 | |
| 	unsigned int vals[UNIPHIER_CLK_MUX_MAX_PARENTS];
 | |
| };
 | |
| 
 | |
| struct uniphier_clk_data {
 | |
| 	const char *name;
 | |
| 	enum uniphier_clk_type type;
 | |
| 	int idx;
 | |
| 	union {
 | |
| 		struct uniphier_clk_cpugear_data cpugear;
 | |
| 		struct uniphier_clk_fixed_factor_data factor;
 | |
| 		struct uniphier_clk_fixed_rate_data rate;
 | |
| 		struct uniphier_clk_gate_data gate;
 | |
| 		struct uniphier_clk_mux_data mux;
 | |
| 	} data;
 | |
| };
 | |
| 
 | |
| #define UNIPHIER_CLK_CPUGEAR(_name, _idx, _regbase, _mask,	\
 | |
| 			     _num_parents, ...)			\
 | |
| 	{							\
 | |
| 		.name = (_name),				\
 | |
| 		.type = UNIPHIER_CLK_TYPE_CPUGEAR,		\
 | |
| 		.idx = (_idx),					\
 | |
| 		.data.cpugear = {				\
 | |
| 			.parent_names = { __VA_ARGS__ },	\
 | |
| 			.num_parents = (_num_parents),		\
 | |
| 			.regbase = (_regbase),			\
 | |
| 			.mask = (_mask)				\
 | |
| 		 },						\
 | |
| 	}
 | |
| 
 | |
| #define UNIPHIER_CLK_FACTOR(_name, _idx, _parent, _mult, _div)	\
 | |
| 	{							\
 | |
| 		.name = (_name),				\
 | |
| 		.type = UNIPHIER_CLK_TYPE_FIXED_FACTOR,		\
 | |
| 		.idx = (_idx),					\
 | |
| 		.data.factor = {				\
 | |
| 			.parent_name = (_parent),		\
 | |
| 			.mult = (_mult),			\
 | |
| 			.div = (_div),				\
 | |
| 		},						\
 | |
| 	}
 | |
| 
 | |
| #define UNIPHIER_CLK_GATE(_name, _idx, _parent, _reg, _bit)	\
 | |
| 	{							\
 | |
| 		.name = (_name),				\
 | |
| 		.type = UNIPHIER_CLK_TYPE_GATE,			\
 | |
| 		.idx = (_idx),					\
 | |
| 		.data.gate = {					\
 | |
| 			.parent_name = (_parent),		\
 | |
| 			.reg = (_reg),				\
 | |
| 			.bit = (_bit),				\
 | |
| 		},						\
 | |
| 	}
 | |
| 
 | |
| #define UNIPHIER_CLK_DIV(parent, div)				\
 | |
| 	UNIPHIER_CLK_FACTOR(parent "/" #div, -1, parent, 1, div)
 | |
| 
 | |
| #define UNIPHIER_CLK_DIV2(parent, div0, div1)			\
 | |
| 	UNIPHIER_CLK_DIV(parent, div0),				\
 | |
| 	UNIPHIER_CLK_DIV(parent, div1)
 | |
| 
 | |
| #define UNIPHIER_CLK_DIV3(parent, div0, div1, div2)		\
 | |
| 	UNIPHIER_CLK_DIV2(parent, div0, div1),			\
 | |
| 	UNIPHIER_CLK_DIV(parent, div2)
 | |
| 
 | |
| #define UNIPHIER_CLK_DIV4(parent, div0, div1, div2, div3)	\
 | |
| 	UNIPHIER_CLK_DIV2(parent, div0, div1),			\
 | |
| 	UNIPHIER_CLK_DIV2(parent, div2, div3)
 | |
| 
 | |
| struct clk_hw *uniphier_clk_register_cpugear(struct device *dev,
 | |
| 					     struct regmap *regmap,
 | |
| 					     const char *name,
 | |
| 				const struct uniphier_clk_cpugear_data *data);
 | |
| struct clk_hw *uniphier_clk_register_fixed_factor(struct device *dev,
 | |
| 						  const char *name,
 | |
| 			const struct uniphier_clk_fixed_factor_data *data);
 | |
| struct clk_hw *uniphier_clk_register_fixed_rate(struct device *dev,
 | |
| 						const char *name,
 | |
| 			const struct uniphier_clk_fixed_rate_data *data);
 | |
| struct clk_hw *uniphier_clk_register_gate(struct device *dev,
 | |
| 					  struct regmap *regmap,
 | |
| 					  const char *name,
 | |
| 				const struct uniphier_clk_gate_data *data);
 | |
| struct clk_hw *uniphier_clk_register_mux(struct device *dev,
 | |
| 					 struct regmap *regmap,
 | |
| 					 const char *name,
 | |
| 				const struct uniphier_clk_mux_data *data);
 | |
| 
 | |
| extern const struct uniphier_clk_data uniphier_sld3_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_ld4_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_pro4_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_sld8_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_pro5_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_pxs2_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_ld11_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_ld20_sys_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_sld3_mio_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_pro5_sd_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_ld4_peri_clk_data[];
 | |
| extern const struct uniphier_clk_data uniphier_pro4_peri_clk_data[];
 | |
| 
 | |
| #endif /* __CLK_UNIPHIER_H__ */
 |