2016-02-27 01:39:27 +01:00
|
|
|
/****************************************************************************
|
2017-07-03 06:33:17 +02:00
|
|
|
* drivers/wireless/ieee802154/mrf24j40/mrf24j40.h
|
2016-02-27 01:39:27 +01:00
|
|
|
*
|
|
|
|
* Copyright (C) 2015-2016 Sebastien Lorquet. All rights reserved.
|
|
|
|
* Author: Sebastien Lorquet <sebastien@lorquet.fr>
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
|
|
|
* used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
#ifndef __DRIVERS_WIRELESS_IEEE802154_MRF24J40_H
|
|
|
|
#define __DRIVERS_WIRELESS_IEEE802154_MRF24J40_H
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
2020-02-01 08:17:32 +01:00
|
|
|
#include <nuttx/semaphore.h>
|
2017-07-10 09:10:20 +02:00
|
|
|
#include <nuttx/wqueue.h>
|
|
|
|
#include <nuttx/spi/spi.h>
|
|
|
|
|
|
|
|
#include <nuttx/wireless/ieee802154/ieee802154_mac.h>
|
|
|
|
#include <nuttx/wireless/ieee802154/ieee802154_radio.h>
|
|
|
|
|
2017-07-12 03:12:50 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Pre-processor Definitions
|
|
|
|
****************************************************************************/
|
2017-07-10 09:10:20 +02:00
|
|
|
|
|
|
|
#define MRF24J40_GTS_SLOTS 2
|
|
|
|
|
|
|
|
/* Definitions for the device structure */
|
|
|
|
|
|
|
|
#define MRF24J40_RXMODE_NORMAL 0
|
|
|
|
#define MRF24J40_RXMODE_PROMISC 1
|
|
|
|
#define MRF24J40_RXMODE_NOCRC 2
|
|
|
|
|
|
|
|
#define MRF24J40_MODE_DEVICE 0
|
|
|
|
#define MRF24J40_MODE_COORD 1
|
|
|
|
#define MRF24J40_MODE_PANCOORD 2
|
|
|
|
|
|
|
|
/* Definitions for PA control on high power modules */
|
|
|
|
|
|
|
|
#define MRF24J40_PA_AUTO 1
|
|
|
|
#define MRF24J40_PA_ED 2
|
|
|
|
#define MRF24J40_PA_SLEEP 3
|
|
|
|
|
|
|
|
/* Formula for calculating default macMaxFrameWaitTime is on pg. 130
|
|
|
|
*
|
|
|
|
* For PHYs other than CSS and UWB, the attribute phyMaxFrameDuration is given by:
|
|
|
|
*
|
|
|
|
* phyMaxFrameDuration = phySHRDuration +
|
|
|
|
* ceiling([aMaxPHYPacketSize + 1] x phySymbolsPerOctet)
|
|
|
|
*
|
|
|
|
* where ceiling() is a function that returns the smallest integer value greater
|
|
|
|
* than or equal to its argument value. [1] pg. 158
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define MRF24J40_DEFAULT_MAX_FRAME_WAITTIME 1824
|
|
|
|
|
|
|
|
#define MRF24J40_SYMBOL_DURATION_PS 16000000
|
|
|
|
|
2017-07-12 03:12:50 +02:00
|
|
|
/* Clock configuration macros */
|
|
|
|
|
|
|
|
#define MRF24J40_BEACONINTERVAL_NSEC(beaconorder) \
|
2017-07-13 09:18:22 +02:00
|
|
|
(IEEE802154_BASE_SUPERFRAME_DURATION * (1 << beaconorder) * (16 * 1000))
|
2017-07-12 03:12:50 +02:00
|
|
|
|
2017-07-13 09:18:22 +02:00
|
|
|
#define MRF24J40_SUPERFRAMEDURATION_NSEC(sforder) \
|
|
|
|
(IEEE802154_BASE_SUPERFRAME_DURATION * (1 << sforder) * (16 * 1000))
|
2017-07-12 03:12:50 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
/* Configuration *************************************************************/
|
|
|
|
|
|
|
|
#ifndef CONFIG_SCHED_HPWORK
|
|
|
|
# error High priority work queue required in this driver
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_IEEE802154_MRF24J40_SPIMODE
|
|
|
|
# define CONFIG_IEEE802154_MRF24J40_SPIMODE SPIDEV_MODE0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_IEEE802154_MRF24J40_FREQUENCY
|
|
|
|
# define CONFIG_IEEE802154_MRF24J40_FREQUENCY 8000000
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_SPI_EXCHANGE
|
|
|
|
# error CONFIG_SPI_EXCHANGE required for this driver
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/****************************************************************************
|
2017-07-12 03:12:50 +02:00
|
|
|
* Public Types
|
2017-07-10 09:10:20 +02:00
|
|
|
****************************************************************************/
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
/* A MRF24J40 device instance */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
struct mrf24j40_radio_s
|
|
|
|
{
|
|
|
|
struct ieee802154_radio_s radio; /* The public device instance */
|
|
|
|
FAR struct ieee802154_radiocb_s *radiocb; /* Registered callbacks */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
/* Low-level MCU-specific support */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
FAR const struct mrf24j40_lower_s *lower;
|
|
|
|
FAR struct spi_dev_s *spi; /* Saved SPI interface instance */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
struct work_s irqwork; /* For deferring interrupt work to work queue */
|
|
|
|
struct work_s csma_pollwork; /* For deferring poll work to the work queue */
|
|
|
|
struct work_s gts_pollwork; /* For deferring poll work to the work queue */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
sem_t exclsem; /* Exclusive access to this struct */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
/* MAC Attributes */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
struct ieee802154_addr_s addr;
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-13 09:18:22 +02:00
|
|
|
uint8_t chan; /* 11 to 26 for the 2.4 GHz band */
|
|
|
|
uint8_t devmode; /* device mode: device, coord, pancoord */
|
|
|
|
uint8_t paenabled; /* enable usage of PA */
|
|
|
|
uint8_t rxmode; /* Reception mode: Main, no CRC, promiscuous */
|
|
|
|
int32_t txpower; /* TX power in mBm = dBm/100 */
|
2017-07-10 09:10:20 +02:00
|
|
|
struct ieee802154_cca_s cca; /* Clear channel assessement method */
|
2017-07-13 09:18:22 +02:00
|
|
|
uint32_t slpclkper; /* Sleep clock period (nanoseconds) */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
/* MAC PIB attributes */
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
uint32_t max_frame_waittime;
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
struct ieee802154_txdesc_s *txdelayed_desc;
|
|
|
|
struct ieee802154_txdesc_s *csma_desc;
|
|
|
|
bool txdelayed_busy : 1;
|
|
|
|
bool csma_busy : 1;
|
|
|
|
bool reschedule_csma : 1;
|
2017-06-20 18:57:24 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
bool rxenabled : 1;
|
2017-06-26 00:07:50 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
uint8_t bsn;
|
|
|
|
|
|
|
|
struct ieee802154_txdesc_s *gts_desc[MRF24J40_GTS_SLOTS];
|
|
|
|
bool gts_busy[MRF24J40_GTS_SLOTS];
|
|
|
|
};
|
|
|
|
|
|
|
|
/****************************************************************************
|
2017-07-12 03:12:50 +02:00
|
|
|
* Public Data
|
2017-07-10 09:10:20 +02:00
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
2017-07-12 03:12:50 +02:00
|
|
|
* Inline Functions
|
2017-07-10 09:10:20 +02:00
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: mrf24j40_spi_lock
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Acquire exclusive access to the shared SPI bus.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
static inline void mrf24j40_spi_lock(FAR struct spi_dev_s *spi)
|
|
|
|
{
|
|
|
|
SPI_LOCK(spi, 1);
|
|
|
|
SPI_SETBITS(spi, 8);
|
|
|
|
SPI_SETMODE(spi, CONFIG_IEEE802154_MRF24J40_SPIMODE);
|
|
|
|
SPI_SETFREQUENCY(spi, CONFIG_IEEE802154_MRF24J40_FREQUENCY);
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: mrf24j40_spi_unlock
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Release exclusive access to the shared SPI bus.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
2017-06-26 00:07:50 +02:00
|
|
|
|
2017-07-10 09:10:20 +02:00
|
|
|
static inline void mrf24j40_spi_unlock(FAR struct spi_dev_s *spi)
|
|
|
|
{
|
|
|
|
SPI_LOCK(spi,0);
|
|
|
|
}
|
2017-06-26 00:07:50 +02:00
|
|
|
|
2017-07-12 03:12:50 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Public Function Prototypes
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
int mrf24j40_interrupt(int irq, FAR void *context, FAR void *arg);
|
|
|
|
void mrf24j40_irqworker(FAR void *arg);
|
|
|
|
|
|
|
|
void mrf24j40_dopoll_csma(FAR void *arg);
|
|
|
|
void mrf24j40_dopoll_gts(FAR void *arg);
|
2017-07-03 06:33:17 +02:00
|
|
|
|
2017-07-12 03:12:50 +02:00
|
|
|
void mrf24j40_norm_setup(FAR struct mrf24j40_radio_s *dev,
|
|
|
|
FAR struct iob_s *frame, bool csma);
|
|
|
|
void mrf24j40_gts_setup(FAR struct mrf24j40_radio_s *dev, uint8_t gts,
|
|
|
|
FAR struct iob_s *frame);
|
|
|
|
void mrf24j40_setup_fifo(FAR struct mrf24j40_radio_s *dev,
|
|
|
|
FAR const uint8_t *buf, uint8_t length, uint32_t fifo_addr);
|
|
|
|
|
|
|
|
void mrf24j40_norm_trigger(FAR struct mrf24j40_radio_s *dev);
|
|
|
|
void mrf24j40_beacon_trigger(FAR struct mrf24j40_radio_s *dev);
|
|
|
|
|
|
|
|
#endif /* __DRIVERS_WIRELESS_IEEE802154_MRF24J40_H */
|