2015-04-23 18:36:55 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-08-09 21:24:55 +02:00
|
|
|
* @defgroup drivers_at86rf2xx AT86RF2xx based drivers
|
2017-02-07 13:26:01 +01:00
|
|
|
* @ingroup drivers_netdev
|
2015-04-23 18:36:55 +02:00
|
|
|
*
|
|
|
|
* This module contains drivers for radio devices in Atmel's AT86RF2xx series.
|
|
|
|
* The driver is aimed to work with all devices of this series.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Interface definition for AT86RF2xx based drivers
|
|
|
|
*
|
|
|
|
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
2015-06-01 15:51:50 +02:00
|
|
|
* @author Daniel Krebs <github@daniel-krebs.net>
|
2015-10-22 23:01:26 +02:00
|
|
|
* @author Kévin Roussel <Kevin.Roussel@inria.fr>
|
2015-09-16 18:25:36 +02:00
|
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
2015-04-23 18:36:55 +02:00
|
|
|
*/
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#ifndef AT86RF2XX_H
|
|
|
|
#define AT86RF2XX_H
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
2016-10-18 10:21:54 +02:00
|
|
|
#include <stdbool.h>
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
#include "board.h"
|
2020-04-02 16:48:21 +02:00
|
|
|
#include "kernel_defines.h"
|
2017-02-15 13:07:34 +01:00
|
|
|
#include "net/netdev.h"
|
|
|
|
#include "net/netdev/ieee802154.h"
|
2016-03-18 10:26:33 +01:00
|
|
|
#include "net/gnrc/nettype.h"
|
2015-04-23 18:36:55 +02:00
|
|
|
|
2019-10-21 01:07:44 +02:00
|
|
|
/* we need no peripherals for memory mapped radios */
|
|
|
|
#if !defined(MODULE_AT86RFA1) && !defined(MODULE_AT86RFR2)
|
|
|
|
#include "periph/spi.h"
|
|
|
|
#include "periph/gpio.h"
|
|
|
|
#endif
|
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum possible packet size in byte
|
|
|
|
*/
|
2016-10-21 12:58:50 +02:00
|
|
|
#define AT86RF2XX_MAX_PKT_LENGTH (IEEE802154_FRAME_LEN_MAX)
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name Channel configuration
|
2016-03-18 10:26:33 +01:00
|
|
|
* @{
|
|
|
|
*/
|
2015-08-12 17:08:42 +02:00
|
|
|
#ifdef MODULE_AT86RF212B
|
2015-04-23 18:36:55 +02:00
|
|
|
/* the AT86RF212B has a sub-1GHz radio */
|
2016-10-21 12:58:50 +02:00
|
|
|
#define AT86RF2XX_MIN_CHANNEL (IEEE802154_CHANNEL_MIN_SUBGHZ)
|
|
|
|
#define AT86RF2XX_MAX_CHANNEL (IEEE802154_CHANNEL_MAX_SUBGHZ)
|
2020-02-07 12:02:45 +01:00
|
|
|
#define AT86RF2XX_DEFAULT_CHANNEL (CONFIG_IEEE802154_DEFAULT_SUBGHZ_CHANNEL)
|
2017-10-05 15:14:41 +02:00
|
|
|
/* Page 2 is O-QPSK 100 kbit/s (channel 0), or 250 kbit/s (channels 1-10) */
|
2020-02-07 12:02:45 +01:00
|
|
|
#define AT86RF2XX_DEFAULT_PAGE (CONFIG_IEEE802154_DEFAULT_SUBGHZ_PAGE)
|
2015-04-23 18:36:55 +02:00
|
|
|
#else
|
2016-10-21 12:58:50 +02:00
|
|
|
#define AT86RF2XX_MIN_CHANNEL (IEEE802154_CHANNEL_MIN)
|
|
|
|
#define AT86RF2XX_MAX_CHANNEL (IEEE802154_CHANNEL_MAX)
|
2020-02-07 12:02:45 +01:00
|
|
|
#define AT86RF2XX_DEFAULT_CHANNEL (CONFIG_IEEE802154_DEFAULT_CHANNEL)
|
2022-11-28 15:35:36 +01:00
|
|
|
#define AT86RF2XX_DEFAULT_PAGE (0)
|
2017-10-05 15:14:41 +02:00
|
|
|
/* Only page 0 is supported in the 2.4 GHz band */
|
2016-02-16 13:07:17 +01:00
|
|
|
#endif
|
2015-04-23 18:36:55 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default TX power (0dBm)
|
|
|
|
*/
|
2020-02-07 12:02:45 +01:00
|
|
|
#define AT86RF2XX_DEFAULT_TXPOWER (CONFIG_IEEE802154_DEFAULT_TXPOWER)
|
2015-04-23 18:36:55 +02:00
|
|
|
|
2015-10-22 23:01:26 +02:00
|
|
|
/**
|
|
|
|
* @brief Base (minimal) RSSI value in dBm
|
|
|
|
*/
|
2017-01-15 14:28:20 +01:00
|
|
|
#if MODULE_AT86RF233
|
|
|
|
# define RSSI_BASE_VAL (-94)
|
|
|
|
#elif MODULE_AT86RF212B
|
|
|
|
/**
|
|
|
|
* @note for the default settings in RIOT for the at86rf212b,
|
2022-09-16 13:28:48 +02:00
|
|
|
* for other settings this value may change.
|
2017-01-15 14:28:20 +01:00
|
|
|
*/
|
|
|
|
# define RSSI_BASE_VAL (-98)
|
2019-10-21 01:07:44 +02:00
|
|
|
#elif MODULE_AT86RFA1 || MODULE_AT86RFR2
|
|
|
|
# define RSSI_BASE_VAL (-90)
|
2017-01-15 14:28:20 +01:00
|
|
|
#else
|
|
|
|
# define RSSI_BASE_VAL (-91)
|
|
|
|
#endif
|
2015-10-22 23:01:26 +02:00
|
|
|
|
2018-08-06 22:56:42 +02:00
|
|
|
/**
|
|
|
|
* @brief Min Receiver sensitivity value in dBm
|
|
|
|
*/
|
|
|
|
#if MODULE_AT86RF233
|
|
|
|
# define MIN_RX_SENSITIVITY (-101)
|
|
|
|
#elif MODULE_AT86RF212B
|
|
|
|
# define MIN_RX_SENSITIVITY (-110)
|
2019-10-21 01:07:44 +02:00
|
|
|
#elif MODULE_AT86RFA1 || MODULE_AT86RFR2
|
|
|
|
# define MIN_RX_SENSITIVITY (-100)
|
2018-08-06 22:56:42 +02:00
|
|
|
#else
|
|
|
|
# define MIN_RX_SENSITIVITY (-101)
|
|
|
|
#endif
|
|
|
|
|
2022-11-24 16:50:58 +01:00
|
|
|
/**
|
|
|
|
* @brief Whether there is a periph version of the radio
|
|
|
|
*/
|
|
|
|
#if IS_USED(MODULE_AT86RFA1) || IS_USED(MODULE_AT86RFR2)
|
|
|
|
#define AT86RF2XX_IS_PERIPH (1)
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_IS_PERIPH (0)
|
|
|
|
#endif
|
|
|
|
|
2022-11-24 17:22:13 +01:00
|
|
|
/**
|
|
|
|
* @brief ED Register
|
|
|
|
*/
|
|
|
|
#if defined(MODULE_AT86RF231) || IS_ACTIVE(AT86RF2XX_PERIPH)
|
|
|
|
#define AT86RF2XX_HAVE_ED_REGISTER (1)
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_HAVE_ED_REGISTER (0)
|
|
|
|
#endif
|
|
|
|
|
2022-11-24 17:21:44 +01:00
|
|
|
/**
|
|
|
|
* @brief Support for SubGHz bands
|
|
|
|
*/
|
|
|
|
#ifdef MODULE_AT86RF212B
|
|
|
|
#define AT86RF2XX_HAVE_SUBGHZ (1)
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_HAVE_SUBGHZ (0)
|
|
|
|
#endif
|
|
|
|
|
2020-07-23 19:50:08 +02:00
|
|
|
#if defined(DOXYGEN) || defined(MODULE_AT86RF232) || defined(MODULE_AT86RF233) || defined(MODULE_AT86RFR2)
|
2017-08-18 13:41:45 +02:00
|
|
|
/**
|
|
|
|
* @brief Frame retry counter reporting
|
|
|
|
*
|
|
|
|
* The AT86RF2XX_HAVE_RETRIES flag enables support for NETOPT_TX_RETRIES NEEDED
|
2022-11-24 17:22:33 +01:00
|
|
|
* operation.
|
2017-08-18 13:41:45 +02:00
|
|
|
*/
|
|
|
|
#define AT86RF2XX_HAVE_RETRIES (1)
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_HAVE_RETRIES (0)
|
|
|
|
#endif
|
|
|
|
|
2022-11-24 17:22:33 +01:00
|
|
|
/**
|
|
|
|
* @brief Frame retry counter register
|
|
|
|
*
|
|
|
|
* Some radios include the XAH_CTRL_2 register which contains the frame retry
|
|
|
|
* counter. Only the at86rf232 and the at86rf233 support this register.
|
|
|
|
*/
|
|
|
|
#if AT86RF2XX_HAVE_RETRIES && defined(AT86RF2XX_REG__XAH_CTRL_2)
|
|
|
|
#define AT86RF2XX_HAVE_RETRIES_REG (1)
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_HAVE_RETRIES_REG (0)
|
|
|
|
#endif
|
|
|
|
|
2022-11-24 17:20:15 +01:00
|
|
|
/**
|
|
|
|
* @brief TX Start IRQ
|
|
|
|
*/
|
|
|
|
#ifdef AT86RF2XX_REG__IRQ_MASK1
|
|
|
|
#define AT86RF2XX_HAVE_TX_START_IRQ (1)
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_HAVE_TX_START_IRQ (0)
|
|
|
|
#endif
|
|
|
|
|
2019-10-21 01:07:44 +02:00
|
|
|
/**
|
|
|
|
* @brief Random Number Generator
|
|
|
|
*
|
|
|
|
* Most AT86RF radios have the option to use the highest bits of the RSSI
|
|
|
|
* register as a source of randomness.
|
|
|
|
* See Section 11.2 of the at86rf233 reference manual. (RND_VALUE)
|
|
|
|
*/
|
|
|
|
#if defined(MODULE_AT86RF233) || defined(MODULE_AT86RF231) || defined(MODULE_AT86RFA1) || defined(MODULE_AT86RFR2)
|
|
|
|
#ifndef AT86RF2XX_RANDOM_NUMBER_GENERATOR
|
|
|
|
#define AT86RF2XX_RANDOM_NUMBER_GENERATOR (1)
|
|
|
|
#endif
|
|
|
|
#else
|
|
|
|
#ifndef AT86RF2XX_RANDOM_NUMBER_GENERATOR
|
|
|
|
#define AT86RF2XX_RANDOM_NUMBER_GENERATOR (0)
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2018-08-06 22:56:42 +02:00
|
|
|
/**
|
|
|
|
* @brief Smart idle listening feature
|
|
|
|
*
|
|
|
|
* This feature optimizes radio operation in the listening mode, reducing
|
2018-10-23 19:41:34 +02:00
|
|
|
* current consumption by ~50%. It is supported by only at86rf233. The reference
|
|
|
|
* manual recommends to disable this feature for RSSI measurements or random number
|
|
|
|
* generation (Section 8.4 and Section 11.2).
|
2018-08-06 22:56:42 +02:00
|
|
|
*/
|
2019-11-13 23:35:40 +01:00
|
|
|
#if defined(MODULE_AT86RF233) || defined(MODULE_AT86RFR2)
|
2018-08-06 22:56:42 +02:00
|
|
|
#ifndef AT86RF2XX_SMART_IDLE_LISTENING
|
|
|
|
#define AT86RF2XX_SMART_IDLE_LISTENING (1)
|
|
|
|
#endif
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_SMART_IDLE_LISTENING (0)
|
|
|
|
#endif
|
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name Flags for device internal states (see datasheet)
|
2015-04-23 18:36:55 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2017-07-07 12:48:46 +02:00
|
|
|
#define AT86RF2XX_STATE_P_ON (0x00) /**< initial power on */
|
2017-09-04 16:06:55 +02:00
|
|
|
#define AT86RF2XX_STATE_BUSY_RX (0x01) /**< busy receiving data (basic mode) */
|
|
|
|
#define AT86RF2XX_STATE_BUSY_TX (0x02) /**< busy transmitting data (basic mode) */
|
2015-12-06 15:09:00 +01:00
|
|
|
#define AT86RF2XX_STATE_FORCE_TRX_OFF (0x03) /**< force transition to idle */
|
2017-09-04 16:06:55 +02:00
|
|
|
#define AT86RF2XX_STATE_RX_ON (0x06) /**< listen mode (basic mode) */
|
2015-12-06 15:09:00 +01:00
|
|
|
#define AT86RF2XX_STATE_TRX_OFF (0x08) /**< idle */
|
|
|
|
#define AT86RF2XX_STATE_PLL_ON (0x09) /**< ready to transmit */
|
|
|
|
#define AT86RF2XX_STATE_SLEEP (0x0f) /**< sleep mode */
|
2017-09-04 16:06:55 +02:00
|
|
|
#define AT86RF2XX_STATE_BUSY_RX_AACK (0x11) /**< busy receiving data (extended mode) */
|
|
|
|
#define AT86RF2XX_STATE_BUSY_TX_ARET (0x12) /**< busy transmitting data (extended mode) */
|
2015-12-06 15:09:00 +01:00
|
|
|
#define AT86RF2XX_STATE_RX_AACK_ON (0x16) /**< wait for incoming data */
|
|
|
|
#define AT86RF2XX_STATE_TX_ARET_ON (0x19) /**< ready for sending data */
|
|
|
|
#define AT86RF2XX_STATE_IN_PROGRESS (0x1f) /**< ongoing state conversion */
|
2015-04-23 18:36:55 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name Internal device option flags
|
2015-04-23 18:36:55 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2018-07-11 14:10:50 +02:00
|
|
|
#define AT86RF2XX_OPT_CSMA (0x0010) /**< CSMA active */
|
2021-02-26 11:32:45 +01:00
|
|
|
#define AT86RF2XX_OPT_PROMISCUOUS (0x0020) /**< promiscuous mode active */
|
2018-07-11 14:10:50 +02:00
|
|
|
#define AT86RF2XX_OPT_PRELOADING (0x0040) /**< preloading enabled */
|
|
|
|
#define AT86RF2XX_OPT_AUTOACK (0x0080) /**< Auto ACK active */
|
2021-02-26 11:32:45 +01:00
|
|
|
#define AT86RF2XX_OPT_ACK_PENDING (0x0100) /**< ACK frames with data pending */
|
2018-07-11 14:10:50 +02:00
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
/** @} */
|
|
|
|
|
2020-04-02 16:48:21 +02:00
|
|
|
#if IS_ACTIVE(AT86RF2XX_BASIC_MODE) || defined(DOXYGEN)
|
|
|
|
/**
|
|
|
|
* @brief Internal radio state equivalent to RX_ON
|
|
|
|
*/
|
|
|
|
#define AT86RF2XX_PHY_STATE_RX AT86RF2XX_STATE_RX_ON
|
|
|
|
/**
|
|
|
|
* @brief Internal radio state equivalent to RX_BUSY
|
|
|
|
*/
|
|
|
|
#define AT86RF2XX_PHY_STATE_RX_BUSY AT86RF2XX_STATE_BUSY_RX
|
|
|
|
/**
|
|
|
|
* @brief Internal radio state equivalent to TX_ON
|
|
|
|
*/
|
|
|
|
#define AT86RF2XX_PHY_STATE_TX AT86RF2XX_STATE_PLL_ON
|
|
|
|
/**
|
|
|
|
* @brief Internal radio state equivalent to TX_BUSY
|
|
|
|
*/
|
|
|
|
#define AT86RF2XX_PHY_STATE_TX_BUSY AT86RF2XX_STATE_BUSY_TX
|
|
|
|
#else
|
|
|
|
#define AT86RF2XX_PHY_STATE_RX AT86RF2XX_STATE_RX_AACK_ON
|
|
|
|
#define AT86RF2XX_PHY_STATE_RX_BUSY AT86RF2XX_STATE_BUSY_RX_AACK
|
|
|
|
#define AT86RF2XX_PHY_STATE_TX AT86RF2XX_STATE_TX_ARET_ON
|
|
|
|
#define AT86RF2XX_PHY_STATE_TX_BUSY AT86RF2XX_STATE_BUSY_TX_ARET
|
|
|
|
#endif /* IS_ACTIVE(AT86RF2XX_BASIC_MODE) */
|
|
|
|
|
2022-11-24 16:50:58 +01:00
|
|
|
#if AT86RF2XX_IS_PERIPH
|
2019-10-21 01:07:44 +02:00
|
|
|
/**
|
|
|
|
* @brief memory mapped radio needs no parameters
|
|
|
|
*/
|
|
|
|
typedef void at86rf2xx_params_t;
|
|
|
|
#else
|
2016-03-27 21:36:00 +02:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief struct holding all params needed for device initialization
|
2016-03-27 21:36:00 +02:00
|
|
|
*/
|
|
|
|
typedef struct at86rf2xx_params {
|
|
|
|
spi_t spi; /**< SPI bus the device is connected to */
|
2016-11-08 18:39:59 +01:00
|
|
|
spi_clk_t spi_clk; /**< SPI clock speed to use */
|
|
|
|
spi_cs_t cs_pin; /**< GPIO pin connected to chip select */
|
2016-03-27 21:36:00 +02:00
|
|
|
gpio_t int_pin; /**< GPIO pin connected to the interrupt pin */
|
|
|
|
gpio_t sleep_pin; /**< GPIO pin connected to the sleep pin */
|
|
|
|
gpio_t reset_pin; /**< GPIO pin connected to the reset pin */
|
|
|
|
} at86rf2xx_params_t;
|
2019-10-21 01:07:44 +02:00
|
|
|
#endif
|
2016-03-27 21:36:00 +02:00
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
/**
|
|
|
|
* @brief Device descriptor for AT86RF2XX radio devices
|
2016-03-18 10:26:33 +01:00
|
|
|
*
|
2017-02-15 13:07:34 +01:00
|
|
|
* @extends netdev_ieee802154_t
|
2015-04-23 18:36:55 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
2017-02-15 13:07:34 +01:00
|
|
|
netdev_ieee802154_t netdev; /**< netdev parent struct */
|
2022-11-24 16:50:58 +01:00
|
|
|
#if AT86RF2XX_IS_PERIPH
|
2019-10-21 01:07:44 +02:00
|
|
|
/* ATmega256rfr2 signals transceiver events with different interrupts
|
|
|
|
* they have to be stored to mimic the same flow as external transceiver
|
|
|
|
* Use irq_status to map saved interrupts of SOC transceiver,
|
|
|
|
* as they clear after IRQ callback.
|
|
|
|
*
|
|
|
|
* irq_status = IRQ_STATUS
|
|
|
|
*/
|
|
|
|
uint8_t irq_status; /**< save irq status */
|
|
|
|
#else
|
2017-08-29 18:00:46 +02:00
|
|
|
/* device specific fields */
|
2016-03-27 21:36:00 +02:00
|
|
|
at86rf2xx_params_t params; /**< parameters for initialization */
|
2019-10-21 01:07:44 +02:00
|
|
|
#endif
|
2018-07-11 14:10:50 +02:00
|
|
|
uint16_t flags; /**< Device specific flags */
|
2016-03-18 10:26:33 +01:00
|
|
|
uint8_t state; /**< current state of the radio */
|
|
|
|
uint8_t tx_frame_len; /**< length of the current TX frame */
|
2015-08-12 17:08:42 +02:00
|
|
|
#ifdef MODULE_AT86RF212B
|
2015-09-16 18:25:36 +02:00
|
|
|
/* Only AT86RF212B supports multiple pages (PHY modes) */
|
|
|
|
uint8_t page; /**< currently used channel page */
|
2015-04-28 15:16:51 +02:00
|
|
|
#endif
|
2015-04-23 18:36:55 +02:00
|
|
|
uint8_t idle_state; /**< state to return to after sending */
|
2016-04-07 16:53:34 +02:00
|
|
|
uint8_t pending_tx; /**< keep track of pending TX calls
|
|
|
|
this is required to know when to
|
|
|
|
return to @ref at86rf2xx_t::idle_state */
|
2017-08-18 13:41:45 +02:00
|
|
|
#if AT86RF2XX_HAVE_RETRIES
|
|
|
|
/* Only radios with the XAH_CTRL_2 register support frame retry reporting */
|
2020-07-23 19:50:08 +02:00
|
|
|
int8_t tx_retries; /**< Number of NOACK retransmissions */
|
2017-08-18 13:41:45 +02:00
|
|
|
#endif
|
2015-08-09 21:24:55 +02:00
|
|
|
} at86rf2xx_t;
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
2016-03-18 10:26:33 +01:00
|
|
|
* @brief Setup an AT86RF2xx based device state
|
2015-04-23 18:36:55 +02:00
|
|
|
*
|
|
|
|
* @param[out] dev device descriptor
|
2016-03-27 21:36:00 +02:00
|
|
|
* @param[in] params parameters for device initialization
|
2020-07-07 20:15:56 +02:00
|
|
|
* @param[in] index index of @p params in a global parameter struct array.
|
|
|
|
* If initialized manually, pass a unique identifier instead.
|
2016-03-27 21:36:00 +02:00
|
|
|
*/
|
2020-07-07 20:15:56 +02:00
|
|
|
void at86rf2xx_setup(at86rf2xx_t *dev, const at86rf2xx_params_t *params, uint8_t index);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Trigger a hardware reset and configure radio with default values
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to reset
|
2015-04-23 18:36:55 +02:00
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_reset(at86rf2xx_t *dev);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the short address of the given device
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to write to
|
2015-04-23 18:36:55 +02:00
|
|
|
* @param[in] addr (2-byte) short address to set
|
|
|
|
*/
|
2019-10-29 23:09:00 +01:00
|
|
|
void at86rf2xx_set_addr_short(at86rf2xx_t *dev, const network_uint16_t *addr);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the long address of the given device
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to write to
|
2015-04-23 18:36:55 +02:00
|
|
|
* @param[in] addr (8-byte) long address to set
|
|
|
|
*/
|
2019-10-29 23:09:00 +01:00
|
|
|
void at86rf2xx_set_addr_long(at86rf2xx_t *dev, const eui64_t *addr);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
2019-09-09 14:30:37 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the PHY mode of the given device
|
|
|
|
*
|
|
|
|
* @param[in,out] dev device to read from
|
|
|
|
* @return the currently set phy mode
|
|
|
|
*/
|
|
|
|
uint8_t at86rf2xx_get_phy_mode(at86rf2xx_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the current O-QPSK rate mode of the PHY
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
2020-07-10 16:08:13 +02:00
|
|
|
* @return the currently set rate mode
|
2019-09-09 14:30:37 +02:00
|
|
|
*/
|
|
|
|
uint8_t at86rf2xx_get_rate(at86rf2xx_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the current O-QPSK rate mode of the PHY
|
|
|
|
* rate modes > 0 are proprietary.
|
|
|
|
*
|
|
|
|
* rate 0: 250 kbit/s (IEEE mode)
|
|
|
|
* rate 1: 500 kbit/s
|
|
|
|
* rate 2: 1000 kbit/s (compatible with AT86RF215)
|
|
|
|
* rate 3: 2000 kbit/s
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] rate the selected data rate mode (0-3)
|
|
|
|
*
|
|
|
|
* @return 0 on success, otherwise error value
|
|
|
|
*/
|
|
|
|
int at86rf2xx_set_rate(at86rf2xx_t *dev, uint8_t rate);
|
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
/**
|
|
|
|
* @brief Set the PAN ID of the given device
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to write to
|
2015-04-23 18:36:55 +02:00
|
|
|
* @param[in] pan PAN ID to set
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_set_pan(at86rf2xx_t *dev, uint16_t pan);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the transmission power of the given device [in dBm]
|
|
|
|
*
|
|
|
|
* If the device does not support the exact dBm value given, it will set a value
|
|
|
|
* as close as possible to the given value. If the given value is larger or
|
|
|
|
* lower then the maximal or minimal possible value, the min or max value is
|
|
|
|
* set, respectively.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] txpower transmission power in dBm
|
2022-11-28 16:06:36 +01:00
|
|
|
* @param[in] channel the current channel
|
2015-04-23 18:36:55 +02:00
|
|
|
*/
|
2022-11-28 16:06:36 +01:00
|
|
|
void at86rf2xx_set_txpower(const at86rf2xx_t *dev, int16_t txpower, uint8_t channel);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
2018-08-06 22:56:42 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the configured receiver sensitivity of the given device [in dBm]
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
|
|
|
* @return configured receiver sensitivity in dBm
|
|
|
|
*/
|
2020-09-16 14:37:02 +02:00
|
|
|
int8_t at86rf2xx_get_rxsensitivity(const at86rf2xx_t *dev);
|
2018-08-06 22:56:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the receiver sensitivity of the given device [in dBm]
|
|
|
|
*
|
|
|
|
* If the device does not support the exact dBm value given, it will set a value
|
|
|
|
* as close as possible to the given value. If the given value is larger or
|
|
|
|
* lower then the maximal or minimal possible value, the min or max value is
|
|
|
|
* set, respectively.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] rxsens rx sensitivity in dBm
|
|
|
|
*/
|
2020-09-16 14:37:02 +02:00
|
|
|
void at86rf2xx_set_rxsensitivity(const at86rf2xx_t *dev, int8_t rxsens);
|
2018-08-06 22:56:42 +02:00
|
|
|
|
2015-05-18 21:19:03 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the maximum number of retransmissions
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
|
|
|
* @return configured number of retransmissions
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
uint8_t at86rf2xx_get_max_retries(const at86rf2xx_t *dev);
|
2015-05-18 21:19:03 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the maximum number of retransmissions
|
|
|
|
*
|
|
|
|
* This setting specifies the number of attempts to retransmit a frame, when it
|
|
|
|
* was not acknowledged by the recipient, before the transaction gets cancelled.
|
|
|
|
* The maximum value is 7.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] max the maximum number of retransmissions
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
void at86rf2xx_set_max_retries(const at86rf2xx_t *dev, uint8_t max);
|
2015-05-18 21:19:03 +02:00
|
|
|
|
2015-06-01 15:51:50 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the maximum number of channel access attempts per frame (CSMA)
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
|
|
|
* @return configured number of retries
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
uint8_t at86rf2xx_get_csma_max_retries(const at86rf2xx_t *dev);
|
2015-06-01 15:51:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the maximum number of channel access attempts per frame (CSMA)
|
|
|
|
*
|
|
|
|
* This setting specifies the number of attempts to access the channel to
|
|
|
|
* transmit a frame. If the channel is busy @p retries times, then frame
|
|
|
|
* transmission fails.
|
|
|
|
* Valid values: 0 to 5, -1 means CSMA disabled
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
2015-09-16 18:25:36 +02:00
|
|
|
* @param[in] retries the maximum number of retries
|
2015-06-01 15:51:50 +02:00
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
void at86rf2xx_set_csma_max_retries(const at86rf2xx_t *dev, int8_t retries);
|
2015-06-01 15:51:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the min and max backoff exponent for CSMA/CA
|
|
|
|
*
|
|
|
|
* - Maximum BE: 0 - 8
|
|
|
|
* - Minimum BE: 0 - [max]
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] min the minimum BE
|
|
|
|
* @param[in] max the maximum BE
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
void at86rf2xx_set_csma_backoff_exp(const at86rf2xx_t *dev,
|
|
|
|
uint8_t min, uint8_t max);
|
2015-06-01 15:51:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set seed for CSMA random backoff
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] entropy 11 bit of entropy as seed for random backoff
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
void at86rf2xx_set_csma_seed(const at86rf2xx_t *dev, const uint8_t entropy[2]);
|
2015-06-01 15:51:50 +02:00
|
|
|
|
2015-10-22 23:01:26 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the CCA threshold value
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read value from
|
|
|
|
*
|
|
|
|
* @return the current CCA threshold value
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
int8_t at86rf2xx_get_cca_threshold(const at86rf2xx_t *dev);
|
2015-10-22 23:01:26 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the CCA threshold value
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] value the new CCA threshold value
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
void at86rf2xx_set_cca_threshold(const at86rf2xx_t *dev, int8_t value);
|
2015-10-22 23:01:26 +02:00
|
|
|
|
2017-09-04 20:16:07 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the latest ED level measurement
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read value from
|
|
|
|
*
|
|
|
|
* @return the last ED level
|
|
|
|
*/
|
|
|
|
int8_t at86rf2xx_get_ed_level(at86rf2xx_t *dev);
|
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
/**
|
|
|
|
* @brief Enable or disable driver specific options
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to set/clear option flag for
|
2015-04-23 18:36:55 +02:00
|
|
|
* @param[in] option option to enable/disable
|
|
|
|
* @param[in] state true for enable, false for disable
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_set_option(at86rf2xx_t *dev, uint16_t option, bool state);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the state of the given device (trigger a state change)
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to change state of
|
2015-04-23 18:36:55 +02:00
|
|
|
* @param[in] state the targeted new state
|
2017-05-31 14:06:23 +02:00
|
|
|
*
|
|
|
|
* @return the previous state before the new state was set
|
2015-04-23 18:36:55 +02:00
|
|
|
*/
|
2017-05-31 14:06:23 +02:00
|
|
|
uint8_t at86rf2xx_set_state(at86rf2xx_t *dev, uint8_t state);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Prepare for sending of data
|
|
|
|
*
|
|
|
|
* This function puts the given device into the TX state, so no receiving of
|
|
|
|
* data is possible after it was called.
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to prepare for sending
|
2015-04-23 18:36:55 +02:00
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_tx_prepare(at86rf2xx_t *dev);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Load chunks of data into the transmit buffer of the given device
|
|
|
|
*
|
2017-06-30 13:53:29 +02:00
|
|
|
* @param[in,out] dev device to write data to
|
2015-04-23 18:36:55 +02:00
|
|
|
* @param[in] data buffer containing the data to load
|
|
|
|
* @param[in] len number of bytes in @p buffer
|
|
|
|
* @param[in] offset offset used when writing data to internal buffer
|
|
|
|
*
|
|
|
|
* @return offset + number of bytes written
|
|
|
|
*/
|
2017-06-30 13:53:29 +02:00
|
|
|
size_t at86rf2xx_tx_load(at86rf2xx_t *dev, const uint8_t *data,
|
|
|
|
size_t len, size_t offset);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Trigger sending of data previously loaded into transmit buffer
|
|
|
|
*
|
|
|
|
* @param[in] dev device to trigger
|
|
|
|
*/
|
2020-07-23 19:50:08 +02:00
|
|
|
void at86rf2xx_tx_exec(at86rf2xx_t *dev);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
2017-09-04 16:06:55 +02:00
|
|
|
/**
|
|
|
|
* @brief Perform one manual channel clear assessment (CCA)
|
|
|
|
*
|
|
|
|
* The CCA mode and threshold level depends on the current transceiver settings.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to use
|
|
|
|
*
|
|
|
|
* @return true if channel is determined clear
|
|
|
|
* @return false if channel is determined busy
|
|
|
|
*/
|
|
|
|
bool at86rf2xx_cca(at86rf2xx_t *dev);
|
|
|
|
|
2022-07-01 00:13:13 +02:00
|
|
|
/**
|
2023-10-16 12:17:48 +02:00
|
|
|
* @brief Enable the smart receive technology (SRT)
|
2022-07-01 00:13:13 +02:00
|
|
|
*
|
|
|
|
* The SRT reduces the power consumption during RX listening periods.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to use
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void at86rf2xx_enable_smart_idle(at86rf2xx_t *dev);
|
|
|
|
|
|
|
|
/**
|
2023-10-16 12:17:48 +02:00
|
|
|
* @brief Disable the smart receive technology (SRT)
|
2022-07-01 00:13:13 +02:00
|
|
|
*
|
|
|
|
* @param[in] dev device to use
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void at86rf2xx_disable_smart_idle(at86rf2xx_t *dev);
|
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#endif /* AT86RF2XX_H */
|
2015-04-23 18:36:55 +02:00
|
|
|
/** @} */
|