mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
drivers/dose: make use of periph_uart_collision feature
This commit is contained in:
parent
a51fb298dc
commit
0c5631bd52
@ -1,5 +1,6 @@
|
|||||||
FEATURES_REQUIRED += periph_gpio_irq
|
FEATURES_REQUIRED += periph_gpio_irq
|
||||||
FEATURES_REQUIRED += periph_uart
|
FEATURES_REQUIRED += periph_uart
|
||||||
|
FEATURES_OPTIONAL += periph_uart_collision
|
||||||
FEATURES_OPTIONAL += periph_uart_rxstart_irq
|
FEATURES_OPTIONAL += periph_uart_rxstart_irq
|
||||||
|
|
||||||
USEMODULE += eui_provider
|
USEMODULE += eui_provider
|
||||||
|
@ -201,9 +201,9 @@ static dose_signal_t state_transit_send(dose_t *ctx, dose_signal_t signal)
|
|||||||
/* Don't trace any END octets ... the timeout or the END signal
|
/* Don't trace any END octets ... the timeout or the END 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
|
||||||
xtimer_set(&ctx->timeout, ctx->timeout_base);
|
xtimer_set(&ctx->timeout, ctx->timeout_base);
|
||||||
|
#endif
|
||||||
return DOSE_SIGNAL_NONE;
|
return DOSE_SIGNAL_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -398,6 +398,10 @@ static int send_octet(dose_t *ctx, uint8_t c)
|
|||||||
{
|
{
|
||||||
uart_write(ctx->uart, (uint8_t *) &c, sizeof(c));
|
uart_write(ctx->uart, (uint8_t *) &c, sizeof(c));
|
||||||
|
|
||||||
|
#ifdef MODULE_PERIPH_UART_COLLISION
|
||||||
|
return uart_collision_detected(ctx->uart);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Wait for a state transition */
|
/* Wait for a state transition */
|
||||||
uint8_t new_state = wait_for_state(ctx, DOSE_STATE_ANY);
|
uint8_t new_state = wait_for_state(ctx, DOSE_STATE_ANY);
|
||||||
if (new_state != DOSE_STATE_SEND) {
|
if (new_state != DOSE_STATE_SEND) {
|
||||||
@ -432,6 +436,28 @@ static int send_data_octet(dose_t *ctx, uint8_t c)
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void _send_start(dose_t *ctx)
|
||||||
|
{
|
||||||
|
#ifdef MODULE_PERIPH_UART_COLLISION
|
||||||
|
uart_collision_detect_enable(ctx->uart);
|
||||||
|
#else
|
||||||
|
(void)ctx;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void _send_done(dose_t *ctx, bool collision)
|
||||||
|
{
|
||||||
|
#ifdef MODULE_PERIPH_UART_COLLISION
|
||||||
|
uart_collision_detect_disable(ctx->uart);
|
||||||
|
if (collision) {
|
||||||
|
state(ctx, DOSE_SIGNAL_XTIMER);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
(void)ctx;
|
||||||
|
(void)collision;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
static int _send(netdev_t *dev, const iolist_t *iolist)
|
static int _send(netdev_t *dev, const iolist_t *iolist)
|
||||||
{
|
{
|
||||||
dose_t *ctx = container_of(dev, dose_t, netdev);
|
dose_t *ctx = container_of(dev, dose_t, netdev);
|
||||||
@ -459,6 +485,8 @@ send:
|
|||||||
state(ctx, DOSE_SIGNAL_SEND);
|
state(ctx, DOSE_SIGNAL_SEND);
|
||||||
} while (wait_for_state(ctx, DOSE_STATE_ANY) != DOSE_STATE_SEND);
|
} while (wait_for_state(ctx, DOSE_STATE_ANY) != DOSE_STATE_SEND);
|
||||||
|
|
||||||
|
_send_start(ctx);
|
||||||
|
|
||||||
/* Send packet buffer */
|
/* Send packet buffer */
|
||||||
for (const iolist_t *iol = iolist; iol; iol = iol->iol_next) {
|
for (const iolist_t *iol = iolist; iol; iol = iol->iol_next) {
|
||||||
size_t n = iol->iol_len;
|
size_t n = iol->iol_len;
|
||||||
@ -491,6 +519,8 @@ send:
|
|||||||
goto collision;
|
goto collision;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_send_done(ctx, false);
|
||||||
|
|
||||||
/* We probably sent the whole packet?! */
|
/* We probably sent the whole packet?! */
|
||||||
dev->event_callback(dev, NETDEV_EVENT_TX_COMPLETE);
|
dev->event_callback(dev, NETDEV_EVENT_TX_COMPLETE);
|
||||||
|
|
||||||
@ -500,11 +530,13 @@ send:
|
|||||||
return pktlen;
|
return pktlen;
|
||||||
|
|
||||||
collision:
|
collision:
|
||||||
|
_send_done(ctx, true);
|
||||||
DEBUG("dose _send(): collision!\n");
|
DEBUG("dose _send(): collision!\n");
|
||||||
if (--retries < 0) {
|
if (--retries < 0) {
|
||||||
dev->event_callback(dev, NETDEV_EVENT_TX_MEDIUM_BUSY);
|
dev->event_callback(dev, NETDEV_EVENT_TX_MEDIUM_BUSY);
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
|
|
||||||
goto send;
|
goto send;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user