aboutsummaryrefslogtreecommitdiff
path: root/src/drivers/spi/spi_flash.c
diff options
context:
space:
mode:
authorDuncan Laurie <dlaurie@chromium.org>2015-01-15 15:28:46 -0800
committerPatrick Georgi <pgeorgi@google.com>2015-04-17 09:21:22 +0200
commitfb032398d262ff7594c35c65b6f14897bb331a39 (patch)
treeadc486e7b25eff3f8b425eb75c78a8f4da77bed0 /src/drivers/spi/spi_flash.c
parent1968b5801098ab1c549ed47e42f543aff1cb2637 (diff)
spi: Add function to read flash status register
Add a function that allows reading of the status register from the SPI chip. This can be used to determine whether write protection is enabled on the chip. BUG=chrome-os-partner:35209 BRANCH=haswell TEST=build and boot on peppy Signed-off-by: Duncan Laurie <dlaurie@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/240702 Reviewed-by: Shawn N <shawnn@chromium.org> (cherry picked from commit c58f17689162b291a7cdb57649a237de21b73545) Change-Id: Ib7fead2cc4ea4339ece322dd18403362c9c79c7d Signed-off-by: Patrick Georgi <pgeorgi@chromium.org> Original-Commit-Id: 9fbdf0d72892eef4a742a418a347ecf650c01ea5 Original-Change-Id: I2541b22c51e43f7b7542ee0f48618cf411976a98 Original-Signed-off-by: Duncan Laurie <dlaurie@chromium.org> Original-Reviewed-on: https://chromium-review.googlesource.com/241128 Original-Reviewed-by: Shawn N <shawnn@chromium.org> Reviewed-on: http://review.coreboot.org/9730 Tested-by: build bot (Jenkins) Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Diffstat (limited to 'src/drivers/spi/spi_flash.c')
-rw-r--r--src/drivers/spi/spi_flash.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/drivers/spi/spi_flash.c b/src/drivers/spi/spi_flash.c
index 8213e852be..d40f72a852 100644
--- a/src/drivers/spi/spi_flash.c
+++ b/src/drivers/spi/spi_flash.c
@@ -234,6 +234,11 @@ out:
return ret;
}
+int spi_flash_cmd_status(struct spi_flash *flash, u8 *reg)
+{
+ return spi_flash_cmd(flash->spi, flash->status_cmd, reg, sizeof(*reg));
+}
+
/*
* The following table holds all device probe functions
*
@@ -372,6 +377,7 @@ flash_detected:
tseg_relocate((void **)&flash->read);
tseg_relocate((void **)&flash->write);
tseg_relocate((void **)&flash->erase);
+ tseg_relocate((void **)&flash->status);
tseg_relocate((void **)&flash->name);
#endif