2013-11-27 16:28:31 +01:00
|
|
|
/**
|
2013-11-27 17:54:30 +01:00
|
|
|
* @defgroup sys_transceiver Transceiver
|
|
|
|
* @ingroup sys
|
2014-04-16 12:09:23 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file transceiver.h
|
2013-11-27 17:54:30 +01:00
|
|
|
* @brief Transceiver library
|
2014-04-16 12:09:23 +02:00
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
2013-11-27 16:28:31 +01:00
|
|
|
*/
|
|
|
|
|
2010-11-19 20:10:09 +01:00
|
|
|
#ifndef TRANSCEIVER_H
|
2013-06-22 05:11:53 +02:00
|
|
|
#define TRANSCEIVER_H
|
2010-11-19 20:10:09 +01:00
|
|
|
|
2013-08-14 17:52:27 +02:00
|
|
|
#include "radio/types.h"
|
2010-11-23 11:37:13 +01:00
|
|
|
|
2013-08-11 14:11:11 +02:00
|
|
|
/* supported transceivers *
|
|
|
|
* NOTE: necessary to include here again due to
|
|
|
|
* https://github.com/RIOT-OS/RIOT/issues/117 */
|
|
|
|
#ifdef MODULE_CC110X
|
2014-02-07 18:26:21 +01:00
|
|
|
#include "cc110x.h"
|
2014-02-03 15:58:18 +01:00
|
|
|
#ifndef TRANSCEIVER_DEFAULT
|
|
|
|
#define TRANSCEIVER_DEFAULT TRANSCEIVER_CC1100
|
|
|
|
#endif
|
2013-08-11 14:11:11 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef MODULE_CC110X_NG
|
2013-08-14 17:52:27 +02:00
|
|
|
#include "cc110x_ng.h"
|
2014-02-03 15:58:18 +01:00
|
|
|
#ifndef TRANSCEIVER_DEFAULT
|
|
|
|
#define TRANSCEIVER_DEFAULT TRANSCEIVER_CC1100
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef MODULE_CC11020
|
|
|
|
#include "cc1020.h"
|
|
|
|
#ifndef TRANSCEIVER_DEFAULT
|
|
|
|
#define TRANSCEIVER_DEFAULT TRANSCEIVER_CC1020
|
|
|
|
#endif
|
2013-08-11 14:11:11 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef MODULE_CC2420
|
2013-08-14 17:52:27 +02:00
|
|
|
#include "cc2420.h"
|
2014-02-03 15:58:18 +01:00
|
|
|
#ifndef TRANSCEIVER_DEFAULT
|
|
|
|
#define TRANSCEIVER_DEFAULT TRANSCEIVER_CC2420
|
|
|
|
#endif
|
2013-08-11 14:11:11 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef MODULE_MC1322X
|
2013-08-14 17:52:27 +02:00
|
|
|
#include "mc1322x.h"
|
|
|
|
#include "maca.h"
|
|
|
|
#include "maca_packet.h"
|
2014-02-03 15:58:18 +01:00
|
|
|
#ifndef TRANSCEIVER_DEFAULT
|
|
|
|
#define TRANSCEIVER_DEFAULT TRANSCEIVER_MC1322X
|
|
|
|
#endif
|
2013-08-11 14:11:11 +02:00
|
|
|
#endif
|
|
|
|
|
2013-08-15 19:26:15 +02:00
|
|
|
#ifdef MODULE_NATIVENET
|
|
|
|
#include "nativenet.h"
|
|
|
|
#include "nativenet_internal.h"
|
2014-02-03 15:58:18 +01:00
|
|
|
#ifndef TRANSCEIVER_DEFAULT
|
|
|
|
#define TRANSCEIVER_DEFAULT TRANSCEIVER_NATIVE
|
|
|
|
#endif
|
2013-08-15 19:26:15 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef MODULE_AT86RF231
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "at86rf231.h"
|
2014-02-03 15:58:18 +01:00
|
|
|
#ifndef TRANSCEIVER_DEFAULT
|
|
|
|
#define TRANSCEIVER_DEFAULT TRANSCEIVER_AT86RF231
|
|
|
|
#endif
|
2013-08-15 19:26:15 +02:00
|
|
|
#endif
|
|
|
|
|
2010-11-21 14:00:24 +01:00
|
|
|
/* Stack size for transceiver thread */
|
2013-04-15 20:08:46 +02:00
|
|
|
#ifndef TRANSCEIVER_STACK_SIZE
|
2013-08-14 18:07:01 +02:00
|
|
|
#define TRANSCEIVER_STACK_SIZE (KERNEL_CONF_STACKSIZE_DEFAULT)
|
2013-04-15 20:08:46 +02:00
|
|
|
#endif
|
2010-11-19 20:10:09 +01:00
|
|
|
|
2013-08-15 13:51:40 +02:00
|
|
|
#ifndef PAYLOAD_SIZE
|
2013-08-08 23:43:15 +02:00
|
|
|
#define PAYLOAD_SIZE (0)
|
2013-08-15 13:51:40 +02:00
|
|
|
#endif
|
2013-08-08 23:43:15 +02:00
|
|
|
#ifdef MODULE_CC110X
|
2013-08-11 14:11:11 +02:00
|
|
|
#if (CC1100_MAX_DATA_LENGTH > PAYLOAD_SIZE)
|
|
|
|
#undef PAYLOAD_SIZE
|
|
|
|
#define PAYLOAD_SIZE (CC1100_MAX_DATA_LENGTH)
|
|
|
|
#endif
|
2013-08-08 23:43:15 +02:00
|
|
|
#endif
|
|
|
|
#ifdef MODULE_CC110X_NG
|
2013-08-11 14:11:11 +02:00
|
|
|
#if (CC1100_MAX_DATA_LENGTH > PAYLOAD_SIZE)
|
|
|
|
#undef PAYLOAD_SIZE
|
|
|
|
#define PAYLOAD_SIZE (CC1100_MAX_DATA_LENGTH)
|
|
|
|
#endif
|
|
|
|
#endif
|
2013-06-10 12:40:59 +02:00
|
|
|
#ifdef MODULE_CC2420
|
2013-08-11 14:11:11 +02:00
|
|
|
#if (CC2420_MAX_DATA_LENGTH > PAYLOAD_SIZE)
|
|
|
|
#undef PAYLOAD_SIZE
|
|
|
|
#define PAYLOAD_SIZE (CC2420_MAX_DATA_LENGTH)
|
|
|
|
#endif
|
2013-08-15 19:26:15 +02:00
|
|
|
#endif
|
2013-08-15 19:07:14 +02:00
|
|
|
#ifdef MODULE_AT86RF231
|
|
|
|
#if (AT86RF231_MAX_DATA_LENGTH > PAYLOAD_SIZE)
|
|
|
|
#undef PAYLOAD_SIZE
|
|
|
|
#define PAYLOAD_SIZE (AT86RF231_MAX_DATA_LENGTH)
|
2013-08-08 23:43:15 +02:00
|
|
|
#endif
|
2013-08-15 19:26:15 +02:00
|
|
|
#endif
|
2013-08-08 23:43:15 +02:00
|
|
|
#ifdef MODULE_MC1322X
|
2014-04-18 16:05:23 +02:00
|
|
|
#if (MACA_MAX_PAYLOAD_SIZE > PAYLOAD_SIZE)
|
2013-08-11 14:11:11 +02:00
|
|
|
#undef PAYLOAD_SIZE
|
2014-04-18 16:05:23 +02:00
|
|
|
#define PAYLOAD_SIZE (MACA_MAX_PAYLOAD_SIZE)
|
2013-08-11 14:11:11 +02:00
|
|
|
#endif
|
2013-06-10 12:40:59 +02:00
|
|
|
#endif
|
2013-08-08 11:08:33 +02:00
|
|
|
#ifdef MODULE_NATIVENET
|
|
|
|
#if (NATIVE_MAX_DATA_LENGTH > PAYLOAD_SIZE)
|
2013-08-15 19:39:39 +02:00
|
|
|
#undef PAYLOAD_SIZE
|
2013-08-08 11:08:33 +02:00
|
|
|
#define PAYLOAD_SIZE (NATIVE_MAX_DATA_LENGTH)
|
|
|
|
#endif
|
|
|
|
#endif
|
2010-11-21 14:00:24 +01:00
|
|
|
/* The maximum of threads to register */
|
2010-12-03 18:42:03 +01:00
|
|
|
#define TRANSCEIVER_MAX_REGISTERED (4)
|
2010-11-21 14:00:24 +01:00
|
|
|
|
2010-11-27 19:27:05 +01:00
|
|
|
/* The size of the message queue between driver and transceiver (must be power
|
|
|
|
* of two */
|
2010-12-03 18:42:03 +01:00
|
|
|
#define TRANSCEIVER_MSG_BUFFER_SIZE (32)
|
2010-11-27 19:27:05 +01:00
|
|
|
|
2014-06-21 14:51:04 +02:00
|
|
|
/** The maximum number of ignored addresses */
|
|
|
|
#define TRANSCEIVER_MAX_IGNORED_ADDR (10)
|
|
|
|
|
2013-06-10 12:40:59 +02:00
|
|
|
/**
|
|
|
|
* @brief All supported transceivers
|
|
|
|
*/
|
2013-07-12 12:31:16 +02:00
|
|
|
#define TRANSCEIVER_NONE (0x0) ///< Invalid
|
|
|
|
#define TRANSCEIVER_CC1100 (0x01) ///< CC110X transceivers
|
|
|
|
#define TRANSCEIVER_CC1020 (0x02) ///< CC1020 transceivers
|
|
|
|
#define TRANSCEIVER_CC2420 (0x04) ///< CC2420 transceivers
|
|
|
|
#define TRANSCEIVER_MC1322X (0x08) ///< MC1322X transceivers
|
2013-08-15 19:07:14 +02:00
|
|
|
#define TRANSCEIVER_NATIVE (0x10) ///< NATIVE transceivers
|
|
|
|
#define TRANSCEIVER_AT86RF231 (0x20) ///< AT86RF231 transceivers
|
2013-06-10 12:40:59 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Data type for transceiver specification
|
|
|
|
*/
|
|
|
|
typedef uint16_t transceiver_type_t;
|
|
|
|
|
2014-01-21 17:08:27 +01:00
|
|
|
/**
|
|
|
|
* @brief Data type to represent the transceiver's EUI-64.
|
|
|
|
*/
|
|
|
|
typedef uint64_t transceiver_eui64_t;
|
|
|
|
|
2010-11-21 14:00:24 +01:00
|
|
|
/**
|
|
|
|
* @brief Message types for transceiver interface
|
|
|
|
*/
|
2010-11-19 20:10:09 +01:00
|
|
|
enum transceiver_msg_type_t {
|
2012-02-08 17:14:50 +01:00
|
|
|
/* Message types for driver <-> transceiver communication */
|
2010-11-24 11:20:27 +01:00
|
|
|
RCV_PKT_CC1020, ///< packet was received by CC1020 transceiver
|
|
|
|
RCV_PKT_CC1100, ///< packet was received by CC1100 transceiver
|
2013-06-10 12:40:59 +02:00
|
|
|
RCV_PKT_CC2420, ///< packet was received by CC2420 transceiver
|
2013-07-23 15:27:12 +02:00
|
|
|
RCV_PKT_MC1322X, ///< packet was received by mc1322x transceiver
|
2013-08-15 19:07:14 +02:00
|
|
|
RCV_PKT_NATIVE, ///< packet was received by native transceiver
|
2013-07-12 12:31:16 +02:00
|
|
|
RCV_PKT_AT86RF231, ///< packet was received by AT86RF231 transceiver
|
2010-11-23 11:37:13 +01:00
|
|
|
|
2012-02-08 17:14:50 +01:00
|
|
|
/* Message types for transceiver <-> upper layer communication */
|
2010-11-23 11:37:13 +01:00
|
|
|
PKT_PENDING, ///< packet pending in transceiver buffer
|
2010-11-21 14:00:24 +01:00
|
|
|
SND_PKT, ///< request for sending a packet
|
|
|
|
SND_ACK, ///< request for sending an acknowledgement
|
2010-11-23 11:37:13 +01:00
|
|
|
SWITCH_RX, ///< switch transceiver to RX sate
|
|
|
|
POWERDOWN, ///< power down transceiver
|
2010-11-24 21:45:38 +01:00
|
|
|
GET_CHANNEL, ///< Get current channel
|
|
|
|
SET_CHANNEL, ///< Set a new channel
|
2010-11-26 10:23:46 +01:00
|
|
|
GET_ADDRESS, ///< Get the radio address
|
|
|
|
SET_ADDRESS, ///< Set the radio address
|
2014-01-21 17:08:27 +01:00
|
|
|
GET_LONG_ADDR, ///< Get the long radio address, if existing
|
|
|
|
SET_LONG_ADDR, ///< Set the long radio address, if supported by hardware
|
2010-11-27 10:50:18 +01:00
|
|
|
SET_MONITOR, ///< Set transceiver to monitor mode (disable address checking)
|
2013-06-10 12:40:59 +02:00
|
|
|
GET_PAN, ///< Get current pan
|
|
|
|
SET_PAN, ///< Set a new pan
|
2010-11-23 11:37:13 +01:00
|
|
|
|
2012-02-08 17:14:50 +01:00
|
|
|
/* debug message types */
|
|
|
|
DBG_IGN, ///< add a physical address to the ignore list
|
|
|
|
|
2010-11-23 11:37:13 +01:00
|
|
|
/* Error messages */
|
2010-11-26 17:06:54 +01:00
|
|
|
ENOBUFFER, ///< No buffer left
|
2013-11-21 20:19:29 +01:00
|
|
|
|
|
|
|
/* reserve message types for higher layer notifications */
|
|
|
|
UPPER_LAYER_1, ///< reserved
|
|
|
|
UPPER_LAYER_2, ///< reserved
|
|
|
|
UPPER_LAYER_3, ///< reserved
|
|
|
|
UPPER_LAYER_4, ///< reserved
|
|
|
|
UPPER_LAYER_5, ///< reserved
|
2010-11-19 20:10:09 +01:00
|
|
|
};
|
|
|
|
|
2010-11-21 14:00:24 +01:00
|
|
|
/**
|
|
|
|
* @brief Manage registered threads per transceiver
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
transceiver_type_t transceivers; ///< the tranceivers the thread is registered for
|
|
|
|
int pid; ///< the thread's pid
|
|
|
|
} registered_t;
|
2010-11-19 20:10:09 +01:00
|
|
|
|
2010-11-21 14:00:24 +01:00
|
|
|
typedef struct {
|
|
|
|
transceiver_type_t transceivers;
|
2010-11-24 21:45:38 +01:00
|
|
|
void *data;
|
2013-08-09 10:26:00 +02:00
|
|
|
} transceiver_command_t;
|
2010-11-19 20:10:09 +01:00
|
|
|
|
2010-11-27 11:09:42 +01:00
|
|
|
/* The transceiver thread's pid */
|
|
|
|
extern int transceiver_pid;
|
2010-11-19 20:10:09 +01:00
|
|
|
|
2014-06-21 14:51:04 +02:00
|
|
|
/** An array of ignored link layer addresses */
|
|
|
|
extern radio_address_t transceiver_ignored_addr[TRANSCEIVER_MAX_IGNORED_ADDR];
|
|
|
|
|
2010-11-21 14:00:24 +01:00
|
|
|
/**
|
2013-06-22 05:11:53 +02:00
|
|
|
* @brief Initializes the transceiver module for certain transceiver types
|
2010-11-21 14:00:24 +01:00
|
|
|
*
|
|
|
|
* @param transceivers Specifies all transceivers to init
|
|
|
|
**/
|
|
|
|
void transceiver_init(transceiver_type_t transceivers);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Runs the transceiver thread
|
2013-08-16 13:12:12 +02:00
|
|
|
*
|
|
|
|
* @return The transceiver thread's pid
|
2010-11-21 14:00:24 +01:00
|
|
|
*/
|
2010-11-23 11:37:13 +01:00
|
|
|
int transceiver_start(void);
|
2010-11-21 14:00:24 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief register a thread for events from certain transceivers
|
|
|
|
*
|
|
|
|
* @param transceivers The transceiver types to register for
|
|
|
|
* @param pid The pid of the thread to register
|
|
|
|
*
|
2013-08-16 13:12:12 +02:00
|
|
|
* @return 1 on success, 0 otherwise
|
2010-11-21 14:00:24 +01:00
|
|
|
*/
|
|
|
|
uint8_t transceiver_register(transceiver_type_t transceivers, int pid);
|
|
|
|
|
2014-07-08 15:29:31 +02:00
|
|
|
/**
|
|
|
|
* @brief unregister a thread for events from certain transceivers
|
|
|
|
*
|
|
|
|
* @param transceivers The transceiver types to register for
|
|
|
|
* @param pid The pid of the thread to register
|
|
|
|
*
|
|
|
|
* @return 1 on success, 0 otherwise
|
|
|
|
*/
|
|
|
|
uint8_t transceiver_unregister(transceiver_type_t transceivers, int pid);
|
|
|
|
|
2010-11-19 20:10:09 +01:00
|
|
|
#endif /* TRANSCEIVER_H */
|
2014-04-16 12:09:23 +02:00
|
|
|
/** @} */
|