mirror of https://github.com/ARMmbed/mbed-os.git
SiLabs: serial_api: Fix LEUART interrupt dispatch
Conditional when dispatching LEUART irq would always select the RX side due to a bitwise AND being typoed as a logical AND. Second, the TX interrupt was not cleared after processing, causing it to stay in an infinite loop.pull/1501/head
parent
b8ab9fbfed
commit
a7ef4ca830
|
@ -122,20 +122,22 @@ static void usart2_tx_irq() { uart_irq(USART_2, 4, TxIrq); USART_IntClear((USART
|
||||||
#ifdef LEUART0
|
#ifdef LEUART0
|
||||||
static void leuart0_irq()
|
static void leuart0_irq()
|
||||||
{
|
{
|
||||||
if(LEUART_IntGetEnabled(LEUART0) && (LEUART_IF_RXDATAV | LEUART_IF_FERR | LEUART_IFC_PERR | LEUART_IF_RXOF)) {
|
if(LEUART_IntGetEnabled(LEUART0) & (LEUART_IF_RXDATAV | LEUART_IF_FERR | LEUART_IF_PERR | LEUART_IF_RXOF)) {
|
||||||
uart_irq(LEUART_0, 5, RxIrq);
|
uart_irq(LEUART_0, 5, RxIrq);
|
||||||
} else {
|
} else {
|
||||||
uart_irq(LEUART_0, 5, TxIrq);
|
uart_irq(LEUART_0, 5, TxIrq);
|
||||||
|
LEUART_IntClear(LEUART0, LEUART_IFC_TXC);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#ifdef LEUART1
|
#ifdef LEUART1
|
||||||
static void leuart1_irq()
|
static void leuart1_irq()
|
||||||
{
|
{
|
||||||
if(LEUART_IntGetEnabled(LEUART1) && (LEUART_IF_RXDATAV | LEUART_IF_FERR | LEUART_IFC_PERR | LEUART_IF_RXOF)) {
|
if(LEUART_IntGetEnabled(LEUART1) & (LEUART_IF_RXDATAV | LEUART_IF_FERR | LEUART_IF_PERR | LEUART_IF_RXOF)) {
|
||||||
uart_irq(LEUART_1, 6, RxIrq);
|
uart_irq(LEUART_1, 6, RxIrq);
|
||||||
} else {
|
} else {
|
||||||
uart_irq(LEUART_1, 6, TxIrq);
|
uart_irq(LEUART_1, 6, TxIrq);
|
||||||
|
LEUART_IntClear(LEUART1, LEUART_IFC_TXC);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue