mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #17565 from fjmolinas/pr_dose_to_ztimer
drivers/dose: migrate to ztimer_usec
This commit is contained in:
commit
617eb359c0
@ -12,4 +12,4 @@ USEMODULE += eui_provider
|
|||||||
USEMODULE += iolist
|
USEMODULE += iolist
|
||||||
USEMODULE += netdev_eth
|
USEMODULE += netdev_eth
|
||||||
USEMODULE += random
|
USEMODULE += random
|
||||||
USEMODULE += xtimer
|
USEMODULE += ztimer_usec
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
|
|
||||||
#include "net/eui_provider.h"
|
#include "net/eui_provider.h"
|
||||||
#include "net/netdev/eth.h"
|
#include "net/netdev/eth.h"
|
||||||
|
#include "timex.h"
|
||||||
|
|
||||||
#define ENABLE_DEBUG 0
|
#define ENABLE_DEBUG 0
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
@ -40,7 +41,7 @@ static dose_signal_t state_transit_send(dose_t *ctx, dose_signal_t signal);
|
|||||||
static void state(dose_t *ctx, dose_signal_t src);
|
static void state(dose_t *ctx, dose_signal_t src);
|
||||||
static void _isr_uart(void *arg, uint8_t c);
|
static void _isr_uart(void *arg, uint8_t c);
|
||||||
static void _isr_gpio(void *arg);
|
static void _isr_gpio(void *arg);
|
||||||
static void _isr_xtimer(void *arg);
|
static void _isr_ztimer(void *arg);
|
||||||
static void clear_recv_buf(dose_t *ctx);
|
static void clear_recv_buf(dose_t *ctx);
|
||||||
static void _isr(netdev_t *netdev);
|
static void _isr(netdev_t *netdev);
|
||||||
static int _recv(netdev_t *dev, void *buf, size_t len, void *info);
|
static int _recv(netdev_t *dev, void *buf, size_t len, void *info);
|
||||||
@ -53,9 +54,6 @@ static int _init(netdev_t *dev);
|
|||||||
static void _poweron(dose_t *dev);
|
static void _poweron(dose_t *dev);
|
||||||
static void _poweroff(dose_t *dev, dose_state_t sleep_state);
|
static void _poweroff(dose_t *dev, dose_state_t sleep_state);
|
||||||
|
|
||||||
/* smallest possible xtimer timeout */
|
|
||||||
static const xtimer_ticks32_t xtimer_min_timeout = {.ticks32 = XTIMER_BACKOFF};
|
|
||||||
|
|
||||||
static uint16_t crc16_update(uint16_t crc, uint8_t octet)
|
static uint16_t crc16_update(uint16_t crc, uint8_t octet)
|
||||||
{
|
{
|
||||||
crc = (uint8_t)(crc >> 8) | (crc << 8);
|
crc = (uint8_t)(crc >> 8) | (crc << 8);
|
||||||
@ -163,7 +161,7 @@ static void _dose_watchdog_cb(void *arg, int chan)
|
|||||||
}
|
}
|
||||||
|
|
||||||
DEBUG_PUTS("timeout");
|
DEBUG_PUTS("timeout");
|
||||||
state(&_dose_base[i], DOSE_SIGNAL_XTIMER);
|
state(&_dose_base[i], DOSE_SIGNAL_ZTIMER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -187,9 +185,8 @@ static dose_signal_t state_transit_blocked(dose_t *ctx, dose_signal_t signal)
|
|||||||
(void) signal;
|
(void) signal;
|
||||||
uint32_t backoff;
|
uint32_t backoff;
|
||||||
|
|
||||||
backoff = random_uint32_range(xtimer_usec_from_ticks(xtimer_min_timeout),
|
backoff = random_uint32_range(0, 2 * ctx->timeout_base);
|
||||||
2 * ctx->timeout_base);
|
ztimer_set(ZTIMER_USEC, &ctx->timeout, backoff);
|
||||||
xtimer_set(&ctx->timeout, backoff);
|
|
||||||
|
|
||||||
return DOSE_SIGNAL_NONE;
|
return DOSE_SIGNAL_NONE;
|
||||||
}
|
}
|
||||||
@ -262,7 +259,7 @@ static dose_signal_t state_transit_recv(dose_t *ctx, dose_signal_t signal)
|
|||||||
|
|
||||||
if (rc == DOSE_SIGNAL_NONE && !IS_ACTIVE(MODULE_DOSE_WATCHDOG)) {
|
if (rc == DOSE_SIGNAL_NONE && !IS_ACTIVE(MODULE_DOSE_WATCHDOG)) {
|
||||||
/* No signal is returned. We stay in the RECV state. */
|
/* No signal is returned. We stay in the RECV state. */
|
||||||
xtimer_set(&ctx->timeout, ctx->timeout_base);
|
ztimer_set(ZTIMER_USEC, &ctx->timeout, ctx->timeout_base);
|
||||||
}
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
@ -281,7 +278,7 @@ static dose_signal_t state_transit_send(dose_t *ctx, dose_signal_t signal)
|
|||||||
* will bring us back to the BLOCKED state after _send has emitted
|
* will bring us back to the BLOCKED state after _send has emitted
|
||||||
* its last octet. */
|
* its last octet. */
|
||||||
#ifndef MODULE_PERIPH_UART_COLLISION
|
#ifndef MODULE_PERIPH_UART_COLLISION
|
||||||
xtimer_set(&ctx->timeout, ctx->timeout_base);
|
ztimer_set(ZTIMER_USEC, &ctx->timeout, ctx->timeout_base);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return DOSE_SIGNAL_NONE;
|
return DOSE_SIGNAL_NONE;
|
||||||
@ -305,10 +302,10 @@ static void state(dose_t *ctx, dose_signal_t signal)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case DOSE_STATE_SEND + DOSE_SIGNAL_END:
|
case DOSE_STATE_SEND + DOSE_SIGNAL_END:
|
||||||
case DOSE_STATE_SEND + DOSE_SIGNAL_XTIMER:
|
case DOSE_STATE_SEND + DOSE_SIGNAL_ZTIMER:
|
||||||
case DOSE_STATE_INIT + DOSE_SIGNAL_INIT:
|
case DOSE_STATE_INIT + DOSE_SIGNAL_INIT:
|
||||||
case DOSE_STATE_RECV + DOSE_SIGNAL_END:
|
case DOSE_STATE_RECV + DOSE_SIGNAL_END:
|
||||||
case DOSE_STATE_RECV + DOSE_SIGNAL_XTIMER:
|
case DOSE_STATE_RECV + DOSE_SIGNAL_ZTIMER:
|
||||||
signal = state_transit_idle(ctx, signal);
|
signal = state_transit_idle(ctx, signal);
|
||||||
ctx->state = DOSE_STATE_IDLE;
|
ctx->state = DOSE_STATE_IDLE;
|
||||||
break;
|
break;
|
||||||
@ -322,7 +319,7 @@ static void state(dose_t *ctx, dose_signal_t signal)
|
|||||||
ctx->state = DOSE_STATE_RECV;
|
ctx->state = DOSE_STATE_RECV;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DOSE_STATE_BLOCKED + DOSE_SIGNAL_XTIMER:
|
case DOSE_STATE_BLOCKED + DOSE_SIGNAL_ZTIMER:
|
||||||
case DOSE_STATE_SEND + DOSE_SIGNAL_UART:
|
case DOSE_STATE_SEND + DOSE_SIGNAL_UART:
|
||||||
signal = state_transit_send(ctx, signal);
|
signal = state_transit_send(ctx, signal);
|
||||||
ctx->state = DOSE_STATE_SEND;
|
ctx->state = DOSE_STATE_SEND;
|
||||||
@ -354,7 +351,7 @@ static void _isr_gpio(void *arg)
|
|||||||
state(dev, DOSE_SIGNAL_GPIO);
|
state(dev, DOSE_SIGNAL_GPIO);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _isr_xtimer(void *arg)
|
static void _isr_ztimer(void *arg)
|
||||||
{
|
{
|
||||||
dose_t *dev = arg;
|
dose_t *dev = arg;
|
||||||
|
|
||||||
@ -364,7 +361,7 @@ static void _isr_xtimer(void *arg)
|
|||||||
#endif
|
#endif
|
||||||
case DOSE_STATE_BLOCKED:
|
case DOSE_STATE_BLOCKED:
|
||||||
case DOSE_STATE_SEND:
|
case DOSE_STATE_SEND:
|
||||||
state(dev, DOSE_SIGNAL_XTIMER);
|
state(dev, DOSE_SIGNAL_ZTIMER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
;
|
;
|
||||||
@ -516,7 +513,7 @@ static inline void _send_done(dose_t *ctx, bool collision)
|
|||||||
#ifdef MODULE_PERIPH_UART_COLLISION
|
#ifdef MODULE_PERIPH_UART_COLLISION
|
||||||
uart_collision_detect_disable(ctx->uart);
|
uart_collision_detect_disable(ctx->uart);
|
||||||
if (collision) {
|
if (collision) {
|
||||||
state(ctx, DOSE_SIGNAL_XTIMER);
|
state(ctx, DOSE_SIGNAL_ZTIMER);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
(void)ctx;
|
(void)ctx;
|
||||||
@ -775,18 +772,12 @@ void dose_setup(dose_t *ctx, const dose_params_t *params, uint8_t index)
|
|||||||
);
|
);
|
||||||
|
|
||||||
/* The timeout base is the minimal timeout base used for this driver.
|
/* The timeout base is the minimal timeout base used for this driver.
|
||||||
* We have to ensure it is above the XTIMER_BACKOFF. Otherwise state
|
|
||||||
* transitions are triggered from another state transition setting up the
|
|
||||||
* timeout.
|
|
||||||
* To calculate how long it takes to transfer one byte we assume
|
* To calculate how long it takes to transfer one byte we assume
|
||||||
* 8 data bits + 1 start bit + 1 stop bit per byte.
|
* 8 data bits + 1 start bit + 1 stop bit per byte.
|
||||||
*/
|
*/
|
||||||
ctx->timeout_base = CONFIG_DOSE_TIMEOUT_BYTES * 10UL * US_PER_SEC / params->baudrate;
|
ctx->timeout_base = CONFIG_DOSE_TIMEOUT_BYTES * 10UL * US_PER_SEC / params->baudrate;
|
||||||
if (ctx->timeout_base < xtimer_usec_from_ticks(xtimer_min_timeout)) {
|
|
||||||
ctx->timeout_base = xtimer_usec_from_ticks(xtimer_min_timeout);
|
|
||||||
}
|
|
||||||
DEBUG("dose timeout set to %" PRIu32 " µs\n", ctx->timeout_base);
|
DEBUG("dose timeout set to %" PRIu32 " µs\n", ctx->timeout_base);
|
||||||
ctx->timeout.callback = _isr_xtimer;
|
ctx->timeout.callback = _isr_ztimer;
|
||||||
ctx->timeout.arg = ctx;
|
ctx->timeout.arg = ctx;
|
||||||
|
|
||||||
#ifdef MODULE_DOSE_WATCHDOG
|
#ifdef MODULE_DOSE_WATCHDOG
|
||||||
|
@ -82,7 +82,7 @@
|
|||||||
#include "net/eui48.h"
|
#include "net/eui48.h"
|
||||||
#include "bitarithm.h"
|
#include "bitarithm.h"
|
||||||
#include "mutex.h"
|
#include "mutex.h"
|
||||||
#include "xtimer.h"
|
#include "ztimer.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@ -120,7 +120,7 @@ typedef enum {
|
|||||||
DOSE_SIGNAL_INIT = 0x10, /**< Init the state machine */
|
DOSE_SIGNAL_INIT = 0x10, /**< Init the state machine */
|
||||||
DOSE_SIGNAL_GPIO = 0x20, /**< Sense GPIO detected a falling edge */
|
DOSE_SIGNAL_GPIO = 0x20, /**< Sense GPIO detected a falling edge */
|
||||||
DOSE_SIGNAL_UART = 0x30, /**< Octet has been received */
|
DOSE_SIGNAL_UART = 0x30, /**< Octet has been received */
|
||||||
DOSE_SIGNAL_XTIMER = 0x40, /**< Timer timed out */
|
DOSE_SIGNAL_ZTIMER = 0x40, /**< Timer timed out */
|
||||||
DOSE_SIGNAL_SEND = 0x50, /**< Enter send state */
|
DOSE_SIGNAL_SEND = 0x50, /**< Enter send state */
|
||||||
DOSE_SIGNAL_END = 0x60 /**< Leave send state */
|
DOSE_SIGNAL_END = 0x60 /**< Leave send state */
|
||||||
} dose_signal_t;
|
} dose_signal_t;
|
||||||
@ -165,7 +165,7 @@ typedef enum {
|
|||||||
/**
|
/**
|
||||||
* @brief Hardware timer to use with the `dose_watchdog` module.
|
* @brief Hardware timer to use with the `dose_watchdog` module.
|
||||||
*
|
*
|
||||||
* This will be used to detect RX timeout instead of xtimer to speed up
|
* This will be used to detect RX timeout instead of ztimer to speed up
|
||||||
* the RX path when high data rates / less CPU overhead is required.
|
* the RX path when high data rates / less CPU overhead is required.
|
||||||
*/
|
*/
|
||||||
#if DOXYGEN
|
#if DOXYGEN
|
||||||
@ -197,7 +197,7 @@ typedef struct {
|
|||||||
gpio_t sense_pin; /**< GPIO to sense for start bits on the UART's rx line */
|
gpio_t sense_pin; /**< GPIO to sense for start bits on the UART's rx line */
|
||||||
#endif
|
#endif
|
||||||
gpio_t standby_pin; /**< GPIO to put the CAN transceiver in standby mode */
|
gpio_t standby_pin; /**< GPIO to put the CAN transceiver in standby mode */
|
||||||
xtimer_t timeout; /**< Timeout timer ensuring always to get back to IDLE state */
|
ztimer_t timeout; /**< Timeout timer ensuring always to get back to IDLE state */
|
||||||
uint32_t timeout_base; /**< Base timeout in us */
|
uint32_t timeout_base; /**< Base timeout in us */
|
||||||
uart_t uart; /**< UART device to use */
|
uart_t uart; /**< UART device to use */
|
||||||
uint8_t uart_octet; /**< Last received octet */
|
uint8_t uart_octet; /**< Last received octet */
|
||||||
|
Loading…
Reference in New Issue
Block a user