1
0
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:
Juergen Fitschen 2022-01-28 13:04:44 +01:00 committed by GitHub
commit 617eb359c0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 19 additions and 28 deletions

View File

@ -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

View File

@ -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

View File

@ -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 */