summaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>2020-01-21 08:17:02 +0100
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2020-01-22 10:22:31 +0100
commit101aa46bd221b768dfff8ef3745173fc8dbb85ee (patch)
treeb5f56b03ed8669053ed21b23ef38556365412e46 /arch
parentserial: 8250_bcm2835aux: Document struct bcm2835aux_data (diff)
downloadlinux-101aa46bd221b768dfff8ef3745173fc8dbb85ee.tar.xz
linux-101aa46bd221b768dfff8ef3745173fc8dbb85ee.zip
serial: imx: fix a race condition in receive path
The main irq handler function starts by first masking disabled interrupts in the status register values to ensure to only handle enabled interrupts. This is important as when the RX path in the hardware is disabled reading the RX fifo results in an external abort. This checking must be done under the port lock, otherwise the following can happen: CPU1 | CPU2 | irq triggers as there are chars | in the RX fifo | | grab port lock imx_uart_int finds RRDY enabled | and calls imx_uart_rxint which | has to wait for port lock | | disable RX (e.g. because we're | using RS485 with !RX_DURING_TX) | | release port lock read from RX fifo with RX | disabled => exception | So take the port lock only once in imx_uart_int() instead of in the functions called from there. Reported-by: Andre Renaud <arenaud@designa-electronics.com> Cc: stable@vger.kernel.org Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> Link: https://lore.kernel.org/r/20200121071702.20150-1-u.kleine-koenig@pengutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'arch')
0 files changed, 0 insertions, 0 deletions