|
|
|
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)
|
|
|
|
{
|