1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-16 16:52:43 +01:00
RIOT/drivers/nrf24l01p_ng/include/nrf24l01p_ng_communication.h
2021-09-01 21:38:40 +02:00

250 lines
6.2 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
*/
void nrf24l01p_ng_acquire(nrf24l01p_ng_t *dev);
/**
* @brief Release the SPI bus of the transceiver
*
* @param[in] dev NRF24L01+ device handle
*/
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 */
/** @} */