/* * Copyright (C) 2019 Hamburg University of Applied Sciences * 2020 Inria * * 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. */ /** * @ingroup pkg_openwsn * @{ * * @file * @brief RIOT adaption of the "radio" bsp module definitions * * The radio adaptation runs in an own thread with the highest priority * (`THREAD_PRIORITY_MAIN - 4`) and maps to RIOT's `netdev` API. * * Hardware MAC layer features such as CSMA/CA, ACK handling and retransmissions * are handled by OpenWSN, so the radio driver must support disabling AUTOACK * and CSMA handling by the hardware. Frame filtering must as well be disabled. * * The radio adaptation preloads the buffer so `NETOPT_PRELOADING` must be * supported. * * OpenWSN needs to be notified when a frame reception/transmission stats and * when it ends. Therefore radio drivers need to support the following netdev * events: * * - `NETDEV_EVENT_RX_STARTED` * - `NETDEV_EVENT_TX_STARTED` * - `NETDEV_EVENT_RX_COMPLETE` * - `NETDEV_EVENT_TX_COMPLETE` * * OpenWSN expects to recover crc information on every received frame even if it * will simply drop frames with invalid crc. The stack can function correctly if * radio drivers automatically drop frames with an invalid crc (i.e. the stack * doesn't get notified about these frames), but it might print the following * error if using `openwsn_serial`: * * - `[IEEE802154E] wdDataDuration overflows while at state 19 in slotOffset 0` * * @author Peter Kietzmann , April 2019 * @author Francisco Molina * * @} */ #ifndef OPENWSN_RADIO_H #define OPENWSN_RADIO_H #ifdef __cplusplus extern "C" { #endif #include "net/netdev.h" #include "net/ieee802154/radio.h" #include "radio.h" /** * @brief Initialize OpenWSN radio * * @param[in] radio_dev pointer to a dev interface * * @return PID of OpenWSN thread * @return -1 on initialization error */ int openwsn_radio_init(void *radio_dev); /** * @brief OpenWSN radio variables structure */ typedef struct { #if IS_ACTIVE(MODULE_OPENWSN_RADIO_NETDEV) netdev_t *dev; /**< netdev device */ #else ieee802154_dev_t *dev; /**< radio hal */ #endif radio_capture_cbt startFrame_cb; /**< start of frame capture callback */ radio_capture_cbt endFrame_cb; /**< end of frame capture callback */ } openwsn_radio_t; #ifdef __cplusplus } #endif #endif /* OPENWSN_RADIO_H */ /** @} */