Made timeouts more explicit in write()
This commit is contained in:
parent
ca4820cd27
commit
c5823c2605
2 changed files with 23 additions and 16 deletions
34
RF24.cpp
34
RF24.cpp
|
@ -13,7 +13,7 @@
|
||||||
|
|
||||||
#undef SERIAL_DEBUG
|
#undef SERIAL_DEBUG
|
||||||
#ifdef SERIAL_DEBUG
|
#ifdef SERIAL_DEBUG
|
||||||
#define IF_SERIAL_DEBUG(x) (x)
|
#define IF_SERIAL_DEBUG(x) ({x;})
|
||||||
#else
|
#else
|
||||||
#define IF_SERIAL_DEBUG(x)
|
#define IF_SERIAL_DEBUG(x)
|
||||||
#endif
|
#endif
|
||||||
|
@ -365,30 +365,33 @@ boolean RF24::write( const void* buf, uint8_t len )
|
||||||
|
|
||||||
// Allons!
|
// Allons!
|
||||||
ce(HIGH);
|
ce(HIGH);
|
||||||
|
delayMicroseconds(15);
|
||||||
|
ce(LOW);
|
||||||
|
|
||||||
|
// ------------
|
||||||
|
// At this point we could return from a non-blocking write, and then call
|
||||||
|
// the rest after an interrupt
|
||||||
|
|
||||||
|
// Instead, we are going to block here until we get TX_DS (transmission completed and ack'd)
|
||||||
|
// or MAX_RT (maximum retries, transmission failed). Also, we'll timeout in case the radio
|
||||||
|
// is flaky and we get neither.
|
||||||
|
|
||||||
// IN the end, the send should be blocking. It comes back in 60ms worst case, or much faster
|
|
||||||
// if I tighted up the retry logic. (Default settings will be 750us.
|
|
||||||
// Monitor the send
|
|
||||||
uint8_t observe_tx;
|
uint8_t observe_tx;
|
||||||
uint8_t status;
|
uint8_t status;
|
||||||
uint8_t retries = 255;
|
uint32_t sent_at = millis();
|
||||||
|
const uint32_t timeout = 100; //ms to wait for timeout
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
status = read_register(OBSERVE_TX,&observe_tx,1);
|
status = read_register(OBSERVE_TX,&observe_tx,1);
|
||||||
IF_SERIAL_DEBUG(Serial.print(status,HEX));
|
|
||||||
IF_SERIAL_DEBUG(Serial.print(observe_tx,HEX));
|
IF_SERIAL_DEBUG(Serial.print(observe_tx,HEX));
|
||||||
if ( ! retries-- )
|
|
||||||
{
|
|
||||||
IF_SERIAL_DEBUG(printf("ABORTED: too many retries\n\r"));
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
while( ! ( status & ( _BV(TX_DS) | _BV(MAX_RT) ) ) && ( millis() - sent_at < timeout ) );
|
||||||
while( ! ( status & ( _BV(TX_DS) | _BV(MAX_RT) ) ) );
|
|
||||||
|
|
||||||
|
// What was the result of the send?
|
||||||
if ( status & _BV(TX_DS) )
|
if ( status & _BV(TX_DS) )
|
||||||
result = true;
|
result = true;
|
||||||
|
|
||||||
IF_SERIAL_DEBUG(Serial.print(result?"...OK.":"...Failed"));
|
IF_SERIAL_DEBUG(Serial.print(result?"...OK.":"...Failed"); if ( status & _BV(MAX_RT) ) Serial.print(" too many retries"));
|
||||||
|
|
||||||
ack_payload_available = ( status & _BV(RX_DR) );
|
ack_payload_available = ( status & _BV(RX_DR) );
|
||||||
if ( ack_payload_available )
|
if ( ack_payload_available )
|
||||||
|
@ -400,7 +403,6 @@ boolean RF24::write( const void* buf, uint8_t len )
|
||||||
}
|
}
|
||||||
|
|
||||||
// Yay, we are done.
|
// Yay, we are done.
|
||||||
ce(LOW);
|
|
||||||
|
|
||||||
// Power down
|
// Power down
|
||||||
write_register(CONFIG,read_register(CONFIG) & ~_BV(PWR_UP));
|
write_register(CONFIG,read_register(CONFIG) & ~_BV(PWR_UP));
|
||||||
|
@ -440,7 +442,9 @@ boolean RF24::available(void)
|
||||||
boolean RF24::available(uint8_t* pipe_num)
|
boolean RF24::available(uint8_t* pipe_num)
|
||||||
{
|
{
|
||||||
uint8_t status = get_status();
|
uint8_t status = get_status();
|
||||||
IF_SERIAL_DEBUG(print_status(status));
|
|
||||||
|
// Too noisy, enable if you really want lots o data!! IF_SERIAL_DEBUG(print_status(status));
|
||||||
|
|
||||||
boolean result = ( status & _BV(RX_DR) );
|
boolean result = ( status & _BV(RX_DR) );
|
||||||
|
|
||||||
if (result)
|
if (result)
|
||||||
|
|
|
@ -96,6 +96,9 @@ void setup(void)
|
||||||
// optionally, use a high channel to avoid WiFi chatter
|
// optionally, use a high channel to avoid WiFi chatter
|
||||||
radio.setChannel(110);
|
radio.setChannel(110);
|
||||||
|
|
||||||
|
// optionally, increase the CRC length for improved reliability
|
||||||
|
radio.setCRCLength(RF24_CRC_16);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Open pipes to other nodes for communication
|
// Open pipes to other nodes for communication
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in a new issue