Hi Hugo,
On 11/15/23 16:01, Hugo Villeneuve wrote:
On Wed, 15 Nov 2023 12:22:10 +0100 Daniel Mack daniel@zonque.org wrote: Hi Daniel,
The bug has hit us on production units and when it does, sc16is7xx_irq() would spin forever because sc16is7xx_port_irq() keeps seeing an interrupt in the IIR register that is not cleared because the driver does not call into sc16is7xx_handle_rx() unless the RXLVL register reports at least one byte in the FIFO.
I would suggest that you replace the second paragraph or your original commit message with this, it better explains what is the problem.
Good idea, will do.
Also, when the problem happens, you say that "the fill level reporting is off-by-one", so doest it mean that RXLVL can sometimes be non-zero when the bug occurs?
Maybe, but if that happens we would read one byte too less, which doesn't harm as we would get another interrupt later to handle the rest. The problematic case is when we don't read any data at all even though there is something in the FIFO, and the interrupt suggested that as well.
Note that this issue might only occur in revision E of the silicon. And
Is this just a supposition or based on NXP info or some actual tests?
Well, the datasheet states "Errata for Rev. E added 12 August 2011", and as "Revision E" does not seem to refer to a datasheet version, it will most likely be about the silicon revision. And another assumption is that the issue would fixed in subsequent versions of the chip, in case there are any at all.
FTR, this is the document I'm looking at:
https://www.nxp.com/docs/en/data-sheet/SC16IS752_SC16IS762.pdf
there seems to be now way to read the revision code through I2C, so I guess you won't be able to figure out easily whether your chip is affected.
Let me know if I can provide more information.
I have a board with two SC16IS752IPW using SPI interface, but I don't know (yet) what is the revision. I will try to determine it if possible, although I do not see any info on that in the datasheet.
I will also try to reproduce the issue, and test your patch.
Great, thanks!
Best regards, Daniel