1
0
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:
Sebastian Meiling 2017-09-26 08:36:50 +01:00 committed by GitHub
commit 0292105d78
8 changed files with 33 additions and 18 deletions

View File

@ -110,7 +110,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_3, .rx_pad = UART_PAD_RX_3,
.tx_pad = UART_PAD_TX_2, .tx_pad = UART_PAD_TX_2,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
} }
}; };

View File

@ -113,7 +113,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_3, .rx_pad = UART_PAD_RX_3,
.tx_pad = UART_PAD_TX_2, .tx_pad = UART_PAD_TX_2,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
}, },
{ {
@ -123,7 +123,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_C, .mux = GPIO_MUX_C,
.rx_pad = UART_PAD_RX_3, .rx_pad = UART_PAD_RX_3,
.tx_pad = UART_PAD_TX_2, .tx_pad = UART_PAD_TX_2,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
} }
}; };

View File

@ -118,7 +118,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_C, .mux = GPIO_MUX_C,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_0, .tx_pad = UART_PAD_TX_0,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
}, },
{ /* EXT1 */ { /* EXT1 */
@ -128,7 +128,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_0, .tx_pad = UART_PAD_TX_0,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
}, },
{ /* EXT2/3 */ { /* EXT2/3 */
@ -138,7 +138,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_3, .rx_pad = UART_PAD_RX_3,
.tx_pad = UART_PAD_TX_2, .tx_pad = UART_PAD_TX_2,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
} }
}; };

View File

@ -60,7 +60,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_C, .mux = GPIO_MUX_C,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_0, .tx_pad = UART_PAD_TX_0,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_PCHCTRL_GEN_GCLK0 .gclk_src = GCLK_PCHCTRL_GEN_GCLK0
}, },
{ /* EXT1 header */ { /* EXT1 header */
@ -70,7 +70,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_0, .tx_pad = UART_PAD_TX_0,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_PCHCTRL_GEN_GCLK0 .gclk_src = GCLK_PCHCTRL_GEN_GCLK0
} }
}; };

View File

@ -118,7 +118,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_0, .tx_pad = UART_PAD_TX_0,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
}, },
{ {
@ -128,7 +128,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_0, .tx_pad = UART_PAD_TX_0,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
} }
}; };

View File

@ -109,7 +109,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_C, .mux = GPIO_MUX_C,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_2, .tx_pad = UART_PAD_TX_2,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
}, },
{ {
@ -119,7 +119,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_D, .mux = GPIO_MUX_D,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_0_RTS_2_CTS_3, .tx_pad = UART_PAD_TX_0_RTS_2_CTS_3,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
}, },
{ {
@ -129,7 +129,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_C, .mux = GPIO_MUX_C,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_2, .tx_pad = UART_PAD_TX_2,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
}, },
{ {
@ -139,7 +139,7 @@ static const uart_conf_t uart_config[] = {
.mux = GPIO_MUX_C, .mux = GPIO_MUX_C,
.rx_pad = UART_PAD_RX_1, .rx_pad = UART_PAD_RX_1,
.tx_pad = UART_PAD_TX_2, .tx_pad = UART_PAD_TX_2,
.runstdby = 0, .flags = UART_FLAG_NONE,
.gclk_src = GCLK_CLKCTRL_GEN_GCLK0 .gclk_src = GCLK_CLKCTRL_GEN_GCLK0
} }
}; };

View File

@ -117,6 +117,15 @@ typedef enum {
* and CTS on pad 3 */ * and CTS on pad 3 */
} uart_txpad_t; } 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 * @brief UART device configuration
*/ */
@ -127,7 +136,7 @@ typedef struct {
gpio_mux_t mux; /**< alternative function for pins */ gpio_mux_t mux; /**< alternative function for pins */
uart_rxpad_t rx_pad; /**< pad selection for RX line */ uart_rxpad_t rx_pad; /**< pad selection for RX line */
uart_txpad_t tx_pad; /**< pad selection for TX 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 */ uint32_t gclk_src; /**< GCLK source which supplys SERCOM */
} uart_conf_t; } uart_conf_t;

View File

@ -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_SAMPR(0x1) |
SERCOM_USART_CTRLA_TXPO(uart_config[uart].tx_pad) | SERCOM_USART_CTRLA_TXPO(uart_config[uart].tx_pad) |
SERCOM_USART_CTRLA_RXPO(uart_config[uart].rx_pad) | SERCOM_USART_CTRLA_RXPO(uart_config[uart].rx_pad) |
SERCOM_USART_CTRLA_MODE(0x1) | SERCOM_USART_CTRLA_MODE(0x1));
(uart_config[uart].runstdby ? /* Set run in standby mode if enabled */
SERCOM_USART_CTRLA_RUNSTDBY : 0)); if (uart_config[uart].flags & UART_FLAG_RUN_STANDBY) {
dev(uart)->CTRLA.reg |= SERCOM_USART_CTRLA_RUNSTDBY;
}
/* calculate and set baudrate */ /* calculate and set baudrate */
uint32_t baud = ((((uint32_t)CLOCK_CORECLOCK * 10) / baudrate) / 16); 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))); NVIC_EnableIRQ(SERCOM0_IRQn + sercom_id(dev(uart)));
dev(uart)->CTRLB.reg |= SERCOM_USART_CTRLB_RXEN; dev(uart)->CTRLB.reg |= SERCOM_USART_CTRLB_RXEN;
dev(uart)->INTENSET.reg |= SERCOM_USART_INTENSET_RXC; 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) {} while (dev(uart)->SYNCBUSY.reg & SERCOM_USART_SYNCBUSY_CTRLB) {}