if (end > m_len)
end = m_len;
- call Registers.setTxbuf((m_txBuf) ? m_txBuf[m_pos] : 0);
+ call Registers.setTxbuf(m_txBuf ? m_txBuf[m_pos] : 0);
while (++m_pos < end) {
- while (!call Registers.getIfgRx());
+ while (!call Registers.getIfgRx() && !call Registers.getCtl1(UCSWRST));
+ tmp = call Registers.getRxbuf();
if (m_rxBuf)
m_rxBuf[m_pos - 1] = call Registers.getRxbuf();
- else
- tmp = call Registers.getRxbuf();
- call Registers.setTxbuf((m_txBuf) ? m_txBuf[m_pos] : 0);
+ call Registers.setTxbuf(m_txBuf ? m_txBuf[m_pos] : 0);
}
}
}
task void signalSendDone()
{
atomic {
+ uint16_t len = m_len;
m_len = 0;
- signal SpiPacket.sendDone(m_txBuf, m_rxBuf, m_len, SUCCESS);
+ signal SpiPacket.sendDone(m_txBuf, m_rxBuf, len, SUCCESS);
}
}
async event void Interrupts.rx(uint8_t byte)
{
if (m_rxBuf)
- m_rxBuf[m_pos - 1] = call Registers.getRxbuf();
- else
- call Registers.getRxbuf();
+ m_rxBuf[m_pos - 1] = byte;
if (m_pos < m_len)
sendData();