They will be reused by the ast2600 driver. Signed-off-by: Joel Stanley <joel@jms.id.au> Link: https://lkml.kernel.org/r/20190825141848.17346-2-joel@jms.id.au Signed-off-by: Stephen Boyd <sboyd@kernel.org>
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0-or-later */
 | |
| /*
 | |
|  * Structures used by ASPEED clock drivers
 | |
|  *
 | |
|  * Copyright 2019 IBM Corp.
 | |
|  */
 | |
| 
 | |
| #include <linux/clk-provider.h>
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/reset-controller.h>
 | |
| #include <linux/spinlock.h>
 | |
| 
 | |
| struct clk_div_table;
 | |
| struct regmap;
 | |
| 
 | |
| /**
 | |
|  * struct aspeed_gate_data - Aspeed gated clocks
 | |
|  * @clock_idx: bit used to gate this clock in the clock register
 | |
|  * @reset_idx: bit used to reset this IP in the reset register. -1 if no
 | |
|  *             reset is required when enabling the clock
 | |
|  * @name: the clock name
 | |
|  * @parent_name: the name of the parent clock
 | |
|  * @flags: standard clock framework flags
 | |
|  */
 | |
| struct aspeed_gate_data {
 | |
| 	u8		clock_idx;
 | |
| 	s8		reset_idx;
 | |
| 	const char	*name;
 | |
| 	const char	*parent_name;
 | |
| 	unsigned long	flags;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * struct aspeed_clk_gate - Aspeed specific clk_gate structure
 | |
|  * @hw:		handle between common and hardware-specific interfaces
 | |
|  * @reg:	register controlling gate
 | |
|  * @clock_idx:	bit used to gate this clock in the clock register
 | |
|  * @reset_idx:	bit used to reset this IP in the reset register. -1 if no
 | |
|  *		reset is required when enabling the clock
 | |
|  * @flags:	hardware-specific flags
 | |
|  * @lock:	register lock
 | |
|  *
 | |
|  * Some of the clocks in the Aspeed SoC must be put in reset before enabling.
 | |
|  * This modified version of clk_gate allows an optional reset bit to be
 | |
|  * specified.
 | |
|  */
 | |
| struct aspeed_clk_gate {
 | |
| 	struct clk_hw	hw;
 | |
| 	struct regmap	*map;
 | |
| 	u8		clock_idx;
 | |
| 	s8		reset_idx;
 | |
| 	u8		flags;
 | |
| 	spinlock_t	*lock;
 | |
| };
 | |
| 
 | |
| #define to_aspeed_clk_gate(_hw) container_of(_hw, struct aspeed_clk_gate, hw)
 | |
| 
 | |
| /**
 | |
|  * struct aspeed_reset - Aspeed reset controller
 | |
|  * @map: regmap to access the containing system controller
 | |
|  * @rcdev: reset controller device
 | |
|  */
 | |
| struct aspeed_reset {
 | |
| 	struct regmap			*map;
 | |
| 	struct reset_controller_dev	rcdev;
 | |
| };
 | |
| 
 | |
| #define to_aspeed_reset(p) container_of((p), struct aspeed_reset, rcdev)
 | |
| 
 | |
| /**
 | |
|  * struct aspeed_clk_soc_data - Aspeed SoC specific divisor information
 | |
|  * @div_table: Common divider lookup table
 | |
|  * @eclk_div_table: Divider lookup table for ECLK
 | |
|  * @mac_div_table: Divider lookup table for MAC (Ethernet) clocks
 | |
|  * @calc_pll: Callback to maculate common PLL settings
 | |
|  */
 | |
| struct aspeed_clk_soc_data {
 | |
| 	const struct clk_div_table *div_table;
 | |
| 	const struct clk_div_table *eclk_div_table;
 | |
| 	const struct clk_div_table *mac_div_table;
 | |
| 	struct clk_hw *(*calc_pll)(const char *name, u32 val);
 | |
| };
 |