 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			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
				
			
		
			
				
	
	
		
			27 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From e9294823cf02068189a0e901223ed4991923c689 Mon Sep 17 00:00:00 2001
 | |
| From: Phil Elwell <phil@raspberrypi.com>
 | |
| Date: Wed, 31 Jul 2024 10:55:19 +0100
 | |
| Subject: [PATCH 1202/1215] spi: dw: Clamp the minimum clock speed
 | |
| 
 | |
| The DW SPI interface has a 16-bit clock divider, where the bottom bit
 | |
| of the divisor must be 0. Limit how low the clock speed can go to
 | |
| prevent the clock divider from being truncated, as that could lead to
 | |
| a much higher clock rate than requested.
 | |
| 
 | |
| Signed-off-by: Phil Elwell <phil@raspberrypi.com>
 | |
| ---
 | |
|  drivers/spi/spi-dw-core.c | 2 +-
 | |
|  1 file changed, 1 insertion(+), 1 deletion(-)
 | |
| 
 | |
| --- a/drivers/spi/spi-dw-core.c
 | |
| +++ b/drivers/spi/spi-dw-core.c
 | |
| @@ -397,7 +397,7 @@ void dw_spi_update_config(struct dw_spi
 | |
|  		dw_writel(dws, DW_SPI_CTRLR1, cfg->ndf ? cfg->ndf - 1 : 0);
 | |
|  
 | |
|  	/* Note DW APB SSI clock divider doesn't support odd numbers */
 | |
| -	clk_div = (DIV_ROUND_UP(dws->max_freq, cfg->freq) + 1) & 0xfffe;
 | |
| +	clk_div = min(DIV_ROUND_UP(dws->max_freq, cfg->freq) + 1, 0xfffe) & 0xfffe;
 | |
|  	speed_hz = dws->max_freq / clk_div;
 | |
|  
 | |
|  	if (dws->current_freq != speed_hz) {
 |