Initial commit
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			
		
			
				
	
				Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			
		
			
				
	
				Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			
		
			
				
	
				Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			
		
			
				
	
				Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			
		
			
				
	
				Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			This commit is contained in:
		| @@ -0,0 +1,118 @@ | ||||
| From a3e8abeba9c63145d98dfc1cf859a2a2796ea7c0 Mon Sep 17 00:00:00 2001 | ||||
| From: Phil Elwell <phil@raspberrypi.org> | ||||
| Date: Mon, 13 Feb 2017 17:20:08 +0000 | ||||
| Subject: [PATCH 0045/1085] clk-bcm2835: Add claim-clocks property | ||||
|  | ||||
| The claim-clocks property can be used to prevent PLLs and dividers | ||||
| from being marked as critical. It contains a vector of clock IDs, | ||||
| as defined by dt-bindings/clock/bcm2835.h. | ||||
|  | ||||
| Use this mechanism to claim PLLD_DSI0, PLLD_DSI1, PLLH_AUX and | ||||
| PLLH_PIX for the vc4_kms_v3d driver. | ||||
|  | ||||
| Signed-off-by: Phil Elwell <phil@raspberrypi.org> | ||||
| --- | ||||
|  drivers/clk/bcm/clk-bcm2835.c | 43 +++++++++++++++++++++++++++++++++-- | ||||
|  1 file changed, 41 insertions(+), 2 deletions(-) | ||||
|  | ||||
| --- a/drivers/clk/bcm/clk-bcm2835.c | ||||
| +++ b/drivers/clk/bcm/clk-bcm2835.c | ||||
| @@ -1335,6 +1335,8 @@ static const struct clk_ops bcm2835_vpu_ | ||||
|  	.debug_init = bcm2835_clock_debug_init, | ||||
|  }; | ||||
|   | ||||
| +static bool bcm2835_clk_is_claimed(const char *name); | ||||
| + | ||||
|  static struct clk_hw *bcm2835_register_pll(struct bcm2835_cprman *cprman, | ||||
|  					   const void *data) | ||||
|  { | ||||
| @@ -1352,6 +1354,9 @@ static struct clk_hw *bcm2835_register_p | ||||
|  	init.ops = &bcm2835_pll_clk_ops; | ||||
|  	init.flags = pll_data->flags | CLK_IGNORE_UNUSED; | ||||
|   | ||||
| +	if (!bcm2835_clk_is_claimed(pll_data->name)) | ||||
| +		init.flags |= CLK_IS_CRITICAL; | ||||
| + | ||||
|  	pll = kzalloc(sizeof(*pll), GFP_KERNEL); | ||||
|  	if (!pll) | ||||
|  		return NULL; | ||||
| @@ -1408,8 +1413,10 @@ bcm2835_register_pll_divider(struct bcm2 | ||||
|  	divider->div.table = NULL; | ||||
|   | ||||
|  	if (!(cprman_read(cprman, divider_data->cm_reg) & divider_data->hold_mask)) { | ||||
| -		init.flags |= CLK_IS_CRITICAL; | ||||
| -		divider->div.flags |= CLK_IS_CRITICAL; | ||||
| +		if (!bcm2835_clk_is_claimed(divider_data->source_pll)) | ||||
| +			init.flags |= CLK_IS_CRITICAL; | ||||
| +		if (!bcm2835_clk_is_claimed(divider_data->name)) | ||||
| +			divider->div.flags |= CLK_IS_CRITICAL; | ||||
|  	} | ||||
|   | ||||
|  	divider->cprman = cprman; | ||||
| @@ -1466,6 +1473,15 @@ static struct clk_hw *bcm2835_register_c | ||||
|  	init.flags = clock_data->flags | CLK_IGNORE_UNUSED; | ||||
|   | ||||
|  	/* | ||||
| +	 * Some GPIO clocks for ethernet/wifi PLLs are marked as | ||||
| +	 * critical (since some platforms use them), but if the | ||||
| +	 * firmware didn't have them turned on then they clearly | ||||
| +	 * aren't actually critical. | ||||
| +	 */ | ||||
| +	if ((cprman_read(cprman, clock_data->ctl_reg) & CM_ENABLE) == 0) | ||||
| +		init.flags &= ~CLK_IS_CRITICAL; | ||||
| + | ||||
| +	/* | ||||
|  	 * Pass the CLK_SET_RATE_PARENT flag if we are allowed to propagate | ||||
|  	 * rate changes on at least of the parents. | ||||
|  	 */ | ||||
| @@ -2245,6 +2261,8 @@ static const struct bcm2835_clk_desc clk | ||||
|  		.ctl_reg = CM_PERIICTL), | ||||
|  }; | ||||
|   | ||||
| +static bool bcm2835_clk_claimed[ARRAY_SIZE(clk_desc_array)]; | ||||
| + | ||||
|  /* | ||||
|   * Permanently take a reference on the parent of the SDRAM clock. | ||||
|   * | ||||
| @@ -2264,6 +2282,19 @@ static int bcm2835_mark_sdc_parent_criti | ||||
|  	return clk_prepare_enable(parent); | ||||
|  } | ||||
|   | ||||
| +static bool bcm2835_clk_is_claimed(const char *name) | ||||
| +{ | ||||
| +	int i; | ||||
| + | ||||
| +	for (i = 0; i < ARRAY_SIZE(clk_desc_array); i++) { | ||||
| +		const char *clk_name = *(const char **)(clk_desc_array[i].data); | ||||
| +		if (!strcmp(name, clk_name)) | ||||
| +		    return bcm2835_clk_claimed[i]; | ||||
| +	} | ||||
| + | ||||
| +	return false; | ||||
| +} | ||||
| + | ||||
|  static int bcm2835_clk_probe(struct platform_device *pdev) | ||||
|  { | ||||
|  	struct device *dev = &pdev->dev; | ||||
| @@ -2273,6 +2304,7 @@ static int bcm2835_clk_probe(struct plat | ||||
|  	const size_t asize = ARRAY_SIZE(clk_desc_array); | ||||
|  	const struct cprman_plat_data *pdata; | ||||
|  	size_t i; | ||||
| +	u32 clk_id; | ||||
|  	int ret; | ||||
|   | ||||
|  	pdata = of_device_get_match_data(&pdev->dev); | ||||
| @@ -2291,6 +2323,13 @@ static int bcm2835_clk_probe(struct plat | ||||
|  	if (IS_ERR(cprman->regs)) | ||||
|  		return PTR_ERR(cprman->regs); | ||||
|   | ||||
| +	memset(bcm2835_clk_claimed, 0, sizeof(bcm2835_clk_claimed)); | ||||
| +	for (i = 0; | ||||
| +	     !of_property_read_u32_index(pdev->dev.of_node, "claim-clocks", | ||||
| +					 i, &clk_id); | ||||
| +	     i++) | ||||
| +		bcm2835_clk_claimed[clk_id]= true; | ||||
| + | ||||
|  	memcpy(cprman->real_parent_names, cprman_parent_names, | ||||
|  	       sizeof(cprman_parent_names)); | ||||
|  	of_clk_parent_fill(dev->of_node, cprman->real_parent_names, | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico