2015-03-12 14:20:27 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 INRIA
|
2016-11-23 19:38:41 +01:00
|
|
|
* Copyright (C) 2015-2016 Freie Universität Berlin
|
2015-03-12 14:20:27 +01:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup drivers_xbee XBee driver
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_netdev
|
2015-03-12 14:20:27 +01:00
|
|
|
* @brief High-level driver for the XBee S1 802.15.4 modem
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief High-level driver for the XBee S1 802.15.4 modem
|
|
|
|
*
|
|
|
|
* @author Kévin Roussel <kevin.roussel@inria.fr>
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef XBEE_H_
|
|
|
|
#define XBEE_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "mutex.h"
|
2016-02-04 05:19:51 +01:00
|
|
|
#include "xtimer.h"
|
2015-03-12 14:20:27 +01:00
|
|
|
#include "periph/uart.h"
|
|
|
|
#include "periph/gpio.h"
|
2016-11-23 19:38:41 +01:00
|
|
|
#include "net/netdev2.h"
|
2015-08-07 14:36:04 +02:00
|
|
|
#include "net/ieee802154.h"
|
2016-11-23 19:38:41 +01:00
|
|
|
#include "net/gnrc/nettype.h"
|
2015-03-12 14:20:27 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
2015-08-07 14:37:19 +02:00
|
|
|
extern "C" {
|
2015-03-12 14:20:27 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum payload length that can be send
|
|
|
|
*/
|
2015-05-14 15:03:52 +02:00
|
|
|
#ifdef MODULE_XBEE_ENCRYPTION
|
|
|
|
#define XBEE_MAX_PAYLOAD_LENGTH (95U)
|
|
|
|
#else
|
2015-03-12 14:20:27 +01:00
|
|
|
#define XBEE_MAX_PAYLOAD_LENGTH (100U)
|
2015-05-14 15:03:52 +02:00
|
|
|
#endif
|
2015-03-12 14:20:27 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum packet length, including XBee API frame overhead
|
|
|
|
*/
|
|
|
|
#define XBEE_MAX_PKT_LENGTH (115U)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum length of a command response
|
|
|
|
*/
|
|
|
|
#define XBEE_MAX_RESP_LENGTH (16U)
|
|
|
|
|
2016-11-23 19:38:41 +01:00
|
|
|
/**
|
|
|
|
* @brief Maximal possible size of a TX header
|
|
|
|
*/
|
|
|
|
#define XBEE_MAX_TXHDR_LENGTH (14U)
|
|
|
|
|
2015-03-12 14:20:27 +01:00
|
|
|
/**
|
|
|
|
* @brief Default protocol for data that is coming in
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifdef MODULE_GNRC_SIXLOWPAN
|
|
|
|
#define XBEE_DEFAULT_PROTOCOL (GNRC_NETTYPE_SIXLOWPAN)
|
2015-03-12 14:20:27 +01:00
|
|
|
#else
|
2015-08-17 15:41:29 +02:00
|
|
|
#define XBEE_DEFAULT_PROTOCOL (GNRC_NETTYPE_UNDEF)
|
2015-03-12 14:20:27 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default PAN ID used after initialization
|
|
|
|
*/
|
2016-10-21 12:58:50 +02:00
|
|
|
#define XBEE_DEFAULT_PANID (IEEE802154_DEFAULT_PANID)
|
2015-03-12 14:20:27 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default channel used after initialization
|
|
|
|
*/
|
2016-10-21 12:58:50 +02:00
|
|
|
#define XBEE_DEFAULT_CHANNEL (IEEE802154_DEFAULT_CHANNEL)
|
2015-03-12 14:20:27 +01:00
|
|
|
|
2015-06-03 17:11:20 +02:00
|
|
|
/**
|
|
|
|
* @name Address flags
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @brief Use long addresses if not otherwise defined when set, use short
|
|
|
|
* addresses when unset.
|
|
|
|
*/
|
|
|
|
#define XBEE_ADDR_FLAGS_LONG (0x80)
|
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2015-03-12 14:20:27 +01:00
|
|
|
/**
|
|
|
|
* @brief States of the internal FSM for handling incoming UART frames
|
|
|
|
*
|
|
|
|
* Incoming data frames on the UART interfaces are handled using a finite state
|
|
|
|
* machine (FSM) in the UARTs RX interrupt handler. The FSM is needed to extract
|
|
|
|
* frame specific data as the frame size, frame type, and checksums.
|
|
|
|
*/
|
|
|
|
typedef enum {
|
2016-11-23 19:38:41 +01:00
|
|
|
XBEE_INT_STATE_IDLE, /**< waiting for the beginning of a new frame */
|
|
|
|
XBEE_INT_STATE_SIZE1, /**< waiting for the first byte (MSB) of the
|
|
|
|
* frame size field */
|
|
|
|
XBEE_INT_STATE_SIZE2, /**< waiting for the second byte (LSB) of the
|
|
|
|
* frame size field */
|
|
|
|
XBEE_INT_STATE_TYPE, /**< waiting for the frame type field */
|
|
|
|
XBEE_INT_STATE_RESP, /**< handling incoming data for AT command
|
|
|
|
* responses */
|
|
|
|
XBEE_INT_STATE_RX, /**< handling incoming data when receiving radio
|
|
|
|
* packets */
|
2015-03-12 14:20:27 +01:00
|
|
|
} xbee_rx_state_t;
|
|
|
|
|
2016-11-23 19:38:41 +01:00
|
|
|
/**
|
|
|
|
* @brief Configuration parameters for XBee devices
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
uart_t uart; /**< UART interfaced the device is connected to */
|
|
|
|
uint32_t br; /**< baudrate to use */
|
|
|
|
gpio_t pin_sleep; /**< GPIO pin that is connected to the SLEEP pin
|
|
|
|
set to GPIO_UNDEF if not used */
|
|
|
|
gpio_t pin_reset; /**< GPIO pin that is connected to the STATUS pin
|
|
|
|
set to GPIO_UNDEF if not used */
|
|
|
|
} xbee_params_t;
|
|
|
|
|
2015-03-12 14:20:27 +01:00
|
|
|
/**
|
|
|
|
* @brief XBee device descriptor
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/* netdev fields */
|
2016-11-23 19:38:41 +01:00
|
|
|
const struct netdev2_driver *driver; /**< ptr to that driver's interface. */
|
|
|
|
netdev2_event_cb_t event_callback; /**< callback for device events */
|
|
|
|
void* context; /**< ptr to network stack context */
|
|
|
|
#ifdef MODULE_NETSTATS_L2
|
|
|
|
netstats_t stats; /**< transceiver's statistics */
|
|
|
|
#endif
|
2015-03-12 14:20:27 +01:00
|
|
|
/* device driver specific fields */
|
2016-11-23 19:38:41 +01:00
|
|
|
xbee_params_t p; /**< configuration parameters */
|
2015-03-12 14:20:27 +01:00
|
|
|
uint8_t options; /**< options field */
|
2015-06-03 17:11:20 +02:00
|
|
|
uint8_t addr_flags; /**< address flags as defined above */
|
2015-03-12 14:20:27 +01:00
|
|
|
uint8_t addr_short[2]; /**< onw 802.15.4 short address */
|
2015-05-11 11:29:28 +02:00
|
|
|
eui64_t addr_long; /**< own 802.15.4 long address */
|
2015-03-12 14:20:27 +01:00
|
|
|
/* general variables for the UART RX state machine */
|
|
|
|
xbee_rx_state_t int_state; /**< current state if the UART RX FSM */
|
|
|
|
uint16_t int_size; /**< temporary space for parsing the
|
|
|
|
* frame size */
|
|
|
|
/* values for the UART TX state machine */
|
|
|
|
mutex_t tx_lock; /**< mutex to allow only one
|
|
|
|
* transmission at a time */
|
2016-11-23 19:38:41 +01:00
|
|
|
uint8_t cmd_buf[XBEE_MAX_RESP_LENGTH];/**< command data buffer */
|
|
|
|
uint8_t tx_fid; /**< TX frame ID */
|
2015-03-12 14:20:27 +01:00
|
|
|
/* buffer and synchronization for command responses */
|
|
|
|
mutex_t resp_lock; /**< mutex for waiting for AT command
|
|
|
|
* response frames */
|
|
|
|
uint8_t resp_buf[XBEE_MAX_RESP_LENGTH]; /**< AT response data buffer */
|
|
|
|
uint16_t resp_count; /**< counter for ongoing transmission */
|
|
|
|
uint16_t resp_limit; /**< size RESP frame in transferred */
|
|
|
|
/* buffer and synchronization for incoming network packets */
|
|
|
|
uint8_t rx_buf[XBEE_MAX_PKT_LENGTH];/**< receiving data buffer */
|
|
|
|
uint16_t rx_count; /**< counter for ongoing transmission */
|
|
|
|
uint16_t rx_limit; /**< size RX frame transferred */
|
|
|
|
} xbee_t;
|
|
|
|
|
2016-03-27 21:36:00 +02:00
|
|
|
/**
|
2016-11-23 19:38:41 +01:00
|
|
|
* @brief Data structure for extraction L2 information of received packets
|
2016-03-27 21:36:00 +02:00
|
|
|
*/
|
2016-11-23 19:38:41 +01:00
|
|
|
typedef struct {
|
|
|
|
uint8_t addr_len; /**< L2 address length (SRC and DST) */
|
|
|
|
uint8_t bcast; /**< 0 := unicast, 1:=broadcast */
|
|
|
|
uint8_t rssi; /**< RSSI value */
|
|
|
|
uint8_t src_addr[8]; /**< L2 source address */
|
|
|
|
uint8_t dst_addr[8]; /**< L2 dst address */
|
|
|
|
} xbee_l2hdr_t;
|
2016-03-27 21:36:00 +02:00
|
|
|
|
2015-03-12 14:20:27 +01:00
|
|
|
/**
|
|
|
|
* @brief Reference to the XBee driver interface
|
|
|
|
*/
|
2016-11-23 19:38:41 +01:00
|
|
|
extern const netdev2_driver_t xbee_driver;
|
2015-03-12 14:20:27 +01:00
|
|
|
|
|
|
|
/**
|
2016-11-23 19:38:41 +01:00
|
|
|
* @brief Prepare the given Xbee device
|
2015-03-12 14:20:27 +01:00
|
|
|
*
|
|
|
|
* @param[out] dev Xbee device to initialize
|
2016-03-27 21:36:00 +02:00
|
|
|
* @param[in] params parameters for device initialization
|
2015-03-12 14:20:27 +01:00
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -ENODEV on invalid device descriptor
|
|
|
|
* @return -ENXIO on invalid UART or GPIO pins
|
|
|
|
*/
|
2016-11-23 19:38:41 +01:00
|
|
|
void xbee_setup(xbee_t *dev, const xbee_params_t *params);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Put together the internal proprietary XBee header
|
|
|
|
*
|
|
|
|
* @param[out] xhdr buffer to write the header into, MUST be at least of
|
|
|
|
* length XBEE_MAX_TXHDR_LENGTH
|
|
|
|
* @param[in] payload_len actual payload length (without the XBee header)
|
|
|
|
* @param[in] dst_addr link layer (L2) destination address
|
|
|
|
* @param[in] addr_len length of @p dst_addr in byte (MUST be 2 or 8)
|
|
|
|
*
|
|
|
|
* @return the length of the created header in byte
|
|
|
|
* @return -EOVERFLOW if @p payload_len is greater than XBEE_MAX_PAYLOAD_LENGTH
|
|
|
|
* @return -ENOMSG if the given destination address has an invalid length
|
|
|
|
*/
|
|
|
|
int xbee_build_hdr(xbee_t *dev, uint8_t *xhdr, size_t payload_len,
|
|
|
|
void *dst_addr, size_t addr_len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Extract IEEE802.15.4 L2 header information from the XBee header
|
|
|
|
*
|
|
|
|
* @param[in] xhdr XBee header, starting with the API identifier
|
|
|
|
* @param[out] l2hdr the L2 header information is written here
|
|
|
|
*
|
|
|
|
* @return the length of the XBee header
|
|
|
|
* @return -ENOMST if the given XBee header is invalid
|
|
|
|
*/
|
|
|
|
int xbee_parse_hdr(xbee_t *dev, const uint8_t *xhdr, xbee_l2hdr_t *l2hdr);
|
2015-05-08 15:51:26 +02:00
|
|
|
|
2015-03-12 14:20:27 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* XBEE_H_ */
|
|
|
|
/** @} */
|