OSDN Git Service

iio: adc: ti_am335x_adc: fix fifo overrun recovery
authorMichael Engl <michael.engl@wjw-solutions.com>
Tue, 3 Oct 2017 12:57:00 +0000 (13:57 +0100)
committerJonathan Cameron <jic23@kernel.org>
Wed, 15 Mar 2017 19:47:23 +0000 (19:47 +0000)
commite83bb3e6f3efa21f4a9d883a25d0ecd9dfb431e1
tree40bd08460f21c216274f21f8c3d7414a77765088
parentc42f8218610aa09d7d3795e5810387673c1f84b6
iio: adc: ti_am335x_adc: fix fifo overrun recovery

The tiadc_irq_h(int irq, void *private) function is handling FIFO
overruns by clearing flags, disabling and enabling the ADC to
recover.

If the ADC is running in continuous mode a FIFO overrun happens
regularly. If the disabling of the ADC happens concurrently with
a new conversion. It might happen that the enabling of the ADC
is ignored by the hardware. This stops the ADC permanently. No
more interrupts are triggered.

According to the AM335x Reference Manual (SPRUH73H October 2011 -
Revised April 2013 - Chapter 12.4 and 12.5) it is necessary to
check the ADC FSM bits in REG_ADCFSM before enabling the ADC
again. Because the disabling of the ADC is done right after the
current conversion has been finished.

To trigger this bug it is necessary to run the ADC in continuous
mode. The ADC values of all channels need to be read in an endless
loop. The bug appears within the first 6 hours (~5.4 million
handled FIFO overruns). The user space application will hang on
reading new values from the character device.

Fixes: ca9a563805f7a ("iio: ti_am335x_adc: Add continuous sampling
support")
Signed-off-by: Michael Engl <michael.engl@wjw-solutions.com>
Cc: <Stable@vger.kernel.org>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
drivers/iio/adc/ti_am335x_adc.c