stm32/uart: optimize swap_rx_tx

This commit is contained in:
Alessandro Pezzato 2023-07-19 10:50:40 +02:00
parent 3df2c71e6c
commit 36ff688fab

View file

@ -694,13 +694,10 @@ impl<'d, T: BasicInstance, TxDma, RxDma> Uart<'d, T, TxDma, RxDma> {
let r = T::regs();
#[allow(unused_variables)]
let swap_rx_tx = false;
#[cfg(any(usart_v3, usart_v4))]
let swap_rx_tx = config.swap_rx_tx;
if swap_rx_tx {
// Some chips do not have swap_rx_tx bit
cfg_if::cfg_if! {
if #[cfg(any(usart_v3, usart_v4))] {
if config.swap_rx_tx {
let (rx, tx) = (tx, rx);
rx.set_as_af(rx.af_num(), AFType::Input);
tx.set_as_af(tx.af_num(), AFType::OutputPushPull);
@ -708,6 +705,11 @@ impl<'d, T: BasicInstance, TxDma, RxDma> Uart<'d, T, TxDma, RxDma> {
rx.set_as_af(rx.af_num(), AFType::Input);
tx.set_as_af(tx.af_num(), AFType::OutputPushPull);
}
} else {
rx.set_as_af(rx.af_num(), AFType::Input);
tx.set_as_af(tx.af_num(), AFType::OutputPushPull);
}
}
configure(r, &config, T::frequency(), T::KIND, true, true);