]> git.sur5r.net Git - u-boot/commitdiff
sf: ops: Add configuration register writing support
authorJagannadha Sutradharudu Teki <jaganna@xilinx.com>
Mon, 23 Dec 2013 10:17:48 +0000 (15:47 +0530)
committerJagannadha Sutradharudu Teki <jaganna@xilinx.com>
Sat, 11 Jan 2014 09:43:25 +0000 (15:13 +0530)
This patch provides support to program a flash config register.

Configuration register contains the control bits used to configure
the different configurations and security features of a device.

Signed-off-by: Jagannadha Sutradharudu Teki <jaganna@xilinx.com>
drivers/mtd/spi/sf_ops.c

index 3d304ce6acb4aeaf8bb7b84dd740e96fa259ceac..39e06ecae0dcf341464a11f8eebea3afe4ab2c92 100644 (file)
@@ -38,6 +38,30 @@ int spi_flash_cmd_write_status(struct spi_flash *flash, u8 sr)
        return 0;
 }
 
+static int spi_flash_cmd_write_config(struct spi_flash *flash, u8 cr)
+{
+       u8 data[2];
+       u8 cmd;
+       int ret;
+
+       cmd = CMD_READ_STATUS;
+       ret = spi_flash_read_common(flash, &cmd, 1, &data[0], 1);
+       if (ret < 0) {
+               debug("SF: fail to read status register\n");
+               return ret;
+       }
+
+       cmd = CMD_WRITE_STATUS;
+       data[1] = cr;
+       ret = spi_flash_write_common(flash, &cmd, 1, &data, 2);
+       if (ret) {
+               debug("SF: fail to write config register\n");
+               return ret;
+       }
+
+       return 0;
+}
+
 #ifdef CONFIG_SPI_FLASH_BAR
 static int spi_flash_cmd_bankaddr_write(struct spi_flash *flash, u8 bank_sel)
 {