Skip to content
Snippets Groups Projects
Commit 000044d8 authored by Mike Frysinger's avatar Mike Frysinger Committed by Wolfgang Denk
Browse files

sf: unify read/write helpers


These functions largely do the same exact thing, so unify them all
into one basic function.

Signed-off-by: default avatarMike Frysinger <vapier@gentoo.org>
parent 17e967b3
No related branches found
No related tags found
No related merge requests found
...@@ -14,32 +14,10 @@ ...@@ -14,32 +14,10 @@
#include "spi_flash_internal.h" #include "spi_flash_internal.h"
int spi_flash_cmd(struct spi_slave *spi, u8 cmd, void *response, size_t len) static int spi_flash_read_write(struct spi_slave *spi,
{ const u8 *cmd, size_t cmd_len,
unsigned long flags = SPI_XFER_BEGIN; const u8 *data_out, u8 *data_in,
int ret; size_t data_len)
if (len == 0)
flags |= SPI_XFER_END;
ret = spi_xfer(spi, 8, &cmd, NULL, flags);
if (ret) {
debug("SF: Failed to send command %02x: %d\n", cmd, ret);
return ret;
}
if (len) {
ret = spi_xfer(spi, len * 8, NULL, response, SPI_XFER_END);
if (ret)
debug("SF: Failed to read response (%zu bytes): %d\n",
len, ret);
}
return ret;
}
int spi_flash_cmd_read(struct spi_slave *spi, const u8 *cmd,
size_t cmd_len, void *data, size_t data_len)
{ {
unsigned long flags = SPI_XFER_BEGIN; unsigned long flags = SPI_XFER_BEGIN;
int ret; int ret;
...@@ -49,41 +27,34 @@ int spi_flash_cmd_read(struct spi_slave *spi, const u8 *cmd, ...@@ -49,41 +27,34 @@ int spi_flash_cmd_read(struct spi_slave *spi, const u8 *cmd,
ret = spi_xfer(spi, cmd_len * 8, cmd, NULL, flags); ret = spi_xfer(spi, cmd_len * 8, cmd, NULL, flags);
if (ret) { if (ret) {
debug("SF: Failed to send read command (%zu bytes): %d\n", debug("SF: Failed to send command (%zu bytes): %d\n",
cmd_len, ret); cmd_len, ret);
} else if (data_len != 0) { } else if (data_len != 0) {
ret = spi_xfer(spi, data_len * 8, NULL, data, SPI_XFER_END); ret = spi_xfer(spi, data_len * 8, data_out, data_in, SPI_XFER_END);
if (ret) if (ret)
debug("SF: Failed to read %zu bytes of data: %d\n", debug("SF: Failed to transfer %zu bytes of data: %d\n",
data_len, ret); data_len, ret);
} }
return ret; return ret;
} }
int spi_flash_cmd_write(struct spi_slave *spi, const u8 *cmd, size_t cmd_len, int spi_flash_cmd(struct spi_slave *spi, u8 cmd, void *response, size_t len)
const void *data, size_t data_len)
{ {
unsigned long flags = SPI_XFER_BEGIN; return spi_flash_cmd_read(spi, &cmd, 1, response, len);
int ret; }
if (data_len == 0)
flags |= SPI_XFER_END;
ret = spi_xfer(spi, cmd_len * 8, cmd, NULL, flags);
if (ret) {
debug("SF: Failed to send read command (%zu bytes): %d\n",
cmd_len, ret);
} else if (data_len != 0) {
ret = spi_xfer(spi, data_len * 8, data, NULL, SPI_XFER_END);
if (ret)
debug("SF: Failed to read %zu bytes of data: %d\n",
data_len, ret);
}
return ret; int spi_flash_cmd_read(struct spi_slave *spi, const u8 *cmd,
size_t cmd_len, void *data, size_t data_len)
{
return spi_flash_read_write(spi, cmd, cmd_len, NULL, data, data_len);
} }
int spi_flash_cmd_write(struct spi_slave *spi, const u8 *cmd, size_t cmd_len,
const void *data, size_t data_len)
{
return spi_flash_read_write(spi, cmd, cmd_len, data, NULL, data_len);
}
int spi_flash_read_common(struct spi_flash *flash, const u8 *cmd, int spi_flash_read_common(struct spi_flash *flash, const u8 *cmd,
size_t cmd_len, void *data, size_t data_len) size_t cmd_len, void *data, size_t data_len)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment