1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

drivers/cc2420: adapt FIFO access to recent msp430 SPI changes

When redoing the SPI driver for the msp430 platforms an assert
statement was introduced to prohibit SPI access without any
buffers. Since in the existing code the FIFO pointer is incremented
through a dummy read this results in triggering aforementioned
assert.
This commit is contained in:
Thomas Eichinger 2016-11-07 10:10:26 -08:00
parent e6ad438a0b
commit b57ce103a3

View File

@ -217,7 +217,7 @@ int cc2420_rx(cc2420_t *dev, uint8_t *buf, size_t max_len, void *info)
{ {
uint8_t len; uint8_t len;
/* get the packet length (without dropping it) (first byte in RX FIFO */ /* get the packet length (without dropping it) (first byte in RX FIFO) */
cc2420_ram_read(dev, CC2420_RAM_RXFIFO, &len, 1); cc2420_ram_read(dev, CC2420_RAM_RXFIFO, &len, 1);
len -= 2; /* subtract RSSI and FCF */ len -= 2; /* subtract RSSI and FCF */
@ -227,10 +227,13 @@ int cc2420_rx(cc2420_t *dev, uint8_t *buf, size_t max_len, void *info)
/* if a buffer is given, read (and drop) the packet */ /* if a buffer is given, read (and drop) the packet */
if (buf) { if (buf) {
/* We could the drop length byte here, msp430 platforms don't allow
* empty reads so we don't do it and read the length byte again. */
cc2420_fifo_read(dev, &len, 1);
len -=2; /* subtract RSSI and FCF */
len = (len > max_len) ? max_len : len; len = (len > max_len) ? max_len : len;
/* drop length byte */
cc2420_fifo_read(dev, NULL, 1);
/* read fifo contents */ /* read fifo contents */
DEBUG("cc2420: recv: reading %i byte of the packet\n", (int)len); DEBUG("cc2420: recv: reading %i byte of the packet\n", (int)len);
cc2420_fifo_read(dev, buf, len); cc2420_fifo_read(dev, buf, len);