mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
326 lines
10 KiB
C
326 lines
10 KiB
C
|
/**
|
||
|
* Copyright (C) 2014 INRIA
|
||
|
*
|
||
|
* This source code is licensed under the GNU Lesser General Public License,
|
||
|
* Version 2. See the file LICENSE for more details.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @ingroup drivers
|
||
|
* @{
|
||
|
* @file radio_driver.h
|
||
|
* @brief API definitions for 802.15.4 radio transceivers' drivers
|
||
|
* @author Kévin Roussel <Kevin.Roussel@inria.fr>
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#ifndef IEEE802154_RADIO_DRIVER_API_
|
||
|
#define IEEE802154_RADIO_DRIVER_API_
|
||
|
|
||
|
#include <stdint.h>
|
||
|
#include <stdbool.h>
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief Callback function type for receiving incoming packets
|
||
|
* from 802.15.4 radio transceiver.
|
||
|
*
|
||
|
* @param[in] buf Pointer to the buffer containing the incoming
|
||
|
* 802.15.4 packet's raw data.
|
||
|
* @param[in] len Length (in bytes) of the incoming packet's raw data.
|
||
|
*
|
||
|
*/
|
||
|
typedef void (* receive_802154_packet_callback_t)(void *buf, unsigned int len);
|
||
|
|
||
|
/**
|
||
|
* @brief Kind of packet to prepare/configure for transmission.
|
||
|
*
|
||
|
*/
|
||
|
typedef enum {
|
||
|
/** Beacon packet */
|
||
|
PACKET_KIND_BEACON,
|
||
|
|
||
|
/** Standard data packet */
|
||
|
PACKET_KIND_DATA,
|
||
|
|
||
|
/** Acknowledgement packet */
|
||
|
PACKET_KIND_ACK,
|
||
|
|
||
|
/** MAC command */
|
||
|
PACKET_KIND_MAC_CMD,
|
||
|
|
||
|
/** invalid packet kind */
|
||
|
PACKET_KIND_INVALID = -1
|
||
|
|
||
|
} ieee802154_packet_kind_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Return values for packet emission function of 802.15.4 radio driver.
|
||
|
*
|
||
|
*/
|
||
|
typedef enum {
|
||
|
/** Transmission completed successfully */
|
||
|
RADIO_TX_OK,
|
||
|
|
||
|
/** Transmission buffer underflow (forgot to call @c load_tx()
|
||
|
before @c transmit() ) */
|
||
|
RADIO_TX_UNDERFLOW,
|
||
|
|
||
|
/** Transmission failed because of collision on radio medium */
|
||
|
RADIO_TX_COLLISION,
|
||
|
|
||
|
/** Transmission supposedly failed since no ACK packet
|
||
|
has been received as response */
|
||
|
RADIO_TX_NOACK,
|
||
|
|
||
|
/** Transmission failed because of an unexpected (fatal?) error */
|
||
|
RADIO_TX_ERROR,
|
||
|
|
||
|
} radio_tx_status_t;
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief Definition of an IEEE 802.15.4 node address.
|
||
|
*
|
||
|
* @details The @c union allows to choose between PAN-centric addressing
|
||
|
* ("volatile" 16-bit address and 16-bit PAN ID), or canonical
|
||
|
* IEEE 64-bit ("long") addressing.
|
||
|
*
|
||
|
*/
|
||
|
typedef union {
|
||
|
/** @brief PAN-centric ("short") addressing mode */
|
||
|
struct {
|
||
|
/** @brief Address assigned to the node within its current PAN */
|
||
|
uint16_t addr;
|
||
|
/** @brief ID of the PAN to which the node is currently associated */
|
||
|
uint16_t id;
|
||
|
} pan;
|
||
|
/** @brief 64-bit ("long") addressing mode */
|
||
|
uint64_t long_addr;
|
||
|
} ieee802154_node_addr_t;
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief IEEE 802.15.4 radio driver API definition.
|
||
|
*
|
||
|
* @details This is the set of functions that must be implemented
|
||
|
* by any driver for a 802.15.4 radio transceiver.
|
||
|
*
|
||
|
*/
|
||
|
typedef struct {
|
||
|
/**
|
||
|
* @brief Turn radio transceiver on.
|
||
|
*
|
||
|
* @return @c true if radio transceiver was actually started;
|
||
|
* @c false if an error prevented transceiver to start.
|
||
|
*/
|
||
|
bool (* on)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Turn radio transceiver off.
|
||
|
*/
|
||
|
void (* off)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Indicate whether the radio transceiver is up and running.
|
||
|
*
|
||
|
* @return @c true if radio transceiver is on;
|
||
|
* @c false if it is off.
|
||
|
*/
|
||
|
bool (* is_on)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Load the tranceiver TX buffer with the given
|
||
|
* IEEE 802.15.4 packet.
|
||
|
*
|
||
|
* @param[in] kind Kind of packet to transmit.
|
||
|
* @param[in] dest Address of the node to which the packet is sent.
|
||
|
* @param[in] use_long_addr @c true to use the 64-bit address mode
|
||
|
* with @c dest param; @c false to use
|
||
|
* "short" PAN-centric mode.
|
||
|
* @param[in] wants_ack @c true to request an acknowledgement
|
||
|
* from the receiving node for this packet;
|
||
|
* @c false otherwise.
|
||
|
* @param[in] buf Pointer to the buffer containing the payload
|
||
|
* of the 802.15.4 packet to transmit.
|
||
|
* The frame header (i.e.: FCS, sequence number,
|
||
|
* src and dest PAN and addresses) is inserted
|
||
|
* using values in accord with @c kind parameter
|
||
|
* and transceiver configuration.
|
||
|
* @param[in] len Length (in bytes) of the outgoing packet payload.
|
||
|
*
|
||
|
* @return @c true if the transceiver TX buffer was loaded correctly;
|
||
|
* @c false otherwise (transceiver error).
|
||
|
*/
|
||
|
bool (* load_tx)(ieee802154_packet_kind_t kind,
|
||
|
ieee802154_node_addr_t dest, bool use_long_addr,
|
||
|
bool wants_ack,
|
||
|
void *buf, unsigned int len);
|
||
|
|
||
|
/**
|
||
|
* @brief Transmit the data loaded into the transceiver TX buffer.
|
||
|
*
|
||
|
* @return The outcome of this packet's transmission.
|
||
|
* @see radio_tx_status_t
|
||
|
*/
|
||
|
radio_tx_status_t (* transmit)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Transmit the given IEEE 802.15.4 packet,
|
||
|
* by calling successively functions @c load_tx()
|
||
|
* and @c transmit().
|
||
|
*
|
||
|
* @param[in] kind Kind of packet to transmit.
|
||
|
* @param[in] dest Address of the node to which the packet is sent.
|
||
|
* @param[in] use_long_addr @c true to use the 64-bit address mode
|
||
|
* with @c dest param; @c false to use
|
||
|
* "short" PAN-centric mode.
|
||
|
* @param[in] wants_ack @c true to request an acknowledgement
|
||
|
* from the receiving node for this packet;
|
||
|
* @c false otherwise.
|
||
|
* @param[in] buf Pointer to the buffer containing the payload
|
||
|
* of the 802.15.4 packet to transmit.
|
||
|
* The frame header (i.e.: FCS, sequence number,
|
||
|
* src and dest PAN and addresses) is inserted
|
||
|
* using values in accord with @c kind parameter
|
||
|
* and transceiver configuration.
|
||
|
* @param[in] len Length (in bytes) of the outgoing packet payload.
|
||
|
*
|
||
|
* @return The outcome of this packet's transmission.
|
||
|
* @see radio_tx_status_t
|
||
|
*/
|
||
|
radio_tx_status_t (* send)(ieee802154_packet_kind_t,
|
||
|
ieee802154_node_addr_t dest, bool use_long_addr,
|
||
|
bool wants_ack,
|
||
|
void *buf, unsigned int len);
|
||
|
|
||
|
/**
|
||
|
* @brief Define the function to be called back the radio transceiver
|
||
|
* has received a incoming packet.
|
||
|
*
|
||
|
* @param[in] recv_func the callback function to invoke for each
|
||
|
* packet received by the radio transceiver.
|
||
|
* @see receive_802154_packet_callback_t
|
||
|
*/
|
||
|
void (* set_receive_callback)(receive_802154_packet_callback_t recv_func);
|
||
|
|
||
|
/**
|
||
|
* @brief Switch the radio transceiver to receive mode.
|
||
|
*/
|
||
|
void (* switch_to_rx)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the 802.15.4 channel to be used
|
||
|
* by the radio transceiver as medium.
|
||
|
*
|
||
|
* @param[in] chan Channel to switch to.
|
||
|
* Usual values are 0 (868 MHz band),
|
||
|
* 1 to 10 (915 MHz band), and
|
||
|
* 11 to 26 (2.4 GHz band).
|
||
|
*/
|
||
|
void (* set_channel)(unsigned int chan);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the 802.15.4 channel currently used
|
||
|
* by the radio transceiver as medium.
|
||
|
*/
|
||
|
unsigned int (* get_channel)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the 16-bit short address to be used by
|
||
|
* the radio transceiver within the current PAN.
|
||
|
*
|
||
|
* @param[in] addr Address to use.
|
||
|
*/
|
||
|
void (* set_address)(uint16_t addr);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the 16-bit short address currently used by
|
||
|
* the radio transceiver within the current PAN.
|
||
|
*/
|
||
|
uint16_t (* get_address)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the 64-bit long ("extended") address
|
||
|
* to be used by the radio transceiver.
|
||
|
*
|
||
|
* @param[in] addr Address to use.
|
||
|
*/
|
||
|
void (* set_long_address)(uint64_t addr);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the 64-bit long ("extended") address
|
||
|
* currently used by the radio transceiver.
|
||
|
*/
|
||
|
uint64_t (* get_long_address)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the 16-bit PAN ID within which the radio
|
||
|
* transceiver shall operate.
|
||
|
*
|
||
|
* @param[in] pan PAN ID to use.
|
||
|
*/
|
||
|
void (* set_pan_id)(uint16_t pan);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the 16-bit PAN ID within which the radio
|
||
|
* transceiver currently operates.
|
||
|
*/
|
||
|
uint16_t (* get_pan_id)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the transmission power of the radio transceiver.
|
||
|
*
|
||
|
* @param[in] pow Output power to use (in dB).
|
||
|
*/
|
||
|
void (* set_tx_power)(int pow);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the transmission (output) power currently used
|
||
|
* by the radio transceiver (in dB).
|
||
|
*/
|
||
|
int (* get_tx_power)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Indicates if the radio medium is available for transmission
|
||
|
* ("Clear Channel Assessment").
|
||
|
*
|
||
|
* @return @c true if radio medium is "clear" (available);
|
||
|
* @c false if another transmission is already running.
|
||
|
*/
|
||
|
bool (* channel_is_clear)(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the radio transceiver in or out of "promiscuous mode"
|
||
|
* (i.e. reception of all packets without regard for their
|
||
|
* intended destination).
|
||
|
*
|
||
|
* @param[in] monitor Set to @c true to put the transceiver in
|
||
|
* "promiscuous mode" (a.k.a. monitor mode);
|
||
|
* @c false to only receive packets actually
|
||
|
* destined to the currently used address (i.e.:
|
||
|
* to activate hardware address-decoding).
|
||
|
*/
|
||
|
void (* set_promiscuous_mode)(bool monitor);
|
||
|
|
||
|
/**
|
||
|
* @brief Indicates if the radio medium is currently in "promiscuous
|
||
|
* mode" (i.e. receiving all packets without regard for their
|
||
|
* intended destination).
|
||
|
*
|
||
|
* @return @c true if the transceiver is in "promiscuous mode";
|
||
|
* @c false if only packets actually destined to the
|
||
|
* current transceiver are received (i.e. hardware
|
||
|
* address-decoding is active).
|
||
|
*/
|
||
|
bool (* in_promiscuous_mode)(void);
|
||
|
|
||
|
} ieee802154_radio_driver_t;
|
||
|
|
||
|
|
||
|
#endif /* IEEE802154_RADIO_DRIVER_API_ */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|