Hi Piotr, On Tue, Feb 21, 2017 at 09:00:39AM +0100, Piotr Figiel wrote: > On 20.02.2017 20:20, Baruch Siach wrote: > > On Mon, Feb 20, 2017 at 02:54:02PM +0100, Piotr Figiel wrote: > > > I'm looking to find a correct way to disable RX in the I.MX6 UART during > > > TX-ing. I stumbled on the issue described below when working on > > > ~SER_RS485_RX_DURING_TX on custom 3.10 tree (branched from Freescale's/NXP's > > > BSP release) independently to what is now in the main line imx.c, but I see > > > now that the implementation in mainline also seem to have the same problem > > > I'm trying to solve now. I would like to request for comments to > > > confirm/deny whether the issue I raise here is valid and how to best > > > approach this. > > > > > > I'm mostly concerned about the fact that the URXD register must not be > > > accessed (as documented in IMX.6 RM) when RX is disabled (RXEN=0). The issue > > > is that in the following sequence happening during imx_start_tx with > > > ~SER_RS485_RX_DURING_TX set: > > > > > > 1. Acquire spinlock, disable local interrupts (from serial_core.c), > > > 2. Disable RX receiver (RXEN=0 in UCR2), > > > 3. Release spinlock, reenable interrupts. > > > > > > The RX fifo may become not empty between #1 and #2. This will raise > > > interrupt which will be handled after re-enabling interrupts (after #3). ISR > > > in this case will check the status bit of the interrupt and fetch RX FIFO > > > contents, which I understand is forbidden by the documentation and may raise > > > error on the bus [1]. In addition disabling RX IRQ in this procedure, e.g. > > > after #1 doesn't seem to be enough, as the IRQ still may trigger after #1 > > > and will need to be serviced. > > As I understand it, SER_RS485_RX_DURING_TX is for half-duplex RS-485 where > > only one device is allowed to transmit at any given time. Higher level code > > determines when any given device on the bus is allowed to transmit. If Rx FIFO > > becomes non-empty during Tx enable, you have a contention problem to solve. > > That's correct, although I don't want bugs from the user-space or > misbehaving devices on RS-485 to cause errors on the AXI/AHB bus resulting > with possible crash/exception on the CPU core. The reason I write about this > is that the RM explicitly forbids accessing those registers in such case. The trivial solution might be to return early from imx_rxint() when RXEN=0. Would that be sufficient? baruch -- http://baruch.siach.name/blog/ ~. .~ Tk Open Systems =}------------------------------------------------ooO--U--Ooo------------{= - baruch@xxxxxxxxxx - tel: +972.52.368.4656, http://www.tkos.co.il - -- To unsubscribe from this list: send the line "unsubscribe linux-serial" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html