 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
				
			
		
			
				
	
	
		
			81 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From da11da943487e2f724f25d409bcaa1f099637c0b Mon Sep 17 00:00:00 2001
 | |
| From: Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
 | |
| Date: Sun, 13 Oct 2013 14:56:45 +0200
 | |
| Subject: sf: add slim probe funtions for SPL
 | |
| 
 | |
| Signed-off-by: Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
 | |
| 
 | |
| --- a/drivers/mtd/spi/sf_probe.c
 | |
| +++ b/drivers/mtd/spi/sf_probe.c
 | |
| @@ -365,3 +365,58 @@ void spi_flash_free(struct spi_flash *fl
 | |
|  	spi_free_slave(flash->spi);
 | |
|  	free(flash);
 | |
|  }
 | |
| +
 | |
| +#ifdef CONFIG_SPI_SPL_SIMPLE
 | |
| +int spl_spi_flash_probe(struct spi_flash *flash)
 | |
| +{
 | |
| +	struct spi_slave *spi;
 | |
| +	u8 idcode[5];
 | |
| +	int ret;
 | |
| +
 | |
| +	/* Setup spi_slave */
 | |
| +	spi = spi_setup_slave(CONFIG_SPL_SPI_BUS, CONFIG_SPL_SPI_CS,
 | |
| +		CONFIG_SPL_SPI_MAX_HZ, CONFIG_SPL_SPI_MODE);
 | |
| +	if (!spi) {
 | |
| +		debug("SF: Failed to set up slave\n");
 | |
| +		return -1;
 | |
| +	}
 | |
| +
 | |
| +	/* Claim spi bus */
 | |
| +	ret = spi_claim_bus(spi);
 | |
| +	if (ret) {
 | |
| +		debug("SF: Failed to claim SPI bus: %d\n", ret);
 | |
| +		goto err_claim_bus;
 | |
| +	}
 | |
| +
 | |
| +	/* Read the ID codes */
 | |
| +	ret = spi_flash_cmd(spi, CMD_READ_ID, idcode, sizeof(idcode));
 | |
| +	if (ret) {
 | |
| +		debug("SF: Failed to get idcodes\n");
 | |
| +		goto err_read_id;
 | |
| +	}
 | |
| +
 | |
| +	/* Validate params from spi_flash_params table */
 | |
| +	flash->spi = spi;
 | |
| +	ret = spi_flash_validate_params(flash, idcode);
 | |
| +	if (ret)
 | |
| +		goto err_read_id;
 | |
| +
 | |
| +	/* Release spi bus */
 | |
| +	spi_release_bus(spi);
 | |
| +
 | |
| +	return 0;
 | |
| +
 | |
| +err_read_id:
 | |
| +	spi_release_bus(spi);
 | |
| +err_claim_bus:
 | |
| +	spi_free_slave(spi);
 | |
| +	flash->spi = NULL;
 | |
| +
 | |
| +	return ret;
 | |
| +}
 | |
| +
 | |
| +void spl_spi_flash_free(struct spi_flash *flash)
 | |
| +{
 | |
| +	spi_free_slave(flash->spi);
 | |
| +}
 | |
| +#endif
 | |
| --- a/include/spi_flash.h
 | |
| +++ b/include/spi_flash.h
 | |
| @@ -69,6 +69,9 @@ struct spi_flash *spi_flash_probe(unsign
 | |
|  		unsigned int max_hz, unsigned int spi_mode);
 | |
|  void spi_flash_free(struct spi_flash *flash);
 | |
|  
 | |
| +int spl_spi_flash_probe(struct spi_flash *flash);
 | |
| +void spl_spi_flash_free(struct spi_flash *flash);
 | |
| +
 | |
|  static inline int spi_flash_read(struct spi_flash *flash, u32 offset,
 | |
|  		size_t len, void *buf)
 | |
|  {
 |