2015-04-02 17:09:29 +02:00
|
|
|
/*
|
2016-05-20 17:13:31 +02:00
|
|
|
* Copyright (C) 2016 Phytec Messtechnik GmbH
|
2015-04-02 17:09:29 +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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-02-14 17:28:31 +01:00
|
|
|
* @defgroup drivers_kw2xrf KW2x radio-driver
|
|
|
|
* @ingroup drivers_netdev
|
2016-05-20 17:13:31 +02:00
|
|
|
* @brief Device driver for the NXP CR20A and KW2xD radios
|
2015-04-02 17:09:29 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2016-05-20 17:13:31 +02:00
|
|
|
* @brief Interface definition for the kw2xrf driver
|
2015-04-02 17:09:29 +02:00
|
|
|
*
|
|
|
|
* @author Johann Fischer <j.fischer@phytec.de>
|
|
|
|
* @author Jonas Remmert <j.remmert@phytec.de>
|
2017-01-31 13:26:01 +01:00
|
|
|
* @author Sebastian Meiling <s@mlng.net>
|
2015-04-02 17:09:29 +02:00
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef KW2XRF_H
|
|
|
|
#define KW2XRF_H
|
2015-04-02 17:09:29 +02:00
|
|
|
|
2015-04-02 17:39:10 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "board.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-05-20 17:13:31 +02:00
|
|
|
#include "net/gnrc/nettype.h"
|
2017-12-20 13:54:32 +01:00
|
|
|
#include "thread.h"
|
2022-07-28 18:27:16 +02:00
|
|
|
#include "net/ieee802154/radio.h"
|
2015-04-02 17:09:29 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
2015-04-02 17:39:10 +02:00
|
|
|
* @brief Maximum packet length
|
2015-04-02 17:09:29 +02:00
|
|
|
*/
|
2017-01-31 13:26:01 +01:00
|
|
|
#define KW2XRF_MAX_PKT_LENGTH (IEEE802154_FRAME_LEN_MAX)
|
2015-04-02 17:39:10 +02:00
|
|
|
|
2015-04-02 17:09:29 +02:00
|
|
|
/**
|
2020-04-06 08:51:18 +02:00
|
|
|
* @defgroup drivers_kw2xrf_config CR20A and KW2xD radio driver compile configuration
|
|
|
|
* @ingroup config_drivers_netdev
|
2017-01-23 11:06:37 +01:00
|
|
|
* @{
|
2015-04-02 17:09:29 +02:00
|
|
|
*/
|
2020-04-06 08:51:18 +02:00
|
|
|
/**
|
|
|
|
* @brief Default channel used after initialization.
|
|
|
|
*/
|
2016-02-16 13:07:17 +01:00
|
|
|
#ifndef KW2XRF_DEFAULT_CHANNEL
|
2020-02-07 12:02:45 +01:00
|
|
|
#define KW2XRF_DEFAULT_CHANNEL (CONFIG_IEEE802154_DEFAULT_CHANNEL)
|
2016-02-16 13:07:17 +01:00
|
|
|
#endif
|
2017-01-23 11:06:37 +01:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name Allowed range of channels
|
2017-01-23 11:06:37 +01:00
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
2016-05-20 17:13:31 +02:00
|
|
|
#define KW2XRF_MIN_CHANNEL (11U)
|
|
|
|
#define KW2XRF_MAX_CHANNEL (26U)
|
2017-01-23 11:06:37 +01:00
|
|
|
/** @} */
|
2015-04-02 17:39:10 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default TX_POWER in dbm used after initialization
|
|
|
|
*/
|
2020-02-07 12:02:45 +01:00
|
|
|
#define KW2XRF_DEFAULT_TX_POWER (CONFIG_IEEE802154_DEFAULT_TXPOWER)
|
2015-04-02 17:09:29 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum output power of the kw2x device in dBm
|
|
|
|
*/
|
2017-01-31 13:26:01 +01:00
|
|
|
#define KW2XDRF_OUTPUT_POWER_MAX (8)
|
2015-04-02 17:09:29 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Minimum output power of the kw2x device in dBm
|
|
|
|
*/
|
2017-01-31 13:26:01 +01:00
|
|
|
#define KW2XDRF_OUTPUT_POWER_MIN (-35)
|
2015-04-02 17:39:10 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Internal device option flags
|
2016-05-20 17:13:31 +02:00
|
|
|
*
|
|
|
|
* `0x00ff` is reserved for general IEEE 802.15.4 flags
|
2017-02-15 13:07:34 +01:00
|
|
|
* (see @ref netdev_ieee802154_t)
|
2016-05-20 17:13:31 +02:00
|
|
|
*
|
2015-04-02 17:39:10 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2017-02-15 13:07:34 +01:00
|
|
|
#define KW2XRF_OPT_SRC_ADDR_LONG (NETDEV_IEEE802154_SRC_MODE_LONG) /**< legacy define */
|
|
|
|
#define KW2XRF_OPT_RAWDUMP (NETDEV_IEEE802154_RAW) /**< legacy define */
|
|
|
|
#define KW2XRF_OPT_ACK_REQ (NETDEV_IEEE802154_ACK_REQ) /**< legacy define */
|
2016-05-20 17:13:31 +02:00
|
|
|
|
2019-10-23 21:25:51 +02:00
|
|
|
#define KW2XRF_OPT_AUTOCCA (0x0100) /**< CCA before TX active */
|
2016-05-20 17:13:31 +02:00
|
|
|
#define KW2XRF_OPT_PROMISCUOUS (0x0200) /**< promiscuous mode
|
|
|
|
* active */
|
|
|
|
#define KW2XRF_OPT_PRELOADING (0x0400) /**< preloading enabled */
|
|
|
|
#define KW2XRF_OPT_AUTOACK (0x8000) /**< enable automatically ACK
|
|
|
|
* for incommint packet */
|
2015-04-02 17:39:10 +02:00
|
|
|
/** @} */
|
2015-04-02 17:09:29 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Struct holding all params needed for device initialization
|
2016-05-20 17:13:31 +02:00
|
|
|
*/
|
|
|
|
typedef struct kw2xrf_params {
|
|
|
|
spi_t spi; /**< SPI bus the device is connected to */
|
2017-01-23 11:06:37 +01:00
|
|
|
spi_clk_t spi_clk; /**< SPI clock speed to use */
|
2016-05-20 17:13:31 +02:00
|
|
|
gpio_t cs_pin; /**< GPIO pin connected to chip select */
|
|
|
|
gpio_t int_pin; /**< GPIO pin connected to the interrupt pin */
|
2022-07-28 18:27:16 +02:00
|
|
|
gpio_t rst_pin; /**< GPIO pin connected to RST_B */
|
2016-05-20 17:13:31 +02:00
|
|
|
} kw2xrf_params_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Device descriptor for KW2XRF radio devices
|
|
|
|
*
|
2017-02-15 13:07:34 +01:00
|
|
|
* @extends netdev_ieee802154_t
|
2015-04-02 17:09:29 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
2016-05-20 17:13:31 +02:00
|
|
|
/**
|
|
|
|
* @brief device specific fields
|
|
|
|
* @{
|
|
|
|
*/
|
2017-12-20 13:54:32 +01:00
|
|
|
thread_t *thread; /**< Network driver thread, for providing feedback from IRQ handler */
|
2022-07-28 18:27:16 +02:00
|
|
|
const kw2xrf_params_t *params; /**< parameters for initialization */
|
2016-05-20 17:13:31 +02:00
|
|
|
uint8_t buf[KW2XRF_MAX_PKT_LENGTH]; /**< Buffer for incoming or outgoing packets */
|
|
|
|
uint8_t state; /**< current state of the radio */
|
|
|
|
uint8_t tx_frame_len; /**< length of the current TX frame */
|
|
|
|
uint8_t idle_state; /**< state to return to after sending */
|
|
|
|
uint8_t pending_tx; /**< keep track of pending TX calls
|
|
|
|
this is required to know when to
|
|
|
|
return to @ref kw2xrf_t::idle_state */
|
|
|
|
int16_t tx_power; /**< The current tx-power setting of the device */
|
2022-07-28 18:27:16 +02:00
|
|
|
bool ack_requested; /**< ACK was requested for last frame */
|
|
|
|
bool ch_clear; /**< CCA indicated channel clear */
|
|
|
|
bool waiting_for_cca; /**< Indicate whether CCA is still ongoing */
|
|
|
|
bool tx_done; /**< Indicate whether TX completed */
|
|
|
|
bool ack_rcvd; /**< Indicate if ACK was received for last transmission */
|
|
|
|
bool cca_before_tx; /**< true if CCA shall be performed before TX */
|
|
|
|
bool tx_cca_pending; /**< true a manual CCA was started and a TX should be triggered on channel clear indication */
|
2016-05-20 17:13:31 +02:00
|
|
|
/** @} */
|
2015-04-02 17:09:29 +02:00
|
|
|
} kw2xrf_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize the given KW2XRF device
|
2015-04-02 17:39:10 +02:00
|
|
|
* @param[out] dev device descriptor
|
2022-07-28 18:27:16 +02:00
|
|
|
* @param[in] params parameters for device initialization
|
|
|
|
* @param[in] hal pointer to IEEE 802.15.4 Radio HAL descriptor
|
|
|
|
* @param[in] cb isr callback
|
|
|
|
* @param[in] ctx context pointer handed to isr
|
2015-04-02 17:09:29 +02:00
|
|
|
*
|
|
|
|
* @return 0 on success
|
2015-04-02 17:39:10 +02:00
|
|
|
* @return <0 on error
|
2015-04-02 17:09:29 +02:00
|
|
|
*/
|
2022-07-28 18:27:16 +02:00
|
|
|
int kw2xrf_init(kw2xrf_t *dev, const kw2xrf_params_t *params, ieee802154_dev_t *hal,
|
|
|
|
gpio_cb_t cb, void *ctx);
|
2015-04-02 17:09:29 +02:00
|
|
|
|
2015-05-17 15:21:49 +02:00
|
|
|
/**
|
2016-05-20 17:13:31 +02:00
|
|
|
* @brief Configure radio with default values
|
|
|
|
*
|
|
|
|
* @param[in] dev device to reset
|
2015-05-17 15:21:49 +02:00
|
|
|
*/
|
2016-05-20 17:13:31 +02:00
|
|
|
void kw2xrf_reset_phy(kw2xrf_t *dev);
|
2015-05-17 15:21:49 +02:00
|
|
|
|
2022-07-28 18:27:16 +02:00
|
|
|
/**
|
|
|
|
* @brief IRQ Handler for the KW2XRF device
|
|
|
|
*
|
|
|
|
* @param[in] dev pointer to the IEEE 802.15.4 Radio HAL descriptor
|
|
|
|
*/
|
|
|
|
void kw2xrf_radio_hal_irq_handler(void *dev);
|
|
|
|
|
2015-04-02 17:09:29 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* KW2XRF_H */
|
2015-04-02 17:09:29 +02:00
|
|
|
/** @} */
|