diff options
author | Dan Ehrenberg <dehrenberg@chromium.org> | 2015-01-08 10:29:19 -0800 |
---|---|---|
committer | Patrick Georgi <pgeorgi@google.com> | 2015-04-17 09:21:07 +0200 |
commit | a5aac76ac6be23448c164b0bc8047facb7238cdf (patch) | |
tree | 50bdd770ce2e8b1d257cd6c9cf56fd5cd8635b52 /src/drivers/spi/sst.c | |
parent | f9b49e8782efb7628984e1f3c3abc1ef7a58b84b (diff) | |
download | coreboot-a5aac76ac6be23448c164b0bc8047facb7238cdf.tar.xz |
drivers/spi: Pass flash parameters from coreboot to payload
A payload may want to run erase operations on SPI NOR flash without
re-probing the device to get its properties. This patch passes up
three properties of flash to achieve that:
- The size of the flash device
- The sector size, i.e., the granularity of erase
- The command used for erase
The patch sends the parameters through coreboot and then libpayload.
The patch also includes a minor refactoring of the flash erase code.
Parameters are sent up for just one flash device. If multiple SPI
flash devices are probed, the second one will "win" and its
parameters will be sent up to the payload.
TEST=Observed parameters to be passed up to depthcharge through
libpayload and be used to correctly initialize flash and do an erase.
TEST=Winbond and Gigadevices spi flash drivers compile with the changes;
others don't, for seemingly unrelated reasons.
BRANCH=none
BUG=chromium:446377
Change-Id: Ib8be86494b5a3d1cfe1d23d3492e3b5cba5f99c6
Signed-off-by: Patrick Georgi <pgeorgi@chromium.org>
Original-Commit-Id: 988c8c68bbfcdfa69d497ea5f806567bc80f8126
Original-Change-Id: Ie2b3a7f5b6e016d212f4f9bac3fabd80daf2ce72
Original-Signed-off-by: Dan Ehrenberg <dehrenberg@chromium.org>
Original-Reviewed-on: https://chromium-review.googlesource.com/239570
Original-Reviewed-by: Vadim Bendebury <vbendeb@chromium.org>
Reviewed-on: http://review.coreboot.org/9726
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Diffstat (limited to 'src/drivers/spi/sst.c')
-rw-r--r-- | src/drivers/spi/sst.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/src/drivers/spi/sst.c b/src/drivers/spi/sst.c index f681b7eeba..ecd792d46b 100644 --- a/src/drivers/spi/sst.c +++ b/src/drivers/spi/sst.c @@ -207,10 +207,6 @@ done: return ret; } -static int sst_erase(struct spi_flash *flash, u32 offset, size_t len) -{ - return spi_flash_cmd_erase(flash, CMD_SST_SE, offset, len); -} static int sst_unlock(struct spi_flash *flash) @@ -262,10 +258,11 @@ spi_flash_probe_sst(struct spi_slave *spi, u8 *idcode) stm->flash.name = params->name; stm->flash.write = sst_write; - stm->flash.erase = sst_erase; + stm->flash.erase = spi_flash_cmd_erase; stm->flash.read = spi_flash_cmd_read_fast; stm->flash.sector_size = SST_SECTOR_SIZE; stm->flash.size = stm->flash.sector_size * params->nr_sectors; + stm->flash.erase_cmd = CMD_SST_SE; /* Flash powers up read-only, so clear BP# bits */ sst_unlock(&stm->flash); |