Unverified Commit 5678bb99 authored by Earle F. Philhower, III's avatar Earle F. Philhower, III Committed by GitHub

Don't break transfer16 into 2 8-bit CS periods (#1764)

With HW chip select enabled, transfer16's 2 individual byte transfers will
actualy deassert CS for a brief instant between bytes.  Avoid this by doing
a single multi-byte (2) tranfer of 16b.
parent 5ecef160
...@@ -124,12 +124,11 @@ uint16_t SPIClassRP2040::transfer16(uint16_t data) { ...@@ -124,12 +124,11 @@ uint16_t SPIClassRP2040::transfer16(uint16_t data) {
} }
data = (_spis.getBitOrder() == MSBFIRST) ? data : reverse16Bit(data); data = (_spis.getBitOrder() == MSBFIRST) ? data : reverse16Bit(data);
DEBUGSPI("SPI::transfer16(%04x), cpol=%d, cpha=%d\n", data, cpol(), cpha()); DEBUGSPI("SPI::transfer16(%04x), cpol=%d, cpha=%d\n", data, cpol(), cpha());
uint8_t msb, lsb; uint8_t d[2];
msb = (data >> 8) & 0xff; d[0] = (data >> 8) & 0xff;
lsb = data & 0xff; d[1] = data & 0xff;
spi_write_read_blocking(_spi, &msb, &msb, 1); spi_write_read_blocking(_spi, d, d, 2);
spi_write_read_blocking(_spi, &lsb, &lsb, 1); ret = ((d[0] << 8) | (d[1] & 0xff)) & 0xffff;
ret = ((msb << 8) | (lsb & 0xff)) & 0xffff;
ret = (_spis.getBitOrder() == MSBFIRST) ? ret : reverse16Bit(ret); ret = (_spis.getBitOrder() == MSBFIRST) ? ret : reverse16Bit(ret);
DEBUGSPI("SPI: read back %02x\n", ret); DEBUGSPI("SPI: read back %02x\n", ret);
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment