802.15.4 Send Data example for mbed XBeeLib By Digi

Dependencies:   XBeeLib mbed

Description

This example shows how to send data to a remote XBee802 module. The application creates a message for a remote XBee module. This library encodes and sends it to the local XBee module through the serial port. Then the local XBee module sends the packet to the remote XBee module through the air.

The example shows how to send both unicast and broadcast messages.

See Sending data to another module chapter for more information.

Common Setup

Make sure you have a valid Example Common Setup

Example Setup

XBee modules

To evaluate the 16-bit addressing mode you have to configure the local XBee module and the remote XBee module with unique values... for example 0x1111 for the local and 0x2222 for the remote.

Application

Broadcast messages doesn't require any configuration, but for the unicast messages you have to configure:

  • The remote device 64-bit address by customizing the REMOTE_NODE_ADDR64_MSB and REMOTE_NODE_ADDR64_LSB defines with the remote XBee module 64-bit address.
  • The remote device 16-bit address by customizing the REMOTE_NODE_ADDR16 define with the remote XBee module 16-bit address.

Running the example

Build and deploy the example to the mbed module.
Reset the mbed module so the example starts. You should see the example debug information through the debug interface configured in the 'Local Setup' chapter. The application will first send a broadcast message and finally a couple of unicast messages to the configured remote XBee module (first using 64-bit addressing mode and then using 16-bit addressing mode).

Verify that the remote XBee module is receiving the frames by accessing the "Console" tab of the X-CTU. You should see there the broadcast and unicast messages.

Committer:
hbujanda
Date:
Fri Jul 29 12:11:33 2016 +0200
Revision:
10:73901166c6f4
Parent:
7:ab86cae2e208
Automatic upload

Who changed what in which revision?

UserRevisionLine numberNew contents of line
spastor 6:b672355ae49c 1 /**
spastor 6:b672355ae49c 2 * Copyright (c) 2015 Digi International Inc.,
spastor 6:b672355ae49c 3 * All rights not expressly granted are reserved.
spastor 6:b672355ae49c 4 *
spastor 6:b672355ae49c 5 * This Source Code Form is subject to the terms of the Mozilla Public
spastor 6:b672355ae49c 6 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
spastor 6:b672355ae49c 7 * You can obtain one at http://mozilla.org/MPL/2.0/.
spastor 6:b672355ae49c 8 *
spastor 6:b672355ae49c 9 * Digi International Inc. 11001 Bren Road East, Minnetonka, MN 55343
spastor 6:b672355ae49c 10 * =======================================================================
spastor 6:b672355ae49c 11 */
hbujanda 5:1b2d489605b1 12
spastor 6:b672355ae49c 13 #ifndef __CONFIG_H_
hbujanda 5:1b2d489605b1 14 #define __CONFIG_H_
hbujanda 5:1b2d489605b1 15
hbujanda 5:1b2d489605b1 16 /** Library configuration options */
hbujanda 5:1b2d489605b1 17 #define ENABLE_LOGGING
hbujanda 5:1b2d489605b1 18 #define ENABLE_ASSERTIONS
hbujanda 5:1b2d489605b1 19 #define FRAME_BUFFER_SIZE 4
hbujanda 5:1b2d489605b1 20 #define MAX_FRAME_PAYLOAD_LEN 128
hbujanda 5:1b2d489605b1 21
hbujanda 5:1b2d489605b1 22 #define SYNC_OPS_TIMEOUT_MS 2000
hbujanda 5:1b2d489605b1 23
hbujanda 5:1b2d489605b1 24 //#define RADIO_TX NC /* TODO: specify your setup's Serial TX pin connected to the XBee module DIN pin */
hbujanda 5:1b2d489605b1 25 //#define RADIO_RX NC /* TODO: specify your setup's Serial RX pin connected to the XBee module DOUT pin */
hbujanda 5:1b2d489605b1 26 //#define RADIO_RTS NC /* TODO: specify your setup's Serial RTS# pin connected to the XBee module RTS# pin */
hbujanda 5:1b2d489605b1 27 //#define RADIO_CTS NC /* TODO: specify your setup's Serial CTS# pin connected to the XBee module CTS# pin */
hbujanda 5:1b2d489605b1 28 //#define RADIO_RESET NC /* TODO: specify your setup's GPIO (output) connected to the XBee module's reset pin */
hbujanda 5:1b2d489605b1 29 //#define RADIO_SLEEP_REQ NC /* TODO: specify your setup's GPIO (output) connected to the XBee module's SLEEP_RQ pin */
hbujanda 5:1b2d489605b1 30 //#define RADIO_ON_SLEEP NC /* TODO: specify your setup's GPIO (input) connected to the XBee module's ON_SLEEP pin */
hbujanda 5:1b2d489605b1 31 //#define DEBUG_TX NC /* TODO: specify your setup's Serial TX for debugging */
hbujanda 5:1b2d489605b1 32 //#define DEBUG_RX NC /* TODO: specify your setup's Serial RX for debugging (optional) */
hbujanda 5:1b2d489605b1 33
hbujanda 5:1b2d489605b1 34 #if !defined(RADIO_TX)
hbujanda 5:1b2d489605b1 35 #error "Please define RADIO_TX pin"
hbujanda 5:1b2d489605b1 36 #endif
hbujanda 5:1b2d489605b1 37
hbujanda 5:1b2d489605b1 38 #if !defined(RADIO_RX)
hbujanda 5:1b2d489605b1 39 #error "Please define RADIO_RX pin"
hbujanda 5:1b2d489605b1 40 #endif
hbujanda 5:1b2d489605b1 41
hbujanda 5:1b2d489605b1 42 #if !defined(RADIO_RESET)
hbujanda 5:1b2d489605b1 43 #define RADIO_RESET NC
hbujanda 5:1b2d489605b1 44 #warning "RADIO_RESET not defined, defaulted to 'NC'"
hbujanda 5:1b2d489605b1 45 #endif
hbujanda 5:1b2d489605b1 46
hbujanda 5:1b2d489605b1 47 #if defined(ENABLE_LOGGING)
hbujanda 5:1b2d489605b1 48 #if !defined(DEBUG_TX)
hbujanda 5:1b2d489605b1 49 #error "Please define DEBUG_TX"
hbujanda 5:1b2d489605b1 50 #endif
hbujanda 5:1b2d489605b1 51 #if !defined(DEBUG_RX)
hbujanda 5:1b2d489605b1 52 #define DEBUG_RX NC
hbujanda 5:1b2d489605b1 53 #warning "DEBUG_RX not defined, defaulted to 'NC'"
hbujanda 5:1b2d489605b1 54 #endif
hbujanda 5:1b2d489605b1 55 #endif
hbujanda 5:1b2d489605b1 56
hbujanda 5:1b2d489605b1 57 #endif /* __CONFIG_H_ */