mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-14 11:59: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
|
// Enable USART TX output
|
||||||
uart->txPinState = TX_PIN_ACTIVE;
|
uart->txPinState = TX_PIN_ACTIVE;
|
||||||
IOConfigGPIOAF(txIO, IOCFG_AF_PP, uart->tx.af);
|
IOConfigGPIOAF(txIO, IOCFG_AF_PP, uart->tx.af);
|
||||||
|
|
||||||
|
// Enable the UART transmitter
|
||||||
|
SET_BIT(s->Handle.Instance->CR1, USART_CR1_TE);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
// TX line is pulled low so don't enable USART TX
|
// 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)
|
void uartTxMonitor(uartPort_t *s)
|
||||||
{
|
{
|
||||||
uartDevice_t *uart = container_of(s, uartDevice_t, port);
|
uartDevice_t *uart = container_of(s, uartDevice_t, port);
|
||||||
IO_t txIO = IOGetByTag(uart->tx.pin);
|
|
||||||
|
|
||||||
if (uart->txPinState == TX_PIN_ACTIVE) {
|
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
|
// Switch TX to an input with pullup so it's state can be monitored
|
||||||
uart->txPinState = TX_PIN_MONITOR;
|
uart->txPinState = TX_PIN_MONITOR;
|
||||||
IOConfigGPIO(txIO, IOCFG_IPU);
|
IOConfigGPIO(txIO, IOCFG_IPU);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue