Added 3rd test case, static payload
This commit is contained in:
parent
c408c5ef90
commit
d436895f7c
2 changed files with 26 additions and 7 deletions
|
@ -70,7 +70,7 @@ void check_radio(void);
|
||||||
|
|
||||||
const int min_payload_size = 4;
|
const int min_payload_size = 4;
|
||||||
const int max_payload_size = 32;
|
const int max_payload_size = 32;
|
||||||
const int payload_size_increments_by = 2;
|
int payload_size_increments_by = 2;
|
||||||
int next_payload_size = min_payload_size;
|
int next_payload_size = min_payload_size;
|
||||||
|
|
||||||
char receive_payload[max_payload_size+1]; // +1 to allow room for a terminating NULL char
|
char receive_payload[max_payload_size+1]; // +1 to allow room for a terminating NULL char
|
||||||
|
@ -169,9 +169,9 @@ void setup(void)
|
||||||
// We will be using the Ack Payload feature, so please enable it
|
// We will be using the Ack Payload feature, so please enable it
|
||||||
radio.enableAckPayload();
|
radio.enableAckPayload();
|
||||||
|
|
||||||
|
// Config 2 is special radio config
|
||||||
if (configuration=='2')
|
if (configuration=='2')
|
||||||
{
|
{
|
||||||
// Config 2 is special radio config
|
|
||||||
radio.setCRCLength(RF24_CRC_8);
|
radio.setCRCLength(RF24_CRC_8);
|
||||||
radio.setDataRate(RF24_2MBPS);
|
radio.setDataRate(RF24_2MBPS);
|
||||||
radio.setChannel(10);
|
radio.setChannel(10);
|
||||||
|
@ -190,8 +190,18 @@ void setup(void)
|
||||||
radio.setChannel(90);
|
radio.setChannel(90);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Config 3 is static payloads only
|
||||||
|
if (configuration == '3')
|
||||||
|
{
|
||||||
|
next_payload_size = max_payload_size;
|
||||||
|
payload_size_increments_by = 0;
|
||||||
|
radio.setPayloadSize(16);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// enable dynamic payloads
|
// enable dynamic payloads
|
||||||
radio.enableDynamicPayloads();
|
radio.enableDynamicPayloads();
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Open pipes to other nodes for communication
|
// Open pipes to other nodes for communication
|
||||||
|
@ -331,7 +341,7 @@ void check_radio(void)
|
||||||
// is this ack what we were expecting? to account
|
// is this ack what we were expecting? to account
|
||||||
// for failures, we simply want to make sure we get a
|
// for failures, we simply want to make sure we get a
|
||||||
// DIFFERENT ack every time.
|
// DIFFERENT ack every time.
|
||||||
if ( message_count != last_message_count )
|
if ( ( message_count != last_message_count ) || ( configuration=='3' && message_count == 16 ) )
|
||||||
{
|
{
|
||||||
printf("OK ");
|
printf("OK ");
|
||||||
one_ok();
|
one_ok();
|
||||||
|
@ -347,13 +357,19 @@ void check_radio(void)
|
||||||
if ( role == role_receiver )
|
if ( role == role_receiver )
|
||||||
{
|
{
|
||||||
// Get this payload and dump it
|
// Get this payload and dump it
|
||||||
size_t len = radio.getDynamicPayloadSize();
|
size_t len = max_payload_size;
|
||||||
|
memset(receive_payload,0,max_payload_size);
|
||||||
|
|
||||||
|
if ( configuration != '3' )
|
||||||
|
len = radio.getDynamicPayloadSize();
|
||||||
|
|
||||||
radio.read( receive_payload, len );
|
radio.read( receive_payload, len );
|
||||||
|
|
||||||
// Put a zero at the end for easy printing
|
// Put a zero at the end for easy printing
|
||||||
receive_payload[len] = 0;
|
receive_payload[len] = 0;
|
||||||
|
|
||||||
// Spew it
|
// Spew it
|
||||||
|
len = strlen(receive_payload); // How much did we REALLY get?
|
||||||
printf("Got payload size=%i value=%s\n\r",len,receive_payload);
|
printf("Got payload size=%i value=%s\n\r",len,receive_payload);
|
||||||
|
|
||||||
// Add an ack packet for the next time around.
|
// Add an ack packet for the next time around.
|
||||||
|
|
|
@ -3,6 +3,9 @@
|
||||||
# Connect p6 to receiver, p4 to sender
|
# Connect p6 to receiver, p4 to sender
|
||||||
|
|
||||||
jam p4 p6 || exit 1
|
jam p4 p6 || exit 1
|
||||||
|
./runtest.py /dev/tty.usbserial-A600eHIs 3 &
|
||||||
|
./runtest.py /dev/tty.usbserial-A40081RP 3 || exit 1
|
||||||
|
kill `jobs -p`
|
||||||
./runtest.py /dev/tty.usbserial-A600eHIs 1 &
|
./runtest.py /dev/tty.usbserial-A600eHIs 1 &
|
||||||
./runtest.py /dev/tty.usbserial-A40081RP 1 || exit 1
|
./runtest.py /dev/tty.usbserial-A40081RP 1 || exit 1
|
||||||
kill `jobs -p`
|
kill `jobs -p`
|
||||||
|
|
Loading…
Reference in a new issue