mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-13 11:29:58 +03:00
Enable/disable the UART TX before changing the TX pin mode (#13018)
This commit is contained in:
parent
96ffb3aa3d
commit
bd68d3d4a9
1 changed files with 9 additions and 1 deletions
|
@ -249,6 +249,10 @@ bool checkUsartTxOutput(uartPort_t *s)
|
|||
// Enable USART TX output
|
||||
uart->txPinState = TX_PIN_ACTIVE;
|
||||
IOConfigGPIOAF(txIO, IOCFG_AF_PP, uart->tx.af);
|
||||
|
||||
// Enable the UART transmitter
|
||||
SET_BIT(s->Handle.Instance->CR1, USART_CR1_TE);
|
||||
|
||||
return true;
|
||||
} else {
|
||||
// TX line is pulled low so don't enable USART TX
|
||||
|
@ -262,9 +266,13 @@ bool checkUsartTxOutput(uartPort_t *s)
|
|||
void uartTxMonitor(uartPort_t *s)
|
||||
{
|
||||
uartDevice_t *uart = container_of(s, uartDevice_t, port);
|
||||
IO_t txIO = IOGetByTag(uart->tx.pin);
|
||||
|
||||
if (uart->txPinState == TX_PIN_ACTIVE) {
|
||||
IO_t txIO = IOGetByTag(uart->tx.pin);
|
||||
|
||||
// Disable the UART transmitter
|
||||
CLEAR_BIT(s->Handle.Instance->CR1, USART_CR1_TE);
|
||||
|
||||
// Switch TX to an input with pullup so it's state can be monitored
|
||||
uart->txPinState = TX_PIN_MONITOR;
|
||||
IOConfigGPIO(txIO, IOCFG_IPU);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue