mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #7405 from photonthunder/samd21_uart_wake
cpu/sam0/periph/uart - wake from sleep on receive line
This commit is contained in:
commit
0292105d78
@ -110,7 +110,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_3,
|
||||
.tx_pad = UART_PAD_TX_2,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
}
|
||||
};
|
||||
|
@ -113,7 +113,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_3,
|
||||
.tx_pad = UART_PAD_TX_2,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
},
|
||||
{
|
||||
@ -123,7 +123,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_C,
|
||||
.rx_pad = UART_PAD_RX_3,
|
||||
.tx_pad = UART_PAD_TX_2,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
}
|
||||
};
|
||||
|
@ -118,7 +118,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_C,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_0,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
},
|
||||
{ /* EXT1 */
|
||||
@ -128,7 +128,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_0,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
},
|
||||
{ /* EXT2/3 */
|
||||
@ -138,7 +138,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_3,
|
||||
.tx_pad = UART_PAD_TX_2,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
}
|
||||
};
|
||||
|
@ -60,7 +60,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_C,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_0,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_PCHCTRL_GEN_GCLK0
|
||||
},
|
||||
{ /* EXT1 header */
|
||||
@ -70,7 +70,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_0,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_PCHCTRL_GEN_GCLK0
|
||||
}
|
||||
};
|
||||
|
@ -118,7 +118,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_0,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
},
|
||||
{
|
||||
@ -128,7 +128,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_0,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
}
|
||||
};
|
||||
|
@ -109,7 +109,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_C,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_2,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
},
|
||||
{
|
||||
@ -119,7 +119,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_D,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_0_RTS_2_CTS_3,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
},
|
||||
{
|
||||
@ -129,7 +129,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_C,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_2,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
},
|
||||
{
|
||||
@ -139,7 +139,7 @@ static const uart_conf_t uart_config[] = {
|
||||
.mux = GPIO_MUX_C,
|
||||
.rx_pad = UART_PAD_RX_1,
|
||||
.tx_pad = UART_PAD_TX_2,
|
||||
.runstdby = 0,
|
||||
.flags = UART_FLAG_NONE,
|
||||
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0
|
||||
}
|
||||
};
|
||||
|
@ -117,6 +117,15 @@ typedef enum {
|
||||
* and CTS on pad 3 */
|
||||
} uart_txpad_t;
|
||||
|
||||
/**
|
||||
* @brief Available SERCOM UART flag selections
|
||||
*/
|
||||
typedef enum {
|
||||
UART_FLAG_NONE = 0x0, /**< No flags set */
|
||||
UART_FLAG_RUN_STANDBY = 0x1, /**< run SERCOM in standby mode */
|
||||
UART_FLAG_WAKEUP = 0x2, /**< wake from sleep on receive */
|
||||
} uart_flag_t;
|
||||
|
||||
/**
|
||||
* @brief UART device configuration
|
||||
*/
|
||||
@ -127,7 +136,7 @@ typedef struct {
|
||||
gpio_mux_t mux; /**< alternative function for pins */
|
||||
uart_rxpad_t rx_pad; /**< pad selection for RX line */
|
||||
uart_txpad_t tx_pad; /**< pad selection for TX line */
|
||||
uint8_t runstdby; /**< allow SERCOM to run in standby mode */
|
||||
uart_flag_t flags; /**< set optional SERCOM flags */
|
||||
uint32_t gclk_src; /**< GCLK source which supplys SERCOM */
|
||||
} uart_conf_t;
|
||||
|
||||
|
@ -80,9 +80,11 @@ int uart_init(uart_t uart, uint32_t baudrate, uart_rx_cb_t rx_cb, void *arg)
|
||||
SERCOM_USART_CTRLA_SAMPR(0x1) |
|
||||
SERCOM_USART_CTRLA_TXPO(uart_config[uart].tx_pad) |
|
||||
SERCOM_USART_CTRLA_RXPO(uart_config[uart].rx_pad) |
|
||||
SERCOM_USART_CTRLA_MODE(0x1) |
|
||||
(uart_config[uart].runstdby ?
|
||||
SERCOM_USART_CTRLA_RUNSTDBY : 0));
|
||||
SERCOM_USART_CTRLA_MODE(0x1));
|
||||
/* Set run in standby mode if enabled */
|
||||
if (uart_config[uart].flags & UART_FLAG_RUN_STANDBY) {
|
||||
dev(uart)->CTRLA.reg |= SERCOM_USART_CTRLA_RUNSTDBY;
|
||||
}
|
||||
|
||||
/* calculate and set baudrate */
|
||||
uint32_t baud = ((((uint32_t)CLOCK_CORECLOCK * 10) / baudrate) / 16);
|
||||
@ -98,6 +100,10 @@ int uart_init(uart_t uart, uint32_t baudrate, uart_rx_cb_t rx_cb, void *arg)
|
||||
NVIC_EnableIRQ(SERCOM0_IRQn + sercom_id(dev(uart)));
|
||||
dev(uart)->CTRLB.reg |= SERCOM_USART_CTRLB_RXEN;
|
||||
dev(uart)->INTENSET.reg |= SERCOM_USART_INTENSET_RXC;
|
||||
/* set wakeup receive from sleep if enabled */
|
||||
if (uart_config[uart].flags & UART_FLAG_WAKEUP) {
|
||||
dev(uart)->CTRLB.reg |= SERCOM_USART_CTRLB_SFDE;
|
||||
}
|
||||
}
|
||||
while (dev(uart)->SYNCBUSY.reg & SERCOM_USART_SYNCBUSY_CTRLB) {}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user