mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-16 01:52:44 +01:00
f7a77ebb04
The driver uses the netdev interface. Due to the limited capabilities of the transceiver (32 byte FIFO and no source address in the layer2 frame), it relies on 6LowPAN compression and adds the source address to the frame for that.
254 lines
6.3 KiB
C
254 lines
6.3 KiB
C
/*
|
|
* Copyright (C) 2019 Otto-von-Guericke-Universität Magdeburg
|
|
*
|
|
* 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 drivers_nrf24l01p_ng
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Functions to communicate with the NRF24L01+ (NG) transceiver
|
|
* via SPI
|
|
*
|
|
* @author Fabian Hüßler <fabian.huessler@ovgu.de>
|
|
*/
|
|
#ifndef NRF24L01P_NG_COMMUNICATION_H
|
|
#define NRF24L01P_NG_COMMUNICATION_H
|
|
|
|
#include "nrf24l01p_ng.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Mask for 5 bit register address
|
|
*/
|
|
#define NRF24L01P_NG_ADDR_MASK (0x1F)
|
|
|
|
/**
|
|
* @brief Mask for 3 bit pipe number
|
|
*/
|
|
#define NRF24L01P_NG_PIPE_MASK (0x07)
|
|
|
|
/**
|
|
* @brief Read register value
|
|
* (1 to 5 bytes)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_R_REGISTER(reg) \
|
|
(0x00 | ((reg) & NRF24L01P_NG_ADDR_MASK))
|
|
|
|
/**
|
|
* @brief Write register value
|
|
* (1 to 5 bytes)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_W_REGISTER(reg) \
|
|
(0x20 | ((reg) & NRF24L01P_NG_ADDR_MASK))
|
|
|
|
/**
|
|
* @brief Read RX payload buffer
|
|
* (1 to 32 bytes)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_R_RX_PAYLOAD (0x61)
|
|
|
|
/**
|
|
* @brief Write TX payload buffer
|
|
* (1 to 32 bytes)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_W_TX_PAYLOAD (0xA0)
|
|
|
|
/**
|
|
* @brief Flush TX buffer
|
|
* (0 bytes data)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_FLUSH_TX (0xE1)
|
|
|
|
/**
|
|
* @brief Flush RX buffer
|
|
* (0 bytes data)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_FLUSH_RX (0xE2)
|
|
|
|
/**
|
|
* @brief Reuse last transmitted payload
|
|
* (0 bytes data)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_REUSE_TX_PL (0xE3)
|
|
|
|
/**
|
|
* @brief Read RX payload width for the top R_RX_PAYLOAD in RX FIFO
|
|
* (1 byte data)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_R_RX_PL_WID (0x60)
|
|
|
|
/**
|
|
* @brief Write payload to be transmitted together with ACK for certain pipe
|
|
* (1 to 32 bytes data)
|
|
*/
|
|
#define NRF24L01P_NG_CMD_W_ACK_PAYLOAD(pipe) \
|
|
(0xA8 | ((pipe) & NRF24L01P_NG_PIPE_MASK))
|
|
|
|
/**
|
|
* @brief Disable auto ACK on this specific frame
|
|
*/
|
|
#define NRF24L01P_NG_CMD_W_TX_PAYLOAD_NO_ACK (0xB0)
|
|
|
|
/**
|
|
* @brief No operation
|
|
*/
|
|
#define NRF24L01P_NG_CMD_NOP (0xFF)
|
|
|
|
/**
|
|
* @brief Acquire the SPI bus of the transceiver
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
*
|
|
* @return @see spi_acquire
|
|
*/
|
|
int nrf24l01p_ng_acquire(nrf24l01p_ng_t *dev);
|
|
|
|
/**
|
|
* @brief Release the SPI bus of the transceiver
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
*
|
|
* @return @see spi_release
|
|
*/
|
|
void nrf24l01p_ng_release(nrf24l01p_ng_t *dev);
|
|
|
|
/**
|
|
* @brief Read a register value
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
* @param[in] reg Register address
|
|
* @param[out] dest Output register
|
|
* @param[in] len Output register width
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_read_reg(const nrf24l01p_ng_t *dev, uint8_t reg,
|
|
uint8_t *dest, size_t len);
|
|
|
|
/**
|
|
* @brief Write a register value
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
* @param[in] reg Register address
|
|
* @param[in] src Data to be written into the register
|
|
* @param[in] len Register width
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_write_reg(const nrf24l01p_ng_t *dev, uint8_t reg,
|
|
const uint8_t *src, size_t len);
|
|
|
|
/**
|
|
* @brief Read received payload
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
* @param[out] dest Output payload buffer
|
|
* @param[in] len Output payload length
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_read_rx_payload(const nrf24l01p_ng_t *dev, void *dest,
|
|
size_t len);
|
|
|
|
/**
|
|
* @brief Write payload to be transmitted
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
* @param[in] src Input payload buffer
|
|
* @param[in] len Input payload length
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_write_tx_payload(const nrf24l01p_ng_t *dev,
|
|
const void *src, size_t len);
|
|
|
|
/**
|
|
* @brief Flush TX FIFO
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_flush_tx(const nrf24l01p_ng_t *dev);
|
|
|
|
/**
|
|
* @brief Flush RX FIFO
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_flush_rx(const nrf24l01p_ng_t *dev);
|
|
|
|
/**
|
|
* @brief Reuse TX payload in FIFO
|
|
*
|
|
* This function can be used to reattempt to transmit a frame, after a MAX_RT
|
|
* interrupt was triggered.
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_reuse_tx_pl(const nrf24l01p_ng_t *dev);
|
|
|
|
/**
|
|
* @brief Read received payload width
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
* @param[out] dest Payload width
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_read_rx_pl_width(const nrf24l01p_ng_t *dev,
|
|
uint8_t *dest);
|
|
|
|
/**
|
|
* @brief Write Payload to be transmitted in an ACK frame
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
* @param[in] src Input payload buffer
|
|
* @param[in] len Input payload length
|
|
* @param[in] pipe Index of data pipe
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_write_ack_pl(const nrf24l01p_ng_t *dev, const void *src,
|
|
size_t len, uint8_t pipe);
|
|
|
|
/**
|
|
* @brief Write payload to be transmitted but do not expect an ACK for
|
|
* this frame
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
* @param[in] src Input payload buffer
|
|
* @param[in] len Input payload length
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_write_tx_pl_no_ack(const nrf24l01p_ng_t *dev,
|
|
const void *src, size_t len);
|
|
|
|
/**
|
|
* @brief Get status register value
|
|
*
|
|
* @param[in] dev NRF24L01+ device handle
|
|
*
|
|
* @return Status register value
|
|
*/
|
|
uint8_t nrf24l01p_ng_get_status(const nrf24l01p_ng_t *dev);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* NRF24L01P_NG_COMMUNICATION_H */
|
|
/** @} */
|