DM 04b: Receive broadcast

This program shows how to receive packets with XBee-Digimesh modules. The packets received were broadcast

Required Materials

1 x Waspmote 1 x Battery 1 x MiniUSB wire 1 x XBee-Digimesh

Notes

- This example belongs to a two-code example. This is the receiving part. - Both XBee modules must be configured with the same network parameters (PANID, channel, encryption mode) - The battery has to be connected. - This example can be executed in Waspmote v12

Code

/*  
 *  ------ [DM_04b] - receive broadcast packets  -------- 
 *  
 *  Explanation: This program shows how to receive packets with 
 *  XBee-Digimesh modules. The packets received were broadcast
 *  
 *  Copyright (C) 2015 Libelium Comunicaciones Distribuidas S.L. 
 *  http://www.libelium.com 
 *  
 *  This program is free software: you can redistribute it and/or modify 
 *  it under the terms of the GNU General Public License as published by 
 *  the Free Software Foundation, either version 3 of the License, or 
 *  (at your option) any later version. 
 *  
 *  This program is distributed in the hope that it will be useful, 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
 *  GNU General Public License for more details. 
 *  
 *  You should have received a copy of the GNU General Public License 
 *  along with this program.  If not, see . 
 *  
 *  Version:           0.2
 *  Design:            David Gascón 
 *  Implementation:    Yuri Carmona
 */

#include <WaspXBeeDM.h>

// define variable
uint8_t error;



void setup()
{  
  // init USB port
  USB.ON();
  USB.println(F("Receiving BROADCAST packets example"));

  // init XBee 
  xbeeDM.ON();  
}



void loop()
{   
   // receive XBee packet (wait for 10 seconds)
  error = xbeeDM.receivePacketTimeout( 10000 );

  // check answer  
  if( error == 0 ) 
  {
    // Show data stored in '_payload' buffer indicated by '_length'
    USB.print(F("Data: "));  
    USB.println( xbeeDM._payload, xbeeDM._length);
    
    // Show data stored in '_payload' buffer indicated by '_length'
    USB.print(F("Length: "));  
    USB.println( xbeeDM._length,DEC);
    
    // Show data stored in '_payload' buffer indicated by '_length'
    USB.print(F("Source MAC Address: "));  
    USB.printHex( xbeeDM._srcMAC[0] );
    USB.printHex( xbeeDM._srcMAC[1] );
    USB.printHex( xbeeDM._srcMAC[2] );
    USB.printHex( xbeeDM._srcMAC[3] );
    USB.printHex( xbeeDM._srcMAC[4] );
    USB.printHex( xbeeDM._srcMAC[5] );
    USB.printHex( xbeeDM._srcMAC[6] );
    USB.printHex( xbeeDM._srcMAC[7] );
    USB.println();    
    USB.println(F("--------------------------------"));
  }
  else
  {
    // Print error message:
    /*
     * '7' : Buffer full. Not enough memory space
     * '6' : Error escaping character within payload bytes
     * '5' : Error escaping character in checksum byte
     * '4' : Checksum is not correct	  
     * '3' : Checksum byte is not available	
     * '2' : Frame Type is not valid
     * '1' : Timeout when receiving answer   
    */
    USB.print(F("Error receiving a packet:"));
    USB.println(error,DEC);     
    USB.println(F("--------------------------------"));
  }
} 

Output

E#
Receiving BROADCAST packets example
Data: <=>€#387245265#node_01#0#STR:new_sensor_frame#BAT:35#
Length: 54
Source MAC Address: 0013A2004091D1A0
--------------------------------
Data: <=>€#387245265#node_01#1#STR:new_sensor_frame#BAT:35#
Length: 54
Source MAC Address: 0013A2004091D1A0
--------------------------------
Data: <=>€#387245265#node_01#2#STR:new_sensor_frame#BAT:35#
Length: 54
Source MAC Address: 0013A2004091D1A0
--------------------------------
...

Last updated