/* * Copyright (C) 2019 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. */ /** * @defgroup drivers_nrf52_802154 IEEE802.15.4 Driver for nRF52840 SoCs * @ingroup drivers_netdev * @brief Driver for using the nRF52's radio in IEEE802.15.4 mode * * ## Implementation state ## * Netdev events supported: * * - NETDEV_EVENT_RX_COMPLETE * - NETDEV_EVENT_TX_COMPLETE * * Transmission options not yet implemented: * - Send acknowledgement for packages * - Request acknowledgement * - Retransmit unacked packages * - Carrier Sense Multiple Access (CSMA) and Implementation of Clear Channel * Assessment Control (CCACTRL) * * @{ * * @file * @brief Driver interface for using the nRF52 in IEEE802.15.4 mode * * @author Hauke Petersen * @author Semjon Kerner */ #ifndef NRF802154_H #define NRF802154_H #if IS_USED(MODULE_IEEE802154_RADIO_HAL) #include "net/ieee802154/radio.h" #if IS_USED(MODULE_NETDEV_IEEE802154_SUBMAC) #include "net/netdev/ieee802154_submac.h" #endif #else #include "net/netdev/ieee802154.h" #endif #ifdef __cplusplus extern "C" { #endif /** * @brief Device descriptor for NRF802154 transceiver * * @extends netdev_ieee802154_t if using legacy radio * @extends netdev_ieee802154_submac_t if using radio HAL */ typedef struct { #if IS_USED(MODULE_NETDEV_IEEE802154_SUBMAC) netdev_ieee802154_submac_t netdev; /**< netdev SubMAC descriptor */ #elif !IS_USED(MODULE_IEEE802154_RADIO_HAL) netdev_ieee802154_t netdev; /**< ieee802154 device descriptor */ #endif } nrf802154_t; /** * @defgroup drivers_nrf52_802154_conf nrf802154 driver compile configuration * @ingroup drivers_nrf52_802154 * @ingroup config_drivers_netdev * @{ */ /** * @brief NRF802154 default CCA threshold value for CCACTRL register. * * @note This value was copied from the Nordic reference driver configuration */ #ifndef CONFIG_NRF802154_CCA_THRESH_DEFAULT #define CONFIG_NRF802154_CCA_THRESH_DEFAULT 0x14 #endif /** @} */ /** * @brief IEEE 802.15.4 radio timer configuration * * this radio relies on a dedicated hardware timer to maintain IFS * the default timer may be overwritten in the board configuration */ #ifndef NRF802154_TIMER #define NRF802154_TIMER TIMER_DEV(1) #endif /** * @brief Initialize the NRF52840 radio. * * @return 0 on success * @return negative errno on error */ int nrf802154_init(void); /** * @brief Setup a NRF802154 radio device for use with netdev * * @param[out] dev Device descriptor */ void nrf802154_setup(nrf802154_t *dev); #endif /* NRF802154_H */ /** @} */