1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/drivers/include/radio_driver.h

326 lines
10 KiB
C
Raw Normal View History

/**
* 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_ */
/**
* @}
*/