802.15.4 IO Sampling Callback example for mbed XBeeLib By Digi

Dependencies:   XBeeLib mbed

This example shows how to monitor remote XBee modules DigitalInputs and ADCs. The remote XBee module sends packets periodically to the local XBee module containing the value of its DigitalInputs and ADCs. This library process those packets and calls a user registered function callback so the user can handle them.

See Handling IO Data Samples from other modules chapter for more information.

Common Setup

Make sure you have a valid Example Common Setup

Example Setup

Application

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.

Hardware

On the Remote XBee module, wire following peripherals to the pins specified on the table and schematics, or change the application pins according to your hardware setup:

LinePinValue
DIO2/ADC218ADC (Analog Input)
DIO3/ADC317Digital Input

/media/uploads/hbujanda/dio_adc_schem.png

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 do following operations:

  • Register the function callback that will be called by the library when corresponding IO sample frame is received.
  • Configure the remote XBee module pins according to the table above.
  • Configure the sample rate.
  • Configure remote XBee module to send IO Samples to local XBee module
  • Periodically ask the XBee library to process received frames

When a IO Sample frame is received the user callback does:

  • Read DIO3_AD3 digital value
  • Read DIO2_AD2 analog value

config.h

Committer:
hbujanda
Date:
2015-05-11
Revision:
3:e548b51f26c3
Parent:
1:95a425d4fbd8

File content as of revision 3:e548b51f26c3:


#if !defined(__CONFIG_H_)
#define __CONFIG_H_

#define PATFORM_ARCHPRO

/** Library configuration options */
#define ENABLE_LOGGING
#define ENABLE_ASSERTIONS
#define FRAME_BUFFER_SIZE   10
#define MAX_FRAME_PAYLOAD_LEN  128
#define ENABLE_PM_SUPPORT

#define SYNC_OPS_TIMEOUT_MS       2000

#if defined(PATFORM_ARCHPRO)
#define RADIO_TX            P4_28
#define RADIO_RX            P4_29
#define RADIO_RESET         P2_13
//#define RADIO_RESET         NC
#define RADIO_SLEEP_REQ     NC
#define RADIO_ON_SLEEP      NC
#define DEBUG_TX            P0_2
#define DEBUG_RX            P0_3
#elif defined(TARGET_LPC1768)
#define RADIO_TX            p9
#define RADIO_RX            p10
#define RADIO_RESET         p30
#define RADIO_SLEEP_REQ     NC
#define RADIO_ON_SLEEP      NC
#define DEBUG_TX            P0_2
#define DEBUG_RX            P0_3
#elif defined(TARGET_FRDM_KL25)
#define RADIO_TX            PTD3
#define RADIO_RX            PTD2
#define RADIO_RESET         NC
#define RADIO_SLEEP_REQ     NC
#define RADIO_ON_SLEEP      NC
#define DEBUG_TX            USBTX
#define DEBUG_RX            USBRX
#elif (defined TARGET_LPC11U24)
#define RADIO_TX            p9
#define RADIO_RX            p10
#define RADIO_RESET         p30
#define RADIO_SLEEP_REQ     NC
#define RADIO_ON_SLEEP      NC
#define DEBUG_TX            USBTX
#define DEBUG_RX            USBRX
#else
#error "Define a platform"
#endif

#endif /* __CONFIG_H_ */