mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
drivers/nrf24l01p: migrate to ztimer
This commit is contained in:
parent
90da7dcdfe
commit
24a848e844
@ -1,4 +1,4 @@
|
|||||||
FEATURES_REQUIRED += periph_gpio
|
FEATURES_REQUIRED += periph_gpio
|
||||||
FEATURES_REQUIRED += periph_gpio_irq
|
FEATURES_REQUIRED += periph_gpio_irq
|
||||||
FEATURES_REQUIRED += periph_spi
|
FEATURES_REQUIRED += periph_spi
|
||||||
USEMODULE += xtimer
|
USEMODULE += ztimer_usec
|
||||||
|
@ -19,17 +19,13 @@
|
|||||||
#include "mutex.h"
|
#include "mutex.h"
|
||||||
#include "periph/gpio.h"
|
#include "periph/gpio.h"
|
||||||
#include "periph/spi.h"
|
#include "periph/spi.h"
|
||||||
#include "xtimer.h"
|
#include "ztimer.h"
|
||||||
#include "thread.h"
|
#include "thread.h"
|
||||||
#include "msg.h"
|
#include "msg.h"
|
||||||
|
|
||||||
#define ENABLE_DEBUG 0
|
#define ENABLE_DEBUG 0
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
#define DELAY_CS_TOGGLE_TICKS (xtimer_ticks_from_usec(DELAY_CS_TOGGLE_US))
|
|
||||||
#define DELAY_AFTER_FUNC_TICKS (xtimer_ticks_from_usec(DELAY_AFTER_FUNC_US))
|
|
||||||
#define DELAY_CHANGE_TXRX_TICKS (xtimer_ticks_from_usec(DELAY_CHANGE_TXRX_US))
|
|
||||||
|
|
||||||
#define SPI_MODE SPI_MODE_0
|
#define SPI_MODE SPI_MODE_0
|
||||||
#define SPI_CLK SPI_CLK_400KHZ
|
#define SPI_CLK SPI_CLK_400KHZ
|
||||||
|
|
||||||
@ -43,7 +39,7 @@ int nrf24l01p_read_reg(const nrf24l01p_t *dev, char reg, char *answer)
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +52,7 @@ int nrf24l01p_write_reg(const nrf24l01p_t *dev, char reg, char write)
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -87,7 +83,7 @@ int nrf24l01p_init(nrf24l01p_t *dev, spi_t spi, gpio_t ce, gpio_t cs, gpio_t irq
|
|||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
}
|
}
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
/* Flush TX FIFIO */
|
/* Flush TX FIFIO */
|
||||||
status = nrf24l01p_flush_tx_fifo(dev);
|
status = nrf24l01p_flush_tx_fifo(dev);
|
||||||
@ -191,7 +187,7 @@ int nrf24l01p_on(const nrf24l01p_t *dev)
|
|||||||
nrf24l01p_read_reg(dev, REG_CONFIG, &read);
|
nrf24l01p_read_reg(dev, REG_CONFIG, &read);
|
||||||
status = nrf24l01p_write_reg(dev, REG_CONFIG, (read | PWR_UP));
|
status = nrf24l01p_write_reg(dev, REG_CONFIG, (read | PWR_UP));
|
||||||
|
|
||||||
xtimer_usleep(DELAY_CHANGE_PWR_MODE_US);
|
ztimer_sleep(ZTIMER_USEC, DELAY_CHANGE_PWR_MODE_US);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -204,7 +200,7 @@ int nrf24l01p_off(const nrf24l01p_t *dev)
|
|||||||
nrf24l01p_read_reg(dev, REG_CONFIG, &read);
|
nrf24l01p_read_reg(dev, REG_CONFIG, &read);
|
||||||
status = nrf24l01p_write_reg(dev, REG_CONFIG, (read & ~PWR_UP));
|
status = nrf24l01p_write_reg(dev, REG_CONFIG, (read & ~PWR_UP));
|
||||||
|
|
||||||
xtimer_usleep(DELAY_CHANGE_PWR_MODE_US);
|
ztimer_sleep(ZTIMER_USEC, DELAY_CHANGE_PWR_MODE_US);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -212,10 +208,10 @@ int nrf24l01p_off(const nrf24l01p_t *dev)
|
|||||||
void nrf24l01p_transmit(const nrf24l01p_t *dev)
|
void nrf24l01p_transmit(const nrf24l01p_t *dev)
|
||||||
{
|
{
|
||||||
gpio_set(dev->ce);
|
gpio_set(dev->ce);
|
||||||
xtimer_usleep(DELAY_CE_HIGH_US); /* at least 10 us high */
|
ztimer_sleep(ZTIMER_USEC, DELAY_CE_HIGH_US); /* at least 10 us high */
|
||||||
gpio_clear(dev->ce);
|
gpio_clear(dev->ce);
|
||||||
|
|
||||||
xtimer_spin(DELAY_CHANGE_TXRX_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_CHANGE_TXRX_US);
|
||||||
}
|
}
|
||||||
|
|
||||||
int nrf24l01p_read_payload(const nrf24l01p_t *dev, char *answer, unsigned int size)
|
int nrf24l01p_read_payload(const nrf24l01p_t *dev, char *answer, unsigned int size)
|
||||||
@ -223,7 +219,7 @@ int nrf24l01p_read_payload(const nrf24l01p_t *dev, char *answer, unsigned int si
|
|||||||
/* Acquire exclusive access to the bus. */
|
/* Acquire exclusive access to the bus. */
|
||||||
spi_acquire(dev->spi, dev->cs, SPI_MODE, SPI_CLK);
|
spi_acquire(dev->spi, dev->cs, SPI_MODE, SPI_CLK);
|
||||||
spi_transfer_regs(dev->spi, dev->cs, CMD_R_RX_PAYLOAD, NULL, answer, size);
|
spi_transfer_regs(dev->spi, dev->cs, CMD_R_RX_PAYLOAD, NULL, answer, size);
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
@ -254,12 +250,12 @@ void nrf24l01p_get_id(const nrf24l01p_t *dev, unsigned int *pid)
|
|||||||
void nrf24l01p_start(const nrf24l01p_t *dev)
|
void nrf24l01p_start(const nrf24l01p_t *dev)
|
||||||
{
|
{
|
||||||
gpio_set(dev->ce);
|
gpio_set(dev->ce);
|
||||||
xtimer_usleep(DELAY_CE_START_US);
|
ztimer_sleep(ZTIMER_USEC, DELAY_CE_START_US);
|
||||||
}
|
}
|
||||||
|
|
||||||
void nrf24l01p_stop(const nrf24l01p_t *dev)
|
void nrf24l01p_stop(const nrf24l01p_t *dev)
|
||||||
{
|
{
|
||||||
xtimer_spin(DELAY_CS_TOGGLE_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_CS_TOGGLE_US);
|
||||||
gpio_clear(dev->ce);
|
gpio_clear(dev->ce);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -273,7 +269,7 @@ int nrf24l01p_preload(const nrf24l01p_t *dev, char *data, unsigned int size)
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -291,7 +287,7 @@ int nrf24l01p_set_address_width(const nrf24l01p_t *dev, nrf24l01p_aw_t aw)
|
|||||||
char aw_setup;
|
char aw_setup;
|
||||||
nrf24l01p_read_reg(dev, REG_SETUP_AW, &aw_setup);
|
nrf24l01p_read_reg(dev, REG_SETUP_AW, &aw_setup);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
switch (aw) {
|
switch (aw) {
|
||||||
case NRF24L01P_AW_3BYTE:
|
case NRF24L01P_AW_3BYTE:
|
||||||
@ -367,7 +363,7 @@ int nrf24l01p_set_tx_address(const nrf24l01p_t *dev, const uint8_t *saddr, unsig
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
return (int)length;
|
return (int)length;
|
||||||
}
|
}
|
||||||
@ -394,7 +390,7 @@ int nrf24l01p_set_tx_address_long(const nrf24l01p_t *dev, uint64_t saddr, unsign
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
return (int)length;
|
return (int)length;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -411,7 +407,7 @@ uint64_t nrf24l01p_get_tx_address_long(const nrf24l01p_t *dev)
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
for (int i = 0; i < INITIAL_ADDRESS_WIDTH; i++) {
|
for (int i = 0; i < INITIAL_ADDRESS_WIDTH; i++) {
|
||||||
saddr_64 |= (((uint64_t) addr_array[i]) << (8 * (INITIAL_ADDRESS_WIDTH - i - 1)));
|
saddr_64 |= (((uint64_t) addr_array[i]) << (8 * (INITIAL_ADDRESS_WIDTH - i - 1)));
|
||||||
@ -461,7 +457,7 @@ int nrf24l01p_set_rx_address(const nrf24l01p_t *dev, nrf24l01p_rx_pipe_t pipe, c
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
/* Enable this pipe */
|
/* Enable this pipe */
|
||||||
nrf24l01p_enable_pipe(dev, pipe);
|
nrf24l01p_enable_pipe(dev, pipe);
|
||||||
@ -529,7 +525,7 @@ uint64_t nrf24l01p_get_rx_address_long(const nrf24l01p_t *dev, nrf24l01p_rx_pipe
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
for (int i = 0; i < INITIAL_ADDRESS_WIDTH; i++) {
|
for (int i = 0; i < INITIAL_ADDRESS_WIDTH; i++) {
|
||||||
saddr_64 |= (((uint64_t) addr_array[i]) << (8 * (INITIAL_ADDRESS_WIDTH - i - 1)));
|
saddr_64 |= (((uint64_t) addr_array[i]) << (8 * (INITIAL_ADDRESS_WIDTH - i - 1)));
|
||||||
@ -576,7 +572,7 @@ int nrf24l01p_get_status(const nrf24l01p_t *dev)
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
return (int)status;
|
return (int)status;
|
||||||
}
|
}
|
||||||
@ -633,7 +629,7 @@ int nrf24l01p_set_txmode(const nrf24l01p_t *dev)
|
|||||||
conf &= ~(PRIM_RX);
|
conf &= ~(PRIM_RX);
|
||||||
status = nrf24l01p_write_reg(dev, REG_CONFIG, conf);
|
status = nrf24l01p_write_reg(dev, REG_CONFIG, conf);
|
||||||
|
|
||||||
xtimer_usleep(DELAY_CHANGE_TXRX_US);
|
ztimer_sleep(ZTIMER_USEC, DELAY_CHANGE_TXRX_US);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -654,7 +650,7 @@ int nrf24l01p_set_rxmode(const nrf24l01p_t *dev)
|
|||||||
|
|
||||||
nrf24l01p_start(dev);
|
nrf24l01p_start(dev);
|
||||||
|
|
||||||
xtimer_usleep(DELAY_CHANGE_TXRX_US);
|
ztimer_sleep(ZTIMER_USEC, DELAY_CHANGE_TXRX_US);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -893,7 +889,7 @@ int nrf24l01p_flush_tx_fifo(const nrf24l01p_t *dev)
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -906,7 +902,7 @@ int nrf24l01p_flush_rx_fifo(const nrf24l01p_t *dev)
|
|||||||
/* Release the bus for other threads. */
|
/* Release the bus for other threads. */
|
||||||
spi_release(dev->spi);
|
spi_release(dev->spi);
|
||||||
|
|
||||||
xtimer_spin(DELAY_AFTER_FUNC_TICKS);
|
ztimer_spin(ZTIMER_USEC, DELAY_AFTER_FUNC_US);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@ include ../Makefile.tests_common
|
|||||||
USEMODULE += shell
|
USEMODULE += shell
|
||||||
USEMODULE += shell_commands
|
USEMODULE += shell_commands
|
||||||
USEMODULE += ps
|
USEMODULE += ps
|
||||||
USEMODULE += xtimer
|
USEMODULE += ztimer_usec
|
||||||
USEMODULE += nrf24l01p
|
USEMODULE += nrf24l01p
|
||||||
|
|
||||||
# set default device parameters in case they are undefined
|
# set default device parameters in case they are undefined
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
#include "nrf24l01p_settings.h"
|
#include "nrf24l01p_settings.h"
|
||||||
#include "periph/spi.h"
|
#include "periph/spi.h"
|
||||||
#include "periph/gpio.h"
|
#include "periph/gpio.h"
|
||||||
#include "xtimer.h"
|
#include "ztimer.h"
|
||||||
#include "shell.h"
|
#include "shell.h"
|
||||||
#include "shell_commands.h"
|
#include "shell_commands.h"
|
||||||
#include "thread.h"
|
#include "thread.h"
|
||||||
@ -231,7 +231,7 @@ int cmd_send(int argc, char **argv)
|
|||||||
/* trigger transmitting */
|
/* trigger transmitting */
|
||||||
nrf24l01p_transmit(&nrf24l01p_0);
|
nrf24l01p_transmit(&nrf24l01p_0);
|
||||||
/* wait while data is pysically transmitted */
|
/* wait while data is pysically transmitted */
|
||||||
xtimer_usleep(DELAY_DATA_ON_AIR);
|
ztimer_sleep(ZTIMER_USEC, DELAY_DATA_ON_AIR);
|
||||||
/* get status of the transceiver */
|
/* get status of the transceiver */
|
||||||
status = nrf24l01p_get_status(&nrf24l01p_0);
|
status = nrf24l01p_get_status(&nrf24l01p_0);
|
||||||
if (status < 0) {
|
if (status < 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user