2014-09-15 18:22:01 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2014-09-29 20:34:38 +02:00
|
|
|
/**
|
2014-10-20 16:46:53 +02:00
|
|
|
* @defgroup drivers_at86rf231 at86rf231
|
2014-09-29 20:34:38 +02:00
|
|
|
* @ingroup drivers
|
|
|
|
* @brief Device driver for the Atmel AT86RF231 radio
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Interface definition for the AT86RF231 device driver
|
|
|
|
*
|
|
|
|
* @author Alaeddine Weslati <alaeddine.weslati@inria.fr>
|
|
|
|
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2013-07-12 12:31:16 +02:00
|
|
|
#ifndef AT86RF231_H_
|
|
|
|
#define AT86RF231_H_
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2014-08-12 17:21:42 +02:00
|
|
|
#include "kernel_types.h"
|
2014-07-07 00:00:16 +02:00
|
|
|
#include "board.h"
|
2014-01-31 09:50:34 +01:00
|
|
|
#include "radio/types.h"
|
2013-09-18 14:13:19 +02:00
|
|
|
#include "ieee802154_frame.h"
|
2014-02-11 17:15:03 +01:00
|
|
|
#include "at86rf231/at86rf231_settings.h"
|
2014-09-29 20:34:38 +02:00
|
|
|
#include "periph/gpio.h"
|
2014-10-20 16:46:53 +02:00
|
|
|
#include "netdev/802154.h"
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Maximum length of a frame on at86rf231
|
|
|
|
*/
|
|
|
|
#define AT86RF231_MAX_PKT_LENGTH (127)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum payload length
|
|
|
|
* @details Assuming intra PAN short address mode
|
|
|
|
* results in 2 bytes FCF
|
|
|
|
* + 1 bytes SEQNr
|
|
|
|
* + 2 bytes PAN Id
|
|
|
|
* + 2 bytes destination address
|
|
|
|
* + 2 bytes source address
|
|
|
|
*/
|
|
|
|
#define AT86RF231_MAX_DATA_LENGTH (118)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Broadcast address
|
|
|
|
*/
|
|
|
|
#define AT86RF231_BROADCAST_ADDRESS (0xFFFF)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief at86rf231's lowest supported channel
|
|
|
|
*/
|
|
|
|
#define AT86RF231_MIN_CHANNEL (11)
|
2013-07-12 12:31:16 +02:00
|
|
|
|
|
|
|
/**
|
2014-10-20 16:46:53 +02:00
|
|
|
* @brief at86rf231's highest supported channel
|
2013-07-12 12:31:16 +02:00
|
|
|
*/
|
2014-10-20 16:46:53 +02:00
|
|
|
#define AT86RF231_MAX_CHANNEL (26)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Structure to represent a at86rf231 packet.
|
|
|
|
*/
|
|
|
|
typedef struct __attribute__((packed))
|
2013-08-15 19:13:00 +02:00
|
|
|
{
|
2014-10-20 16:46:53 +02:00
|
|
|
/** @{ */
|
|
|
|
uint8_t length; /**< the length of the frame of the frame including fcs*/
|
|
|
|
ieee802154_frame_t frame; /**< the ieee802154 frame */
|
2015-01-12 16:40:21 +01:00
|
|
|
uint8_t rssi; /**< the rssi value */
|
2014-10-20 16:46:53 +02:00
|
|
|
uint8_t crc; /**< 1 if crc was successfull, 0 otherwise */
|
|
|
|
uint8_t lqi; /**< the link quality indicator */
|
|
|
|
/** @} */
|
|
|
|
} at86rf231_packet_t;
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
extern netdev_t at86rf231_netdev; /**< netdev representation of this driver */
|
2014-07-17 15:42:30 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief States to be assigned to `driver_state`
|
|
|
|
* @{
|
|
|
|
*/
|
2014-07-17 15:42:30 +02:00
|
|
|
#define AT_DRIVER_STATE_DEFAULT (0)
|
|
|
|
#define AT_DRIVER_STATE_SENDING (1)
|
2014-10-20 16:46:53 +02:00
|
|
|
/** @} */
|
2014-07-17 15:42:30 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief To keep state inside of at86rf231 driver
|
|
|
|
* @details This variable is used to determine if a TRX_END IRQ from
|
|
|
|
* the radio transceiver has to be interpreted as end of
|
|
|
|
* sending or reception.
|
|
|
|
*/
|
|
|
|
extern uint8_t driver_state;
|
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Initialize the at86rf231 transceiver
|
|
|
|
*/
|
|
|
|
int at86rf231_initialize(netdev_t *dev);
|
|
|
|
|
|
|
|
#ifdef MODULE_TRANSCEIVER
|
|
|
|
/**
|
|
|
|
* @brief Init the at86rf231 for use with RIOT's transceiver module.
|
|
|
|
*
|
|
|
|
* @param[in] tpid The PID of the transceiver thread.
|
|
|
|
*/
|
|
|
|
|
2014-07-06 22:57:56 +02:00
|
|
|
void at86rf231_init(kernel_pid_t tpid);
|
2014-10-20 16:46:53 +02:00
|
|
|
#endif
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Turn at86rf231 on.
|
|
|
|
*
|
|
|
|
* @return 1 if the radio was correctly turned on; 0 otherwise.
|
|
|
|
*/
|
|
|
|
int at86rf231_on(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Turn at86rf231 off.
|
|
|
|
*/
|
|
|
|
void at86rf231_off(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Indicate if the at86rf231 is on.
|
|
|
|
*
|
|
|
|
* @return 1 if the radio transceiver is on (active); 0 otherwise.
|
|
|
|
*/
|
|
|
|
int at86rf231_is_on(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Switches the at86rf231 into receive mode.
|
|
|
|
*/
|
|
|
|
void at86rf231_switch_to_rx(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Turns monitor (promiscuous) mode on or off.
|
|
|
|
*
|
|
|
|
* @param[in] mode The desired mode:
|
|
|
|
* 1 for monitor (promiscuous) mode;
|
|
|
|
* 0 for normal (auto address-decoding) mode.
|
|
|
|
*/
|
|
|
|
void at86rf231_set_monitor(int mode);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Indicate if the at86rf231 is in monitor (promiscuous) mode.
|
|
|
|
*
|
|
|
|
* @return 1 if the transceiver is in monitor (promiscuous) mode;
|
|
|
|
* 0 if it is in normal (auto address-decoding) mode.
|
|
|
|
*/
|
|
|
|
int at86rf231_get_monitor(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the channel of the at86rf231.
|
|
|
|
*
|
|
|
|
* @param[in] chan The desired channel, valid channels are from 11 to 26.
|
|
|
|
*
|
|
|
|
* @return The tuned channel after calling, or -1 on error.
|
|
|
|
*/
|
|
|
|
int at86rf231_set_channel(unsigned int chan);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the channel of the at86rf231.
|
|
|
|
*
|
|
|
|
* @return The tuned channel.
|
|
|
|
*/
|
|
|
|
unsigned int at86rf231_get_channel(void);
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Sets the short address of the at86rf231.
|
|
|
|
*
|
|
|
|
* @param[in] addr The desired address.
|
|
|
|
*
|
|
|
|
* @return The set address after calling.
|
|
|
|
*/
|
|
|
|
uint16_t at86rf231_set_address(uint16_t addr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets the current short address of the at86rf231.
|
|
|
|
*
|
|
|
|
* @return The current short address.
|
|
|
|
*/
|
|
|
|
uint16_t at86rf231_get_address(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sets the IEEE long address of the at86rf231.
|
|
|
|
*
|
|
|
|
* @param[in] addr The desired address.
|
|
|
|
*
|
|
|
|
* @return The set address after calling.
|
|
|
|
*/
|
|
|
|
uint64_t at86rf231_set_address_long(uint64_t addr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets the current IEEE long address of the at86rf231.
|
|
|
|
*
|
|
|
|
* @return The current IEEE long address.
|
|
|
|
*/
|
|
|
|
uint64_t at86rf231_get_address_long(void);
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Sets the pan ID of the at86rf231.
|
|
|
|
*
|
|
|
|
* @param[in] pan The desired pan ID.
|
|
|
|
*
|
|
|
|
* @return The set pan ID after calling.
|
|
|
|
*/
|
2013-07-12 12:31:16 +02:00
|
|
|
uint16_t at86rf231_set_pan(uint16_t pan);
|
2014-10-20 16:46:53 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets the current IEEE long address of the at86rf231.
|
|
|
|
*
|
|
|
|
* @return The current IEEE long address.
|
|
|
|
*/
|
2013-07-12 12:31:16 +02:00
|
|
|
uint16_t at86rf231_get_pan(void);
|
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Sets the output (TX) power of the at86rf231.
|
|
|
|
*
|
|
|
|
* @param[in] pow The desired TX (output) power in dBm,
|
|
|
|
* valid values are -25 to 0; other values
|
|
|
|
* will be "saturated" into this range.
|
|
|
|
*
|
|
|
|
* @return The set TX (output) power after calling.
|
|
|
|
*/
|
|
|
|
int at86rf231_set_tx_power(int pow);
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Gets the current output (TX) power of the at86rf231.
|
|
|
|
*
|
|
|
|
* @return The current TX (output) power.
|
|
|
|
*/
|
|
|
|
int at86rf231_get_tx_power(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Checks if the radio medium is available/clear to send
|
|
|
|
* ("Clear Channel Assessment" a.k.a. CCA).
|
|
|
|
*
|
|
|
|
* @return a 1 value if radio medium is clear (available),
|
|
|
|
* a 0 value otherwise.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
int at86rf231_channel_is_clear(netdev_t *dev);
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Interrupt handler, gets fired when a RX overflow happens.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void at86rf231_rxoverflow_irq(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Interrupt handler, gets fired when bytes in the RX FIFO are present.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void at86rf231_rx_irq(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sets the function called back when a packet is received.
|
|
|
|
* (Low-level mechanism, parallel to the `transceiver` module).
|
|
|
|
*
|
|
|
|
* @param[in] dev The network device to operate on. (Currently not used)
|
|
|
|
* @param[in] recv_cb callback function for 802.15.4 packet arrival
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -ENODEV if *dev* is not recognized
|
|
|
|
* @return -ENOBUFS, if maximum number of registable callbacks is exceeded
|
|
|
|
*/
|
|
|
|
int at86rf231_add_raw_recv_callback(netdev_t *dev,
|
|
|
|
netdev_802154_raw_packet_cb_t recv_cb);
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Unsets the function called back when a packet is received.
|
|
|
|
* (Low-level mechanism, parallel to the `transceiver` module).
|
|
|
|
*
|
|
|
|
* @param[in] dev The network device to operate on. (Currently not used)
|
|
|
|
* @param[in] recv_cb callback function to unset
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -ENODEV if *dev* is not recognized
|
|
|
|
* @return -ENOBUFS, if maximum number of registable callbacks is exceeded
|
|
|
|
*/
|
|
|
|
int at86rf231_rem_raw_recv_callback(netdev_t *dev,
|
|
|
|
netdev_802154_raw_packet_cb_t recv_cb);
|
2013-07-12 12:31:16 +02:00
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* @brief Sets a function called back when a data packet is received.
|
|
|
|
*
|
|
|
|
* @param[in] dev The network device to operate on. (Currently not used)
|
|
|
|
* @param[in] recv_cb callback function for 802.15.4 data packet arrival
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -ENODEV if *dev* is not recognized
|
|
|
|
* @return -ENOBUFS, if maximum number of registable callbacks is exceeded
|
|
|
|
*/
|
|
|
|
int at86rf231_add_data_recv_callback(netdev_t *dev,
|
|
|
|
netdev_rcv_data_cb_t recv_cb);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Unsets a function called back when a data packet is received.
|
|
|
|
*
|
|
|
|
* @param[in] dev The network device to operate on. (Currently not used)
|
|
|
|
* @param[in] recv_cb callback function to unset
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -ENODEV if *dev* is not recognized
|
|
|
|
* @return -ENOBUFS, if maximum number of registable callbacks is exceeded
|
|
|
|
*/
|
|
|
|
int at86rf231_rem_data_recv_callback(netdev_t *dev,
|
|
|
|
netdev_rcv_data_cb_t recv_cb);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief RX handler, process data from the RX FIFO.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void at86rf231_rx_handler(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Prepare the at86rf231 TX buffer to send with the given packet.
|
|
|
|
*
|
|
|
|
* @param[in] dev The network device to operate on. (Currently not used)
|
|
|
|
* @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 1 to use the 64-bit address mode
|
|
|
|
* with *dest* param; 0 to use
|
|
|
|
* "short" PAN-centric mode.
|
|
|
|
* @param[in] wants_ack 1 to request an acknowledgement
|
|
|
|
* from the receiving node for this packet;
|
|
|
|
* 0 otherwise.
|
|
|
|
* @param[in] upper_layer_hdrs header data from higher network layers from
|
|
|
|
* highest to lowest layer. Must be prepended to
|
|
|
|
* the data stream by the network device. May be
|
|
|
|
* NULL if there are none.
|
|
|
|
* @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 *kind* parameter
|
|
|
|
* and transceiver configuration.
|
|
|
|
* @param[in] len Length (in bytes) of the outgoing packet payload.
|
|
|
|
*
|
|
|
|
* @return @ref netdev_802154_tx_status_t
|
|
|
|
*/
|
|
|
|
netdev_802154_tx_status_t at86rf231_load_tx_buf(netdev_t *dev,
|
|
|
|
netdev_802154_pkt_kind_t kind,
|
|
|
|
netdev_802154_node_addr_t *dest,
|
|
|
|
int use_long_addr,
|
|
|
|
int wants_ack,
|
|
|
|
netdev_hlist_t *upper_layer_hdrs,
|
|
|
|
void *buf,
|
|
|
|
unsigned int len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Transmit the data loaded into the at86rf231 TX buffer.
|
|
|
|
*
|
|
|
|
* @param[in] dev The network device to operate on. (Currently not used)
|
|
|
|
*
|
|
|
|
* @return @ref netdev_802154_tx_status_t
|
|
|
|
*/
|
|
|
|
netdev_802154_tx_status_t at86rf231_transmit_tx_buf(netdev_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Send function, sends a at86rf231_packet_t over the air.
|
|
|
|
*
|
|
|
|
* @param[in] *packet The Packet which will be send.
|
|
|
|
*
|
|
|
|
* @return The count of bytes which are send or -1 on error
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
int16_t at86rf231_send(at86rf231_packet_t *packet);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RX Packet Buffer, read from the transceiver, filled by the at86rf231_rx_handler.
|
|
|
|
*/
|
2013-07-12 12:31:16 +02:00
|
|
|
extern at86rf231_packet_t at86rf231_rx_buffer[AT86RF231_RX_BUF_SIZE];
|
|
|
|
|
2014-10-20 16:46:53 +02:00
|
|
|
/**
|
|
|
|
* Get at86rf231's status byte
|
|
|
|
*/
|
|
|
|
uint8_t at86rf231_get_status(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get at86rf231's TRAC status byte
|
|
|
|
*/
|
|
|
|
uint8_t at86rf231_get_trac_status(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* at86rf231 low-level radio driver definition.
|
|
|
|
*/
|
|
|
|
extern const netdev_802154_driver_t at86rf231_driver;
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2014-09-29 20:34:38 +02:00
|
|
|
#endif /* AT86RF231_H_ */
|
|
|
|
/** @} */
|