mirror of
https://review.coreboot.org/flashrom.git
synced 2025-07-01 22:21:16 +02:00
tree: Remove forward-declarations for spi masters
Reorder functions to avoid forward-declarations. It looks like for most of the spi masters this has already been done before, I covered remaining small ones in one patch. BUG=b:140394053 TEST=builds Change-Id: I23ff6b79d794876f73b327f18784ca7c04c32c84 Signed-off-by: Anastasia Klimchuk <aklm@chromium.org> Reviewed-on: https://review.coreboot.org/c/flashrom/+/50711 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Edward O'Callaghan <quasisec@chromium.org> Reviewed-by: Sam McNally <sammc@google.com> Reviewed-by: Angel Pons <th3fanbus@gmail.com>
This commit is contained in:

committed by
Edward O'Callaghan

parent
d784d484c9
commit
f1391c756f
173
ft2232_spi.c
173
ft2232_spi.c
@ -183,10 +183,93 @@ static int ft2232_shutdown(void *data)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Returns 0 upon success, a negative number upon errors. */
|
||||
static int ft2232_spi_send_command(const struct flashctx *flash,
|
||||
unsigned int writecnt, unsigned int readcnt,
|
||||
const unsigned char *writearr,
|
||||
unsigned char *readarr);
|
||||
unsigned char *readarr)
|
||||
{
|
||||
struct ftdi_context *ftdic = &ftdic_context;
|
||||
static unsigned char *buf = NULL;
|
||||
/* failed is special. We use bitwise ops, but it is essentially bool. */
|
||||
int i = 0, ret = 0, failed = 0;
|
||||
size_t bufsize;
|
||||
static size_t oldbufsize = 0;
|
||||
|
||||
if (writecnt > 65536 || readcnt > 65536)
|
||||
return SPI_INVALID_LENGTH;
|
||||
|
||||
/* buf is not used for the response from the chip. */
|
||||
bufsize = max(writecnt + 9, 260 + 9);
|
||||
/* Never shrink. realloc() calls are expensive. */
|
||||
if (!buf || bufsize > oldbufsize) {
|
||||
buf = realloc(buf, bufsize);
|
||||
if (!buf) {
|
||||
msg_perr("Out of memory!\n");
|
||||
/* TODO: What to do with buf? */
|
||||
return SPI_GENERIC_ERROR;
|
||||
}
|
||||
oldbufsize = bufsize;
|
||||
}
|
||||
|
||||
/*
|
||||
* Minimize USB transfers by packing as many commands as possible
|
||||
* together. If we're not expecting to read, we can assert CS#, write,
|
||||
* and deassert CS# all in one shot. If reading, we do three separate
|
||||
* operations.
|
||||
*/
|
||||
msg_pspew("Assert CS#\n");
|
||||
buf[i++] = SET_BITS_LOW;
|
||||
buf[i++] = ~ 0x08 & pinlvl; /* assert CS (3rd) bit only */
|
||||
buf[i++] = pindir;
|
||||
|
||||
if (writecnt) {
|
||||
buf[i++] = MPSSE_DO_WRITE | MPSSE_WRITE_NEG;
|
||||
buf[i++] = (writecnt - 1) & 0xff;
|
||||
buf[i++] = ((writecnt - 1) >> 8) & 0xff;
|
||||
memcpy(buf + i, writearr, writecnt);
|
||||
i += writecnt;
|
||||
}
|
||||
|
||||
/*
|
||||
* Optionally terminate this batch of commands with a
|
||||
* read command, then do the fetch of the results.
|
||||
*/
|
||||
if (readcnt) {
|
||||
buf[i++] = MPSSE_DO_READ;
|
||||
buf[i++] = (readcnt - 1) & 0xff;
|
||||
buf[i++] = ((readcnt - 1) >> 8) & 0xff;
|
||||
ret = send_buf(ftdic, buf, i);
|
||||
failed = ret;
|
||||
/* We can't abort here, we still have to deassert CS#. */
|
||||
if (ret)
|
||||
msg_perr("send_buf failed before read: %i\n", ret);
|
||||
i = 0;
|
||||
if (ret == 0) {
|
||||
/*
|
||||
* FIXME: This is unreliable. There's no guarantee that
|
||||
* we read the response directly after sending the read
|
||||
* command. We may be scheduled out etc.
|
||||
*/
|
||||
ret = get_buf(ftdic, readarr, readcnt);
|
||||
failed |= ret;
|
||||
/* We can't abort here either. */
|
||||
if (ret)
|
||||
msg_perr("get_buf failed: %i\n", ret);
|
||||
}
|
||||
}
|
||||
|
||||
msg_pspew("De-assert CS#\n");
|
||||
buf[i++] = SET_BITS_LOW;
|
||||
buf[i++] = pinlvl;
|
||||
buf[i++] = pindir;
|
||||
ret = send_buf(ftdic, buf, i);
|
||||
failed |= ret;
|
||||
if (ret)
|
||||
msg_perr("send_buf failed at end: %i\n", ret);
|
||||
|
||||
return failed ? -1 : 0;
|
||||
}
|
||||
|
||||
static const struct spi_master spi_master_ft2232 = {
|
||||
.features = SPI_MASTER_4BA,
|
||||
@ -532,92 +615,4 @@ ftdi_err:
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* Returns 0 upon success, a negative number upon errors. */
|
||||
static int ft2232_spi_send_command(const struct flashctx *flash,
|
||||
unsigned int writecnt, unsigned int readcnt,
|
||||
const unsigned char *writearr,
|
||||
unsigned char *readarr)
|
||||
{
|
||||
struct ftdi_context *ftdic = &ftdic_context;
|
||||
static unsigned char *buf = NULL;
|
||||
/* failed is special. We use bitwise ops, but it is essentially bool. */
|
||||
int i = 0, ret = 0, failed = 0;
|
||||
size_t bufsize;
|
||||
static size_t oldbufsize = 0;
|
||||
|
||||
if (writecnt > 65536 || readcnt > 65536)
|
||||
return SPI_INVALID_LENGTH;
|
||||
|
||||
/* buf is not used for the response from the chip. */
|
||||
bufsize = max(writecnt + 9, 260 + 9);
|
||||
/* Never shrink. realloc() calls are expensive. */
|
||||
if (!buf || bufsize > oldbufsize) {
|
||||
buf = realloc(buf, bufsize);
|
||||
if (!buf) {
|
||||
msg_perr("Out of memory!\n");
|
||||
/* TODO: What to do with buf? */
|
||||
return SPI_GENERIC_ERROR;
|
||||
}
|
||||
oldbufsize = bufsize;
|
||||
}
|
||||
|
||||
/*
|
||||
* Minimize USB transfers by packing as many commands as possible
|
||||
* together. If we're not expecting to read, we can assert CS#, write,
|
||||
* and deassert CS# all in one shot. If reading, we do three separate
|
||||
* operations.
|
||||
*/
|
||||
msg_pspew("Assert CS#\n");
|
||||
buf[i++] = SET_BITS_LOW;
|
||||
buf[i++] = ~ 0x08 & pinlvl; /* assert CS (3rd) bit only */
|
||||
buf[i++] = pindir;
|
||||
|
||||
if (writecnt) {
|
||||
buf[i++] = MPSSE_DO_WRITE | MPSSE_WRITE_NEG;
|
||||
buf[i++] = (writecnt - 1) & 0xff;
|
||||
buf[i++] = ((writecnt - 1) >> 8) & 0xff;
|
||||
memcpy(buf + i, writearr, writecnt);
|
||||
i += writecnt;
|
||||
}
|
||||
|
||||
/*
|
||||
* Optionally terminate this batch of commands with a
|
||||
* read command, then do the fetch of the results.
|
||||
*/
|
||||
if (readcnt) {
|
||||
buf[i++] = MPSSE_DO_READ;
|
||||
buf[i++] = (readcnt - 1) & 0xff;
|
||||
buf[i++] = ((readcnt - 1) >> 8) & 0xff;
|
||||
ret = send_buf(ftdic, buf, i);
|
||||
failed = ret;
|
||||
/* We can't abort here, we still have to deassert CS#. */
|
||||
if (ret)
|
||||
msg_perr("send_buf failed before read: %i\n", ret);
|
||||
i = 0;
|
||||
if (ret == 0) {
|
||||
/*
|
||||
* FIXME: This is unreliable. There's no guarantee that
|
||||
* we read the response directly after sending the read
|
||||
* command. We may be scheduled out etc.
|
||||
*/
|
||||
ret = get_buf(ftdic, readarr, readcnt);
|
||||
failed |= ret;
|
||||
/* We can't abort here either. */
|
||||
if (ret)
|
||||
msg_perr("get_buf failed: %i\n", ret);
|
||||
}
|
||||
}
|
||||
|
||||
msg_pspew("De-assert CS#\n");
|
||||
buf[i++] = SET_BITS_LOW;
|
||||
buf[i++] = pinlvl;
|
||||
buf[i++] = pindir;
|
||||
ret = send_buf(ftdic, buf, i);
|
||||
failed |= ret;
|
||||
if (ret)
|
||||
msg_perr("send_buf failed at end: %i\n", ret);
|
||||
|
||||
return failed ? -1 : 0;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
Reference in New Issue
Block a user