mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-17 05:32:45 +01:00
cpu/sam0_common: implement periph_uart_collision feature
This commit is contained in:
parent
f89d0c7c25
commit
a51fb298dc
@ -322,6 +322,82 @@ void uart_poweroff(uart_t uart)
|
||||
sercom_clk_dis(dev(uart));
|
||||
}
|
||||
|
||||
#ifdef MODULE_PERIPH_UART_COLLISION
|
||||
bool uart_collision_detected(uart_t uart)
|
||||
{
|
||||
/* In case of collision, the CTRLB register
|
||||
* will be in sync during disabling of TX,
|
||||
* then the flag will be set.
|
||||
*/
|
||||
_syncbusy(dev(uart));
|
||||
|
||||
bool collision = dev(uart)->STATUS.bit.COLL;
|
||||
dev(uart)->STATUS.reg = SERCOM_USART_STATUS_COLL;
|
||||
return collision;
|
||||
}
|
||||
|
||||
void uart_collision_detect_enable(uart_t uart)
|
||||
{
|
||||
/* CTRLB is enable protected */
|
||||
dev(uart)->CTRLA.bit.ENABLE = 0;
|
||||
_syncbusy(dev(uart));
|
||||
|
||||
/* clear stale collision flag */
|
||||
dev(uart)->STATUS.reg = SERCOM_USART_STATUS_COLL;
|
||||
|
||||
/* enable collision detection */
|
||||
dev(uart)->CTRLB.bit.COLDEN = 1;
|
||||
|
||||
/* disable RX interrupt */
|
||||
dev(uart)->INTENCLR.bit.RXC = 1;
|
||||
|
||||
/* re-enable UART */
|
||||
dev(uart)->CTRLA.bit.ENABLE = 1;
|
||||
|
||||
/* wait for config to be applied */
|
||||
_syncbusy(dev(uart));
|
||||
}
|
||||
|
||||
static void _drain_rxbuf(SercomUsart *dev)
|
||||
{
|
||||
/* clear readback bytes from receive buffer */
|
||||
while (dev->INTFLAG.bit.RXC) {
|
||||
dev->DATA.reg;
|
||||
}
|
||||
}
|
||||
|
||||
void uart_collision_detect_disable(uart_t uart)
|
||||
{
|
||||
uint32_t ctrlb = dev(uart)->CTRLB.reg;
|
||||
|
||||
/* re-enable TX after collision */
|
||||
ctrlb |= SERCOM_USART_CTRLB_TXEN;
|
||||
|
||||
/* disable collision detection */
|
||||
ctrlb &= ~SERCOM_USART_CTRLB_COLDEN;
|
||||
|
||||
/* CTRLB is enable protected */
|
||||
dev(uart)->CTRLA.bit.ENABLE = 0;
|
||||
_syncbusy(dev(uart));
|
||||
|
||||
dev(uart)->CTRLB.reg = ctrlb;
|
||||
|
||||
/* re-enable UART */
|
||||
dev(uart)->CTRLA.bit.ENABLE = 1;
|
||||
|
||||
/* wait for config to be applied */
|
||||
_syncbusy(dev(uart));
|
||||
|
||||
/* clear bytes from RX buffer */
|
||||
_drain_rxbuf(dev(uart));
|
||||
|
||||
/* re-enable RX complete IRQ */
|
||||
if (uart_ctx[uart].rx_cb) {
|
||||
dev(uart)->INTENSET.bit.RXC = 1;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef MODULE_PERIPH_UART_MODECFG
|
||||
int uart_mode(uart_t uart, uart_data_bits_t data_bits, uart_parity_t parity,
|
||||
uart_stop_bits_t stop_bits)
|
||||
|
@ -16,6 +16,7 @@ config CPU_FAM_SAMD10
|
||||
bool
|
||||
select CPU_COMMON_SAMD21
|
||||
select HAS_PERIPH_DMA
|
||||
select HAS_PERIPH_UART_COLLISION
|
||||
|
||||
config CPU_FAM_SAMD20
|
||||
bool
|
||||
@ -25,11 +26,13 @@ config CPU_FAM_SAMD21
|
||||
bool
|
||||
select CPU_COMMON_SAMD21
|
||||
select HAS_PERIPH_DMA
|
||||
select HAS_PERIPH_UART_COLLISION
|
||||
|
||||
config CPU_FAM_SAMR21
|
||||
bool
|
||||
select CPU_COMMON_SAMD21
|
||||
select HAS_PERIPH_DMA
|
||||
select HAS_PERIPH_UART_COLLISION
|
||||
|
||||
## Definition of specific features
|
||||
config HAS_CPU_SAMD21
|
||||
|
@ -2,4 +2,8 @@ CPU_CORE = cortex-m0plus
|
||||
|
||||
FEATURES_PROVIDED += periph_gpio_fast_read
|
||||
|
||||
ifeq (,$(filter samd20%,$(CPU_MODEL)))
|
||||
FEATURES_PROVIDED += periph_uart_collision
|
||||
endif
|
||||
|
||||
-include $(RIOTCPU)/sam0_common/Makefile.features
|
||||
|
@ -16,6 +16,7 @@ config CPU_COMMON_SAMD5X
|
||||
select HAS_PERIPH_GPIO_TAMPER_WAKE
|
||||
select HAS_PERIPH_HWRNG
|
||||
select HAS_PERIPH_RTC_MEM
|
||||
select HAS_PERIPH_UART_COLLISION
|
||||
select HAS_PERIPH_SPI_ON_QSPI
|
||||
|
||||
config CPU_FAM_SAMD51
|
||||
|
@ -6,5 +6,6 @@ FEATURES_PROVIDED += cortexm_mpu
|
||||
FEATURES_PROVIDED += periph_gpio_tamper_wake
|
||||
FEATURES_PROVIDED += periph_rtc_mem
|
||||
FEATURES_PROVIDED += periph_spi_on_qspi
|
||||
FEATURES_PROVIDED += periph_uart_collision
|
||||
|
||||
include $(RIOTCPU)/sam0_common/Makefile.features
|
||||
|
@ -13,6 +13,7 @@ config CPU_COMMON_SAML1X
|
||||
select HAS_PERIPH_DMA
|
||||
select HAS_PERIPH_GPIO_FAST_READ
|
||||
select HAS_PERIPH_HWRNG
|
||||
select HAS_PERIPH_UART_COLLISION
|
||||
|
||||
config CPU_FAM_SAML10
|
||||
bool
|
||||
|
@ -5,5 +5,6 @@ CPU_CORE = cortex-m23
|
||||
|
||||
FEATURES_PROVIDED += periph_hwrng
|
||||
FEATURES_PROVIDED += periph_gpio_fast_read
|
||||
FEATURES_PROVIDED += periph_uart_collision
|
||||
|
||||
include $(RIOTCPU)/sam0_common/Makefile.features
|
||||
|
@ -14,6 +14,7 @@ config CPU_COMMON_SAML21
|
||||
select HAS_PERIPH_DMA
|
||||
select HAS_PERIPH_GPIO_FAST_READ
|
||||
select HAS_PERIPH_RTC_MEM
|
||||
select HAS_PERIPH_UART_COLLISION
|
||||
|
||||
config CPU_FAM_SAML21
|
||||
bool
|
||||
|
@ -4,6 +4,7 @@ CPU_CORE = cortex-m0plus
|
||||
CPU_MODELS_WITHOUT_HWRNG += samr30%
|
||||
|
||||
FEATURES_PROVIDED += periph_gpio_fast_read
|
||||
FEATURES_PROVIDED += periph_uart_collision
|
||||
|
||||
# Low Power SRAM is *not* retained during Backup Sleep.
|
||||
# It therefore does not fulfill the requirements of the 'backup_ram' interface.
|
||||
|
Loading…
Reference in New Issue
Block a user