2016-04-14 13:48:00 +02:00
|
|
|
/*
|
2016-07-05 18:42:59 +02:00
|
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
2016-04-14 13:48:00 +02:00
|
|
|
*
|
2016-07-05 18:42:59 +02:00
|
|
|
* 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.
|
2016-04-14 13:48:00 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-07-02 23:21:36 +02:00
|
|
|
* @defgroup drivers_cc2420 CC2420 radio driver
|
2017-02-07 13:26:01 +01:00
|
|
|
* @ingroup drivers_netdev
|
2016-04-14 13:48:00 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Interface definition for the CC2420 driver
|
|
|
|
*
|
|
|
|
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CC2420_H
|
|
|
|
#define CC2420_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "periph/spi.h"
|
|
|
|
#include "periph/gpio.h"
|
|
|
|
|
2017-02-15 13:07:34 +01:00
|
|
|
#include "net/netdev.h"
|
|
|
|
#include "net/netdev/ieee802154.h"
|
2016-04-14 13:48:00 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum possible packet size in byte
|
|
|
|
*/
|
2016-10-21 12:58:50 +02:00
|
|
|
#define CC2420_PKT_MAXLEN (IEEE802154_FRAME_LEN_MAX)
|
2016-04-14 13:48:00 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name Channel configuration
|
2016-04-14 13:48:00 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2016-10-21 12:58:50 +02:00
|
|
|
#define CC2420_CHAN_MIN (IEEE802154_CHANNEL_MIN)
|
|
|
|
#define CC2420_CHAN_MAX (IEEE802154_CHANNEL_MAX)
|
2020-02-07 12:02:45 +01:00
|
|
|
#define CC2420_CHAN_DEFAULT (CONFIG_IEEE802154_DEFAULT_CHANNEL)
|
2016-04-14 13:48:00 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name Default TX power configuration [in dBm]
|
2016-04-14 13:48:00 +02:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define CC2420_TXPOWER_MIN (-25)
|
|
|
|
#define CC2420_TXPOWER_MAX (0)
|
2020-02-07 12:02:45 +01:00
|
|
|
#define CC2420_TXPOWER_DEFAULT (CONFIG_IEEE802154_DEFAULT_TXPOWER)
|
2016-04-14 13:48:00 +02:00
|
|
|
/** @} */
|
|
|
|
|
2017-08-30 21:09:21 +02:00
|
|
|
/**
|
|
|
|
* @brief RSSI offset
|
|
|
|
*/
|
|
|
|
#define CC2420_RSSI_OFFSET (-45)
|
|
|
|
|
2016-04-14 13:48:00 +02:00
|
|
|
/**
|
|
|
|
* @brief A couple of return values used in this driver
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
CC2420_RET_CHAN_OK = 2,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Struct holding all parameters needed for device initialization
|
|
|
|
*/
|
|
|
|
typedef struct cc2420_params {
|
|
|
|
spi_t spi; /**< SPI bus the device is connected to */
|
2016-11-08 18:40:41 +01:00
|
|
|
spi_clk_t spi_clk; /**< SPI speed to use */
|
2016-04-14 13:48:00 +02:00
|
|
|
gpio_t pin_cs; /**< pin connected to chip select */
|
|
|
|
gpio_t pin_fifo; /**< pin connected to the FIFO interrupt pin */
|
|
|
|
gpio_t pin_fifop; /**< pin connected to the FIFOP interrupt pin */
|
|
|
|
gpio_t pin_cca; /**< pin connected to CCA */
|
|
|
|
gpio_t pin_sfd; /**< pin connected to 'start of frame delimiter' */
|
|
|
|
gpio_t pin_vrefen; /**< pin connected to the Vref enable pin */
|
|
|
|
gpio_t pin_reset; /**< pin connected to the reset pin */
|
|
|
|
} cc2420_params_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Device descriptor for CC2420 radio devices
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/* netdev fields */
|
2017-02-15 13:07:34 +01:00
|
|
|
netdev_ieee802154_t netdev; /**< netdev parent struct */
|
2016-04-14 13:48:00 +02:00
|
|
|
/* device specific fields */
|
2016-07-05 18:42:59 +02:00
|
|
|
cc2420_params_t params; /**< hardware interface configuration */
|
2016-04-14 13:48:00 +02:00
|
|
|
/* device state fields */
|
2016-07-05 18:42:59 +02:00
|
|
|
uint8_t state; /**< current state of the radio */
|
|
|
|
uint16_t options; /**< state of used options */
|
2016-04-14 13:48:00 +02:00
|
|
|
} cc2420_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Setup the device descriptor for the given device
|
|
|
|
*
|
|
|
|
* @param[out] dev device descriptor
|
|
|
|
* @param[in] params device parameters
|
2020-09-11 16:16:50 +02:00
|
|
|
* @param[in] index index of @p params in a global parameter struct array.
|
|
|
|
* If initialized manually, pass a unique identifier instead.
|
2016-04-14 13:48:00 +02:00
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
2020-09-11 16:16:50 +02:00
|
|
|
void cc2420_setup(cc2420_t *dev, const cc2420_params_t *params, uint8_t index);
|
2016-04-14 13:48:00 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize a given CC2420 device
|
|
|
|
*
|
|
|
|
* @param[out] dev device descriptor
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return <0 on error
|
|
|
|
*/
|
|
|
|
int cc2420_init(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Trigger a hardware reset and configure radio with default values
|
|
|
|
*
|
|
|
|
* @param[in] dev device to reset
|
|
|
|
*
|
|
|
|
* @return TODO
|
|
|
|
*/
|
|
|
|
int cc2420_reset(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Trigger a clear channel assessment
|
|
|
|
*
|
|
|
|
* @param[in] dev device to use
|
|
|
|
*
|
|
|
|
* @return true if channel is clear
|
|
|
|
* @return false if channel is busy
|
|
|
|
*/
|
|
|
|
bool cc2420_cca(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the short address of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
* @param[out] addr memory to write the 2 byte address into
|
|
|
|
*/
|
|
|
|
void cc2420_get_addr_short(cc2420_t *dev, uint8_t *addr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the short address of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] addr (2-byte) short address to set
|
|
|
|
*/
|
2017-08-25 07:34:03 +02:00
|
|
|
void cc2420_set_addr_short(cc2420_t *dev, const uint8_t *addr);
|
2016-04-14 13:48:00 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the configured long address of the given device
|
|
|
|
*
|
2016-07-05 18:42:59 +02:00
|
|
|
* @param[in] dev device to read from
|
|
|
|
* @param[out] addr_long buffer to save the read address
|
2016-04-14 13:48:00 +02:00
|
|
|
*
|
|
|
|
* @return the currently set (8-byte) long address
|
|
|
|
*/
|
|
|
|
void cc2420_get_addr_long(cc2420_t *dev, uint8_t *addr_long);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the long address of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
2016-07-05 18:42:59 +02:00
|
|
|
* @param[in] addr_long (8-byte) long address to set
|
2016-04-14 13:48:00 +02:00
|
|
|
*/
|
2017-08-25 07:34:03 +02:00
|
|
|
void cc2420_set_addr_long(cc2420_t *dev, const uint8_t *addr_long);
|
2016-04-14 13:48:00 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the configured PAN ID of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
|
|
|
* @return the currently set PAN ID
|
|
|
|
*/
|
|
|
|
uint16_t cc2420_get_pan(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the PAN ID of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] pan PAN ID to set
|
|
|
|
*/
|
|
|
|
void cc2420_set_pan(cc2420_t *dev, uint16_t pan);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the configured channel of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
|
|
|
* @return the currently set channel
|
|
|
|
*/
|
|
|
|
uint16_t cc2420_get_chan(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the channel of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] chan channel to set
|
|
|
|
*/
|
|
|
|
int cc2420_set_chan(cc2420_t *dev, uint16_t chan);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the configured transmission power of the given device [in dBm]
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
|
|
|
* @return configured transmission power in dBm
|
|
|
|
*/
|
|
|
|
int16_t cc2420_get_txpower(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @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
|
|
|
|
*/
|
|
|
|
void cc2420_set_txpower(cc2420_t *dev, int16_t txpower);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Enable or disable driver specific options
|
|
|
|
*
|
|
|
|
* @param[in] dev device to set/clear option flag for
|
|
|
|
* @param[in] option option to enable/disable
|
|
|
|
* @param[in] state true for enable, false for disable
|
|
|
|
*/
|
|
|
|
int cc2420_set_option(cc2420_t *dev, uint16_t option, bool state);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the state of the given device (trigger a state change)
|
|
|
|
*
|
|
|
|
* @param[in] dev device to change state of
|
|
|
|
* @param[in] state the targeted new state
|
|
|
|
*/
|
|
|
|
int cc2420_set_state(cc2420_t *dev, netopt_state_t state);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the state of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to change state of
|
|
|
|
*
|
|
|
|
* @return the device's current state
|
|
|
|
*/
|
|
|
|
netopt_state_t cc2420_get_state(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convenience function for simply sending data
|
|
|
|
*
|
|
|
|
* @note This function ignores the PRELOADING option
|
|
|
|
*
|
|
|
|
* @param[in] dev device to use for sending
|
2018-01-12 00:19:03 +01:00
|
|
|
* @param[in] iolist data to send (must include IEEE802.15.4 header)
|
2016-04-14 13:48:00 +02:00
|
|
|
*
|
|
|
|
* @return number of bytes that were actually send
|
|
|
|
* @return 0 on error
|
|
|
|
*/
|
2018-01-12 00:19:03 +01:00
|
|
|
size_t cc2420_send(cc2420_t *dev, const iolist_t *iolist);
|
2016-04-14 13:48:00 +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.
|
|
|
|
*
|
2016-07-05 18:42:59 +02:00
|
|
|
* @param[in] dev device to prepare for sending
|
2018-01-12 00:19:03 +01:00
|
|
|
* @param[in] iolist data to prepare (must include IEEE802.15.4 header)
|
2016-04-14 13:48:00 +02:00
|
|
|
*/
|
2018-01-12 00:19:03 +01:00
|
|
|
size_t cc2420_tx_prepare(cc2420_t *dev, const iolist_t *iolist);
|
2016-04-14 13:48:00 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Trigger sending of data previously loaded into transmit buffer
|
|
|
|
*
|
|
|
|
* @param[in] dev device to trigger
|
|
|
|
*/
|
|
|
|
void cc2420_tx_exec(cc2420_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Read a chunk of data from the receive buffer of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
2016-07-05 18:42:59 +02:00
|
|
|
* @param[out] buf buffer to write data to
|
|
|
|
* @param[in] max_len number of bytes to read from device
|
|
|
|
* @param[in] info to be removed
|
2016-10-28 23:46:23 +02:00
|
|
|
*
|
|
|
|
* @return the number of bytes in the Rx FIFO
|
|
|
|
* @return the number of bytes written to @p buf if present
|
2016-04-14 13:48:00 +02:00
|
|
|
*/
|
|
|
|
int cc2420_rx(cc2420_t *dev, uint8_t *buf, size_t max_len, void *info);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* CC2420_H */
|
|
|
|
/** @} */
|