2015-03-17 14:42:35 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-08-17 15:41:29 +02:00
|
|
|
* @defgroup net_gnrc_zep Zigbee Encapsulation Protocol
|
2015-08-20 16:17:37 +02:00
|
|
|
* @ingroup net_gnrc
|
2015-03-17 14:42:35 +01:00
|
|
|
* @brief Transports IEEE 802.15.4 frames over UDP (can be parsed by
|
|
|
|
* Wireshark)
|
2015-07-01 14:46:12 +02:00
|
|
|
* @note Stability uncertain
|
2015-03-17 14:42:35 +01:00
|
|
|
* @see <a href="https://www.wireshark.org/docs/dfref/z/zep.html">
|
|
|
|
* ZigBee Encapsulation Protocol in the Wireshark docs
|
|
|
|
* </a>
|
|
|
|
* @see <a href="https://code.wireshark.org/review/gitweb?p=wireshark.git;a=blob;f=epan/dissectors/packet-zep.c;h=3422eb7876f973f191da98cc4c02aecbd0dbaaeb;hb=HEAD">
|
|
|
|
* ZEP packet definition in the Wireshark code base.
|
|
|
|
* </a>
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief ZEP definitions
|
|
|
|
*
|
|
|
|
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifndef GNRC_ZEP_H_
|
|
|
|
#define GNRC_ZEP_H_
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
#include <inttypes.h>
|
|
|
|
|
|
|
|
#include "byteorder.h"
|
|
|
|
#include "kernel_types.h"
|
2015-08-10 00:26:36 +02:00
|
|
|
#include "net/ipv6/addr.h"
|
2015-08-17 15:41:29 +02:00
|
|
|
#include "net/gnrc/nettype.h"
|
2015-03-17 14:42:35 +01:00
|
|
|
#include "thread.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum possible packet size in byte
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_ZEP_MAX_PKT_LENGTH (116)
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default stack size to use for the ZEP thread
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifndef GNRC_ZEP_STACK_SIZE
|
|
|
|
#define GNRC_ZEP_STACK_SIZE (THREAD_STACKSIZE_DEFAULT)
|
2015-03-17 14:42:35 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default priority for the ZEP thread
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifndef GNRC_ZEP_PRIO
|
|
|
|
#define GNRC_ZEP_PRIO (THREAD_PRIORITY_MAIN - 5)
|
2015-03-17 14:42:35 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default message queue size to use for the ZEP thread.
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#ifndef GNRC_ZEP_MSG_QUEUE_SIZE
|
|
|
|
#define GNRC_ZEP_MSG_QUEUE_SIZE (8U)
|
2015-03-17 14:42:35 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default addresses if the CPUID module is not present
|
|
|
|
* @{
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_ZEP_DEFAULT_ADDR_SHORT (0x98b0)
|
|
|
|
#define GNRC_ZEP_DEFAULT_ADDR_LONG (0x4a8a6377552b4249)
|
2015-03-17 14:42:35 +01:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Channel configuration
|
|
|
|
* @{
|
|
|
|
*/
|
2016-10-21 12:58:50 +02:00
|
|
|
#define GNRC_ZEP_MIN_CHANNEL (IEEE802154_CHANNEL_MIN)
|
|
|
|
#define GNRC_ZEP_MAX_CHANNEL (IEEE802154_CHANNEL_MAX)
|
|
|
|
#define GNRC_ZEP_DEFAULT_CHANNEL (IEEE802154_DEFAULT_CHANNEL)
|
2015-03-17 14:42:35 +01:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default PAN ID
|
|
|
|
*
|
2015-07-31 21:57:36 +02:00
|
|
|
* @todo Read some global network stack specific configuration value
|
2015-03-17 14:42:35 +01:00
|
|
|
*/
|
2016-10-21 12:58:50 +02:00
|
|
|
#define GNRC_ZEP_DEFAULT_PANID (IEEE802154_DEFAULT_PANID)
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Option flags for the ZEP device
|
|
|
|
* @{
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_ZEP_FLAGS_AUTOACK (0x0001) /**< auto ACKS active */
|
|
|
|
#define GNRC_ZEP_FLAGS_SRC_ADDR_LONG (0x0002) /**< send data using long source address */
|
|
|
|
#define GNRC_ZEP_FLAGS_DST_ADDR_LONG (0x0004) /**< send data using long destination address */
|
|
|
|
#define GNRC_ZEP_FLAGS_USE_SRC_PAN (0x0008) /**< do not compress source PAN ID */
|
2015-03-17 14:42:35 +01:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default UDP port for ZEP
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_ZEP_DEFAULT_PORT (17754)
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Type == Data for ZEPv2 header
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_ZEP_V2_TYPE_DATA (1)
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Type == Ack for ZEPv2 header
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
#define GNRC_ZEP_V2_TYPE_ACK (2)
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Mask for length field
|
|
|
|
*/
|
|
|
|
#define ZEP_LENGTH_MASK (0x7f)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief ZEP header definition
|
|
|
|
*/
|
|
|
|
typedef struct __attribute__((packed)) {
|
|
|
|
char preamble[2]; /**< Preamble code (must be "EX") */
|
|
|
|
uint8_t version; /**< Protocol Version (must be 1 or 2) */
|
2015-08-17 15:41:29 +02:00
|
|
|
} gnrc_zep_hdr_t;
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief ZEPv1 header definition
|
2015-08-17 15:41:29 +02:00
|
|
|
* @extends gnrc_zep_hdr_t
|
2015-03-17 14:42:35 +01:00
|
|
|
*/
|
|
|
|
typedef struct __attribute__((packed)) {
|
|
|
|
char preamble[2]; /**< preamble code (must be "EX") */
|
|
|
|
uint8_t version; /**< protocol Version (must be 1) */
|
|
|
|
uint8_t chan; /**< channel ID */
|
|
|
|
network_uint16_t dev; /**< device ID */
|
|
|
|
uint8_t lqi_mode; /**< CRC/LQI Mode */
|
|
|
|
uint8_t lqi_val; /**< LQI value */
|
|
|
|
uint8_t resv[7]; /**< reserved field, must always be 0 */
|
|
|
|
uint8_t length; /**< length of the frame */
|
2015-08-17 15:41:29 +02:00
|
|
|
} gnrc_zep_v1_hdr_t;
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief ZEPv2 header definition (type == Data)
|
2015-08-17 15:41:29 +02:00
|
|
|
* @extends gnrc_zep_hdr_t
|
2015-03-17 14:42:35 +01:00
|
|
|
*/
|
|
|
|
typedef struct __attribute__((packed)) {
|
|
|
|
char preamble[2]; /**< preamble code (must be "EX") */
|
|
|
|
uint8_t version; /**< protocol Version (must be 2) */
|
|
|
|
uint8_t type; /**< type (must be 1/Data) */
|
|
|
|
uint8_t chan; /**< channel ID */
|
|
|
|
network_uint16_t dev; /**< device ID */
|
|
|
|
uint8_t lqi_mode; /**< CRC/LQI Mode */
|
|
|
|
uint8_t lqi_val; /**< LQI value */
|
|
|
|
network_uint64_t time; /**< NTP timestamp */
|
|
|
|
network_uint32_t seq; /**< Sequence number */
|
|
|
|
uint8_t resv[10]; /**< reserved field, must always be 0 */
|
|
|
|
uint8_t length; /**< length of the frame */
|
2015-08-17 15:41:29 +02:00
|
|
|
} gnrc_zep_v2_data_hdr_t;
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief ZEPv2 header definition (type == Ack)
|
2015-08-17 15:41:29 +02:00
|
|
|
* @extends gnrc_zep_hdr_t
|
2015-03-17 14:42:35 +01:00
|
|
|
*/
|
|
|
|
typedef struct __attribute__((packed)) {
|
|
|
|
char preamble[2]; /**< preamble code (must be "EX") */
|
|
|
|
uint8_t version; /**< protocol Version (must be 2) */
|
|
|
|
uint8_t type; /**< type (must be 2/Ack) */
|
|
|
|
network_uint32_t seq; /**< Sequence number */
|
2015-08-17 15:41:29 +02:00
|
|
|
} gnrc_zep_v2_ack_hdr_t;
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief ZEP device descriptor.
|
|
|
|
*
|
2015-08-17 15:41:29 +02:00
|
|
|
* @extends gnrc_netdev_t
|
2015-03-17 14:42:35 +01:00
|
|
|
*/
|
|
|
|
typedef struct {
|
2015-08-17 15:41:29 +02:00
|
|
|
gnrc_netdev_driver_t *driver; /**< pointer to the device's interface */
|
|
|
|
gnrc_netdev_event_cb_t event_cb;/**< netdev event callback */
|
2015-03-17 14:42:35 +01:00
|
|
|
kernel_pid_t mac_pid; /**< the driver's thread's PID */
|
|
|
|
/**
|
2015-08-17 15:41:29 +02:00
|
|
|
* @brief @ref gnrc_zep_t specific members
|
2015-03-17 14:42:35 +01:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
le_uint16_t addr; /**< the device's short address */
|
|
|
|
le_uint64_t eui64; /**< the device's EUI-64 */
|
|
|
|
le_uint16_t pan; /**< the device's PAN ID */
|
|
|
|
uint16_t flags; /**< the device's option flags */
|
|
|
|
uint32_t seq; /**< the current sequence number for frames */
|
2015-08-10 00:26:36 +02:00
|
|
|
ipv6_addr_t dst; /**< destination IPv6 address */
|
2015-03-17 14:42:35 +01:00
|
|
|
uint16_t src_port; /**< source UDP port */
|
|
|
|
uint16_t dst_port; /**< destination UDP port */
|
2015-08-17 15:41:29 +02:00
|
|
|
gnrc_nettype_t proto; /**< the target protocol for received packets */
|
2015-03-17 14:42:35 +01:00
|
|
|
uint8_t chan; /**< the device's channel */
|
|
|
|
uint8_t version; /**< ZEP version to use (default 2) */
|
|
|
|
uint8_t lqi_mode; /**< LQI mode for send packets (default 1) */
|
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
} gnrc_zep_t;
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initializion of the ZEP thread and device.
|
|
|
|
*
|
|
|
|
* @param[in] dev Network device, will be initialized.
|
|
|
|
* @param[in] src_port Source port to use in UDP datagrams. Also the port
|
2015-08-17 15:41:29 +02:00
|
|
|
* @ref net_gnrc_zep registers to in @ref net_gnrc_netreg.
|
2015-03-17 14:42:35 +01:00
|
|
|
* @param[in] dst Destination address to use in IPv6 packets.
|
|
|
|
* @param[in] dst_port Destination port to use in UDP datagrams.
|
|
|
|
*
|
|
|
|
* @return PID of the ZEP thread on success.
|
|
|
|
* @return -EADDRINUSE, if @p src_port is already ready registered to
|
2015-08-17 15:41:29 +02:00
|
|
|
* @ref net_gnrc_netreg.
|
2015-03-17 14:42:35 +01:00
|
|
|
* @return -EEXIST, if ZEP thread was already created.
|
2015-08-17 15:41:29 +02:00
|
|
|
* @return -EINVAL, if @ref GNRC_ZEP_PRIO is greater than or equal to
|
2015-03-17 14:42:35 +01:00
|
|
|
* @ref SCHED_PRIO_LEVELS
|
|
|
|
* @return -ENODEV, if @p dev is NULL.
|
|
|
|
* @return -ENOTSUP, if @p dst is NULL or unspecified address (::).
|
|
|
|
* @return -EOVERFLOW, if there are too many threads running already
|
|
|
|
*/
|
2015-08-17 15:41:29 +02:00
|
|
|
kernel_pid_t gnrc_zep_init(gnrc_zep_t *dev, uint16_t src_port, ipv6_addr_t *dst,
|
|
|
|
uint16_t dst_port);
|
2015-03-17 14:42:35 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-08-17 15:41:29 +02:00
|
|
|
#endif /* GNRC_ZEP_H_ */
|
2015-03-17 14:42:35 +01:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|