mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	ARM: imx: clk-vf610: introduce clks_init_on
At the end of the boot process, the clock framework might disable required main PLL's. So far, this was no issue since drivers requested clocks, which are descended of the main PLL's (e.g. pll1_pfd1, which provides the system clock). To archive the full 500MHz system clock, DDR clock need to be a descendant of PLL2 rather than PLL1 (DDRC_CLK_SEL set to 0). The bootloader sets up the clocks accordingly before making use of DDR at all. However, in Linux, there is no driver using PLL2, which lead to PLL2 being disabled by the clock framework. With this patch, we make sure that the main system clock and the DDR clock are initially enabled and are kept enabled. Signed-off-by: Stefan Agner <stefan@agner.ch> Signed-off-by: Shawn Guo <shawn.guo@freescale.com>
This commit is contained in:
		
							parent
							
								
									24980dc810
								
							
						
					
					
						commit
						3b18dd7a86
					
				
					 1 changed files with 9 additions and 0 deletions
				
			
		|  | @ -98,9 +98,15 @@ static struct clk_div_table pll4_main_div_table[] = { | ||||||
| static struct clk *clk[VF610_CLK_END]; | static struct clk *clk[VF610_CLK_END]; | ||||||
| static struct clk_onecell_data clk_data; | static struct clk_onecell_data clk_data; | ||||||
| 
 | 
 | ||||||
|  | static unsigned int const clks_init_on[] __initconst = { | ||||||
|  | 	VF610_CLK_SYS_BUS, | ||||||
|  | 	VF610_CLK_DDR_SEL, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| static void __init vf610_clocks_init(struct device_node *ccm_node) | static void __init vf610_clocks_init(struct device_node *ccm_node) | ||||||
| { | { | ||||||
| 	struct device_node *np; | 	struct device_node *np; | ||||||
|  | 	int i; | ||||||
| 
 | 
 | ||||||
| 	clk[VF610_CLK_DUMMY] = imx_clk_fixed("dummy", 0); | 	clk[VF610_CLK_DUMMY] = imx_clk_fixed("dummy", 0); | ||||||
| 	clk[VF610_CLK_SIRC_128K] = imx_clk_fixed("sirc_128k", 128000); | 	clk[VF610_CLK_SIRC_128K] = imx_clk_fixed("sirc_128k", 128000); | ||||||
|  | @ -322,6 +328,9 @@ static void __init vf610_clocks_init(struct device_node *ccm_node) | ||||||
| 	clk_set_parent(clk[VF610_CLK_SAI2_SEL], clk[VF610_CLK_AUDIO_EXT]); | 	clk_set_parent(clk[VF610_CLK_SAI2_SEL], clk[VF610_CLK_AUDIO_EXT]); | ||||||
| 	clk_set_parent(clk[VF610_CLK_SAI3_SEL], clk[VF610_CLK_AUDIO_EXT]); | 	clk_set_parent(clk[VF610_CLK_SAI3_SEL], clk[VF610_CLK_AUDIO_EXT]); | ||||||
| 
 | 
 | ||||||
|  | 	for (i = 0; i < ARRAY_SIZE(clks_init_on); i++) | ||||||
|  | 		clk_prepare_enable(clk[clks_init_on[i]]); | ||||||
|  | 
 | ||||||
| 	/* Add the clocks to provider list */ | 	/* Add the clocks to provider list */ | ||||||
| 	clk_data.clks = clk; | 	clk_data.clks = clk; | ||||||
| 	clk_data.clk_num = ARRAY_SIZE(clk); | 	clk_data.clk_num = ARRAY_SIZE(clk); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Stefan Agner
						Stefan Agner