1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/include/transceiver.h

299 lines
7.9 KiB
C

/*
* Copyright (C) 2010 - 2014 Oliver Hahm
*
* 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 sys_transceiver Transceiver
* @ingroup sys
*
* @brief The transceiver module implements a generic link abstraction to
* any radio interface.
*
* @{
*
* @file
* @author Oliver Hahm <oliver.hahm@inria.fr>
*/
#ifndef TRANSCEIVER_H
#define TRANSCEIVER_H
#include "kernel_types.h"
#include "radio/types.h"
/* supported transceivers *
* NOTE: necessary to include here again due to
* https://github.com/RIOT-OS/RIOT/issues/117 */
#ifdef MODULE_CC110X
#include "cc110x.h"
#ifndef TRANSCEIVER_DEFAULT
#define TRANSCEIVER_DEFAULT TRANSCEIVER_CC1100
#endif
#endif
#ifdef MODULE_CC110X_LEGACY_CSMA
#include "cc110x_legacy_csma.h"
#ifndef TRANSCEIVER_DEFAULT
#define TRANSCEIVER_DEFAULT TRANSCEIVER_CC1100
#endif
#endif
#ifdef MODULE_CC110X_LEGACY
#include "cc110x_legacy.h"
#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
#endif
#ifdef MODULE_CC2420
#include "cc2420.h"
#ifndef TRANSCEIVER_DEFAULT
#define TRANSCEIVER_DEFAULT TRANSCEIVER_CC2420
#endif
#endif
#ifdef MODULE_MC1322X
#include "mc1322x.h"
#include "maca.h"
#include "maca_packet.h"
#ifndef TRANSCEIVER_DEFAULT
#define TRANSCEIVER_DEFAULT TRANSCEIVER_MC1322X
#endif
#endif
#ifdef MODULE_NATIVENET
#include "nativenet.h"
#include "nativenet_internal.h"
#ifndef TRANSCEIVER_DEFAULT
#define TRANSCEIVER_DEFAULT TRANSCEIVER_NATIVE
#endif
#endif
#ifdef MODULE_AT86RF231
#include "at86rf231.h"
#ifndef TRANSCEIVER_DEFAULT
#define TRANSCEIVER_DEFAULT TRANSCEIVER_AT86RF231
#endif
#endif
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Stack size for transceiver thread
*/
#ifndef TRANSCEIVER_STACK_SIZE
#define TRANSCEIVER_STACK_SIZE (KERNEL_CONF_STACKSIZE_DEFAULT)
#endif
/**
* @name Defines the upper payload limit for all available transceivers
* @{
*/
#ifndef PAYLOAD_SIZE
#define PAYLOAD_SIZE (0)
#endif
#ifdef MODULE_CC110X_LEGACY_CSMA
#if (CC1100_MAX_DATA_LENGTH > PAYLOAD_SIZE)
#undef PAYLOAD_SIZE
#define PAYLOAD_SIZE (CC1100_MAX_DATA_LENGTH)
#endif
#endif
#if (defined(MODULE_CC110X) || defined(MODULE_CC110X_LEGACY))
#if (CC1100_MAX_DATA_LENGTH > PAYLOAD_SIZE)
#undef PAYLOAD_SIZE
#define PAYLOAD_SIZE (CC1100_MAX_DATA_LENGTH)
#endif
#endif
#ifdef MODULE_CC2420
#if (CC2420_MAX_DATA_LENGTH > PAYLOAD_SIZE)
#undef PAYLOAD_SIZE
#define PAYLOAD_SIZE (CC2420_MAX_DATA_LENGTH)
#endif
#endif
#ifdef MODULE_AT86RF231
#if (AT86RF231_MAX_DATA_LENGTH > PAYLOAD_SIZE)
#undef PAYLOAD_SIZE
#define PAYLOAD_SIZE (AT86RF231_MAX_DATA_LENGTH)
#endif
#endif
#ifdef MODULE_MC1322X
#if (MACA_MAX_PAYLOAD_SIZE > PAYLOAD_SIZE)
#undef PAYLOAD_SIZE
#define PAYLOAD_SIZE (MACA_MAX_PAYLOAD_SIZE)
#endif
#endif
#ifdef MODULE_NATIVENET
#if (NATIVE_MAX_DATA_LENGTH > PAYLOAD_SIZE)
#undef PAYLOAD_SIZE
#define PAYLOAD_SIZE (NATIVE_MAX_DATA_LENGTH)
#endif
#endif
/**
* @}
*/
/**
* @brief The maximum of threads to register
*/
#define TRANSCEIVER_MAX_REGISTERED (4)
/**
* @brief The size of the message queue between driver and transceiver (must be
* power of two
*/
#define TRANSCEIVER_MSG_BUFFER_SIZE (32)
/**
* @brief The maximum number of ignored addresses
*/
#define TRANSCEIVER_MAX_IGNORED_ADDR (10)
/**
* @name All supported transceivers
* @{
*/
#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 */
#define TRANSCEIVER_NATIVE (0x10) /**< NATIVE transceivers */
#define TRANSCEIVER_AT86RF231 (0x20) /**< AT86RF231 transceivers */
/**
* @}
*/
/**
* @brief Data type for transceiver specification
*/
typedef uint16_t transceiver_type_t;
/**
* @brief Data type to represent the transceiver's EUI-64.
*/
typedef uint64_t transceiver_eui64_t;
/**
* @brief Message types for transceiver interface
*/
enum transceiver_msg_type_t {
/* Message types for driver <-> transceiver communication */
RCV_PKT_CC1020, /**< packet was received by CC1020 transceiver */
RCV_PKT_CC1100, /**< packet was received by CC1100 transceiver */
RCV_PKT_CC2420, /**< packet was received by CC2420 transceiver */
RCV_PKT_MC1322X, /**< packet was received by mc1322x transceiver */
RCV_PKT_NATIVE, /**< packet was received by native transceiver */
RCV_PKT_AT86RF231, /**< packet was received by AT86RF231 transceiver */
/* Message types for transceiver <-> upper layer communication */
PKT_PENDING, /**< packet pending in transceiver buffer */
SND_PKT, /**< request for sending a packet */
SND_ACK, /**< request for sending an acknowledgement */
SWITCH_RX, /**< switch transceiver to RX sate */
POWERDOWN, /**< power down transceiver */
GET_CHANNEL, /**< Get current channel */
SET_CHANNEL, /**< Set a new channel */
GET_ADDRESS, /**< Get the radio address */
SET_ADDRESS, /**< Set the radio address */
GET_LONG_ADDR, /**< Get the long radio address, if existing */
SET_LONG_ADDR, /**< Set the long radio address, if supported by hardware */
SET_MONITOR, /**< Set transceiver to monitor mode (disable address
checking) */
GET_PAN, /**< Get current pan */
SET_PAN, /**< Set a new pan */
/* debug message types */
DBG_IGN, /**< add a physical address to the ignore list */
/* Error messages */
ENOBUFFER, /**< No buffer left */
/* 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 */
};
/**
* @brief Manage registered threads per transceiver
*/
typedef struct {
transceiver_type_t transceivers; /**< the tranceivers the thread is
registered for */
kernel_pid_t pid; /**< the thread's pid */
} registered_t;
/**
* @brief Transceiver command struct
*/
typedef struct {
transceiver_type_t transceivers; /**< Bitfield of targeted transceivers */
void *data; /**< The payload of the command */
} transceiver_command_t;
/**
* @brief The transceiver thread's pid
*/
extern volatile kernel_pid_t transceiver_pid;
/**
* @brief An array of ignored link layer addresses
*/
extern radio_address_t transceiver_ignored_addr[TRANSCEIVER_MAX_IGNORED_ADDR];
/**
* @brief Initializes the transceiver module for certain transceiver types
*
* @param transceivers Specifies all transceivers to init
**/
void transceiver_init(transceiver_type_t transceivers);
/**
* @brief Runs the transceiver thread
*
* @return The transceiver thread's pid
*/
kernel_pid_t transceiver_start(void);
/**
* @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
*
* @return 1 on success, 0 otherwise
*/
uint8_t transceiver_register(transceiver_type_t transceivers, kernel_pid_t pid);
/**
* @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, kernel_pid_t pid);
#ifdef __cplusplus
}
#endif
#endif /* TRANSCEIVER_H */
/** @} */