serial: stm32: enable / disable wake irqs for mcrtl_gpio wakeup sources
Enable mctrl_gpio wake_irq if device_may_wakeup when usart is suspended, and disable mctrl_gpios wake_irq if device_may_wakeup when usart is resumed. Signed-off-by: Erwan Le Ray <erwan.leray@foss.st.com> Link: https://lore.kernel.org/r/20220203171644.12231-3-erwan.leray@foss.st.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
9978c2f14f
commit
7547d9ab03
@@ -1756,6 +1756,7 @@ static int __maybe_unused stm32_usart_serial_en_wakeup(struct uart_port *port,
|
||||
if (enable) {
|
||||
stm32_usart_set_bits(port, ofs->cr1, USART_CR1_UESM);
|
||||
stm32_usart_set_bits(port, ofs->cr3, USART_CR3_WUFIE);
|
||||
mctrl_gpio_enable_irq_wake(stm32_port->gpios);
|
||||
|
||||
/*
|
||||
* When DMA is used for reception, it must be disabled before
|
||||
@@ -1782,7 +1783,7 @@ static int __maybe_unused stm32_usart_serial_en_wakeup(struct uart_port *port,
|
||||
if (ret)
|
||||
return ret;
|
||||
}
|
||||
|
||||
mctrl_gpio_disable_irq_wake(stm32_port->gpios);
|
||||
stm32_usart_clr_bits(port, ofs->cr1, USART_CR1_UESM);
|
||||
stm32_usart_clr_bits(port, ofs->cr3, USART_CR3_WUFIE);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user